
--binlog_format 옵션은 MySQL의 로그 기능에서 binlog을 기록하는 형식을 결정하는 옵션입니다. binlog_format에는 세 가지 모드가 있습니다: binlog_format = MIXED, binlog_format = STATEMENT, binlog_format = ROW입니다.
1. binlog_format = MIXED 모드
MIXED 모드는 기본 모드입니다. 이 모드는 statement-level log와 row-level log을 모두 기록합니다. 이 모드는 다음과 같은 상황에서 사용됩니다.
* 문장 단위로 로그를 기록할 때
* 로그를 복원할 때
2. binlog_format = STATEMENT 모드
STATEMENT 모드는 문장 단위로 로그를 기록합니다. 이 모드는 다음과 같은 상황에서 사용됩니다.
* 문장 단위로 로그를 기록할 때
* 로그를 복원할 때
그러나, 이 모드는 트랜잭션의 일부가 취소될 때 문제가 발생할 수 있습니다. 예를 들어, UPDATE 문이 INSERT 문과 DELETE 문으로 나누어질 수 있습니다. 이 경우, 로그를 복원할 때 문제가 발생할 수 있습니다.
3. binlog_format = ROW 모드
ROW 모드는 행 단위로 로그를 기록합니다. 이 모드는 다음과 같은 상황에서 사용됩니다.
* 행 단위로 로그를 기록할 때
* 로그를 복원할 때
이 모드는 트랜잭션의 일부가 취소될 때도 문제가 발생하지 않습니다.
이러한 옵션의 선택에 영향을 미치는 요인은 다음과 같습니다:
* 로그의 양: binlog_format = MIXED 모드는 가장 많은 양의 로그를 생성합니다. binlog_format = STATEMENT 모드는 중간의 양을 생성합니다. binlog_format = ROW 모드는 가장 적은 양의 로그를 생성합니다.
* 로그의 복원: binlog_format = MIXED 모드는 가장 빠른 속도로 로그를 복원할 수 있습니다. binlog_format = STATEMENT 모드는 중간의 속도로 로그를 복원할 수 있습니다. binlog_format = ROW 모드는 가장 느린 속도로 로그를 복원할 수 있습니다.
* 트래픽: binlog_format = MIXED 모드는 가장 많은 양의 트래픽을 발생시킵니다. binlog_format = STATEMENT 모드는 중간의 양을 발생시킵니다. binlog_format = ROW 모드는 가장 적은 양의 트래픽을 발생시킵니다.
따라서, 로그의 양, 로그의 복원, 트래픽에 따라 적절한 모드를 선택하여야 합니다.
2025-05-04 01:29