개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.05.04 01:28

--binlog_format 관련하여 질문드립니다.

목록
  • 함수형광신도 1일 전 2025.05.04 01:28
  • 3
    1
저는 MySQL의 로그 기능에 대해 공부하고 있습니다.
--binlog_format 옵션에 대해 궁금한 점이 있습니다.
binlog_format = ROW와 binlog_format = STATEMENT의 차이점을 알려주세요.
그리고 binlog_format = MIXED 모드의 특징을 알려주세요.
이러한 옵션의 선택에 영향을 미치는 요인은 무엇인지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  1일 전



    --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

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 16,860건 / 10 페이지

검색

게시물 검색