Files
oceanbase/docs/cn/ob-admin/clog-format-introduction.md
He Wang 53f7a64888 add docs website config (#251)
* add docs website config

* move files in doc/ to docs/
2021-07-30 21:20:25 +08:00

65 lines
2.4 KiB
Markdown

# clog 日志格式说明
通常 clog 文件中包含多种类型的日志,其中 OB_LOG_SUBMIT 为主要的日志类型,表示对应的 clog 日志为其他模块(非 clog 模块)提交的日志,包含事务模块向 clog 提交的事务日志。本节介绍事务日志的打印格式。
事务日志的打印格式主要包含三部分:摘要(abstract)、头部(header)和主体(content)。日志形式如下所示:
```bash
$$$abstract |header ||| |||content
```
## 摘要
摘要描述了日志记录在日志文件中的相关信息,内容形式如下所示:
```bash
file_id:*** offset:*** len:*** OB_LOG_SUBMIT
```
下表列出了字段名的详细信息。
| 字段名 | 说明 |
| --- | --- |
| file_id | clog 日志文件名 |
| offset | 日志记录在日志文件中的偏移量 |
| len | 日志记录的长度 |
| OB_LOG_SUBMIT | clog 日志类型为 OB_LOG_SUBMIT |
## 头部
头部描述了日志记录自身的相关信息,内容形式如下所示:
```bash
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 | 日志记录是否是事务记录 |
## 主体
主体描述了该日志记录包含的数据。如果该日志记录是事务日志记录,内容形式如下所示:
```bash
Trans: log_type:***, trans_inc:*** {[trans_log]}||| [mutator]
```
下表列出了部分字段名的详细信息。
| 字段名 | 说明 |
| --- | --- |
| `log_type` | 事务日志的类型 |
| `trans_id` | 事务日志对应的事务标识符 |
| `[trans_log]` | 事务日志的相关信息 |
| `[mutator]` | 如果事务日志类型为 redo,则该日志包含事务修改内容 |
由于 OceanBase 数据库限制一条日志记录的大小,因此当一个事务的修改数据量较大时,可能产生多条 redo 类型的事务日志记录。