2.4 KiB
2.4 KiB
clog 日志格式说明
通常 clog 文件中包含多种类型的日志,其中 OB_LOG_SUBMIT 为主要的日志类型,表示对应的 clog 日志为其他模块(非 clog 模块)提交的日志,包含事务模块向 clog 提交的事务日志。本节介绍事务日志的打印格式。
事务日志的打印格式主要包含三部分:摘要(abstract)、头部(header)和主体(content)。日志形式如下所示:
$$$abstract |header ||| |||content
摘要
摘要描述了日志记录在日志文件中的相关信息,内容形式如下所示:
file_id:*** offset:*** len:*** OB_LOG_SUBMIT
下表列出了字段名的详细信息。
| 字段名 | 说明 |
|---|---|
| file_id | clog 日志文件名 |
| offset | 日志记录在日志文件中的偏移量 |
| len | 日志记录的长度 |
| OB_LOG_SUBMIT | clog 日志类型为 OB_LOG_SUBMIT |
头部
头部描述了日志记录自身的相关信息,内容形式如下所示:
ObLogEntryHeader:{magic:***, version:***, type:***, partition_key:***, log_id:***, data_len:***, generation_timestamp:***, epoch_id:***, proposal_id:***, submit_timestamp:***, is_batch_committed:***, is_trans_log:***, data_checksum:***, active_memstore_version:***, header_checksum:***}
下表列出了部分字段名的详细信息。
| 字段名 | 说明 |
|---|---|
| partition_key | 日志记录对应的数据分区的分区标识符 |
| log_id | 日志记录的标识符,可看作日志序列号 |
| generation_timestamp_ | 日志记录产生的时间点(Unix 时间戳) |
| epoch_id | 选举相关变量,选举周期标识符(Unix 时间戳) |
| proposal_id | Paxos 协议相关变量 |
| is_trans_log | 日志记录是否是事务记录 |
主体
主体描述了该日志记录包含的数据。如果该日志记录是事务日志记录,内容形式如下所示:
Trans: log_type:***, trans_inc:*** {[trans_log]}||| [mutator]
下表列出了部分字段名的详细信息。
| 字段名 | 说明 |
|---|---|
log_type |
事务日志的类型 |
trans_id |
事务日志对应的事务标识符 |
[trans_log] |
事务日志的相关信息 |
[mutator] |
如果事务日志类型为 redo,则该日志包含事务修改内容 |
由于 OceanBase 数据库限制一条日志记录的大小,因此当一个事务的修改数据量较大时,可能产生多条 redo 类型的事务日志记录。