개발자 Q&A

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

2025.04.04 06:48

--replicate-rewrite-db 옵션에 대한 이해

목록
  • MySQL도깨비 17시간 전 2025.04.04 06:48 새글
  • 3
    1
제가 MySQL의 replication을 공부 중인데, --replicate-rewrite-db 옵션에 대한 이해가 잘 안됩니다.

--replicate-rewrite-db 옵션의 기본 동작은 무엇이며, 특정 데이터베이스 이름을 제외하고 복제할 때 어떻게 작동하는지 궁금합니다.

예를 들어, 특정 데이터베이스 이름 "mydb"를 제외하고 복제하고 싶을 때, 어떻게 옵션을 사용해야 하나요?

그리고, 이 옵션에 의해 복제되는 데이터베이스 이름이 변경되는 경우, 원본 데이터베이스 이름과 복제 데이터베이스 이름이 다를 경우, 어떤 문제가 발생할 수 있는지 궁금합니다.

    댓글목록

    profile_image
    나우호스팅  17시간 전



    --replicate-rewrite-db 옵션의 기본 동작은 MySQL replication에서 데이터베이스 이름을 변경하여 복제하는 것입니다.

    이 옵션을 사용하면, 특정 데이터베이스 이름을 제외하고 복제할 수 있습니다. 예를 들어, --replicate-rewrite-db='mydb->mydb_copy' 옵션을 사용하면, 'mydb' 데이터베이스를 'mydb_copy' 데이터베이스로 복제할 수 있습니다.

    만약 원본 데이터베이스 이름과 복제 데이터베이스 이름이 다를 경우, 다음과 같은 문제가 발생할 수 있습니다.

    - 데이터베이스 이름이 다르기 때문에, 원본 데이터베이스에서 수행한 쿼리가 복제 데이터베이스에서 실패할 수 있습니다.
    - 데이터베이스 이름이 다르기 때문에, 복제 데이터베이스에서 수행한 쿼리가 원본 데이터베이스에서 실패할 수 있습니다.
    - 데이터베이스 이름이 다르기 때문에, 데이터베이스의 스키마가 다를 수 있습니다.

    따라서, 원본 데이터베이스 이름과 복제 데이터베이스 이름이 다를 경우, 데이터베이스 이름을 일치시키거나, 데이터베이스 이름을 변경하는 쿼리를 수행하여 문제를 해결해야 합니다.

    예를 들어, 'mydb' 데이터베이스에서 수행한 쿼리가 'mydb_copy' 데이터베이스에서 실패하는 경우, 다음과 같이 쿼리를 수정하여 문제를 해결할 수 있습니다.

    #hostingforum.kr
    sql
    
    UPDATE mydb_copy SET column_name = 'new_value' WHERE id = 1;
    
    


    또는, 데이터베이스 이름을 일치시키는 쿼리를 수행할 수 있습니다.

    #hostingforum.kr
    sql
    
    RENAME TABLE mydb_copy TO mydb;
    
    


    이러한 방법으로, 원본 데이터베이스 이름과 복제 데이터베이스 이름이 다를 경우, 문제를 해결할 수 있습니다.

    2025-04-04 06:49

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

검색

게시물 검색