다음을 통해 공유


방법: 피어 투 피어 트랜잭션 복제 구성(SQL Server Management Studio)

이 항목에서는 3개의 노드로 구성된 피어 투 피어 트랜잭션 복제 토폴로지를 만든 다음 이 토폴로지에 노드를 추가하는 방법을 설명합니다. 이 항목에서는 먼저 각 단계에 대한 개요를 제공한 다음 각 단계를 보다 상세히 설명합니다.

  • 초기 토폴로지에는 서버 A, 서버 B, 서버 C가 포함됩니다. 토폴로지 생성 시 피어 데이터베이스에서 어떤 작업도 발생하지 않는다고 가정합니다. 토폴로지를 만들려면 다음을 수행하십시오.
    1. 서버 A, 서버 B, 서버 C에서 배포를 구성합니다.
      로컬 또는 원격 배포자를 사용할 수 있습니다. 원격 배포자를 사용하는 경우 원격 배포자가 단일 실패 지점이 될 수 있으므로 모든 노드에 같은 원격 배포자를 사용하지 않는 것이 좋습니다. 배포자에 대한 자세한 내용은 배포 구성을 참조하십시오.
    2. 새 게시 마법사를 사용하여 서버 A에 게시를 만듭니다.
    3. 게시 속성 - <Publication> 대화 상자를 사용하여 피어 투 피어 복제용 게시를 설정합니다.
    4. 서버 A의 데이터베이스를 서버 B서버 C로 복원하는 방법을 사용하거나 수동으로 서버 B서버 C의 스키마와 데이터를 초기화합니다. 모든 노드의 스키마는 동일해야 합니다.
    5. 피어 투 피어 토폴로지 구성 마법사를 사용하여 서버 B서버 C를 토폴로지에 추가합니다. 서버를 추가하면 각 서버에 게시가 생성되고 토폴로지의 다른 서버에 있는 게시에 대한 구독이 생성됩니다.
      게시된 테이블에 ID 열이 있는 경우 서버 B서버 C의 테이블에 대해 ID 범위의 초기값을 다시 설정합니다.
  • 토폴로지가 생성된 후 서버 D를 추가합니다. 기존 토폴로지에 노드 추가 시 작업이 발생 중이며 시스템 중단은 최소화되어야 한다고 가정합니다. 기존 토폴로지에 노드를 추가하려면 다음을 수행하십시오.
    1. 서버 D에서 배포를 구성합니다.
    2. 서버 A의 데이터베이스를 서버 D로 복원하여 서버 D의 스키마 및 데이터를 초기화합니다.
    3. 피어 투 피어 토폴로지 구성 마법사를 사용하여 서버 D를 토폴로지에 추가합니다. 서버 D를 추가하면 서버 D에 게시가 생성되고 서버 A서버 D 간에 구독이 생성됩니다.
      게시된 테이블에 ID 열이 있는 경우 서버 D의 테이블에 대해 ID 범위의 초기값을 다시 설정해야 합니다.
      이때 서버 D는 모든 서버로 변경 내용을 보내고 모든 서버에서 변경 내용을 받을 수 있지만 모든 변경 내용은 서버 B서버 C와 연결된 서버 A를 통해 전달되어야 합니다. 서버 D와 다른 노드 간에 구독을 추가하려면 4단계로 이동합니다. 구독을 더 추가할 필요는 없지만 구독을 추가하면 서버 A서버 D 사이만 연결되어 있을 때보다 내결함성이 향상될 수 있습니다.
    4. 토폴로지를 중지합니다. 모든 변경을 중지되고 모든 서버를 동기화합니다.
    5. 피어 투 피어 토폴로지 구성 마법사를 사용하여 서버 D와 다른 노드 간에 구독을 추가합니다.

피어 투 피어 복제 토폴로지 만들기

다음 일련의 과정에서는 3개의 노드로 구성된 피어 투 피어 토폴로지를 만드는 방법을 설명합니다.

[!참고] 토폴로지가 구성되면 Microsoft SQL Server 에이전트가 각 노드에서 실행되고 있는지 여부와 로그 판독기 에이전트 및 배포 에이전트가 실행되고 있는지 여부를 확인하십시오. SQL Server 에이전트에 대한 자세한 내용은 SQL Server 에이전트 시작을 참조하십시오. 에이전트 시작 및 중지 방법은 방법: 복제 에이전트 시작 및 중지(SQL Server Management Studio)를 참조하십시오.

각 노드에 대해 배포를 구성하려면

  1. Microsoft SQL Server Management Studio 에서 서버 A에 연결합니다. 서버 B서버 C에 대해서도 이 구성 프로세스를 반복해야 합니다.

  2. 서버 노드를 확장하고 복제 폴더를 마우스 오른쪽 단추로 클릭한 다음 배포 구성을 클릭합니다.

  3. 배포 구성 마법사의 배포자 페이지에서 배포자를 선택합니다.

    로컬 배포자를 사용하려면 '<ServerName>'을(를) 자체 배포자로 사용합니다. SQL Server에서 배포 데이터베이스와 로그를 만듭니다를 선택합니다. 원격 배포자를 사용하려면 다음 서버를 배포자로 사용을 선택한 다음 서버를 선택합니다. 서버는 미리 배포자로 구성되어 있어야 하며 해당 배포자를 사용하도록 게시자를 설정해야 합니다. 자세한 내용은 방법: 배포자에서 원격 게시자 설정(SQL Server Management Studio)을 참조하십시오.

    원격 배포자를 선택하면 서버 A에서 배포자로의 연결에 대한 관리 암호 페이지에서 암호를 입력해야 합니다. 이 암호는 원격 배포자에서 서버 A를 게시자로 설정할 때 지정한 암호와 일치해야 합니다.

  4. 스냅숏 폴더 페이지에서 스냅숏 폴더를 지정합니다.

    스냅숏 폴더는 공유하도록 지정된 디렉터리일 뿐이며 이 폴더에 읽기/쓰기 작업을 수행하려면 에이전트에게 충분한 액세스 권한이 있어야 합니다. 이 디렉터리는 첫 번째 노드에서의 복제에 필요한 개체를 저장합니다. 이 디렉터리는 다른 노드에서의 피어 투 피어 복제에는 사용되지 않지만 배포자를 구성하는 데 필요합니다. 폴더의 적절한 보안 유지 방법은 스냅숏 폴더 보안 설정을 참조하십시오.

  5. 배포 데이터베이스 페이지에서 배포 데이터베이스의 이름을 지정합니다.

    배포 데이터베이스에는 트랜잭션, 메타데이터 및 기록 데이터가 저장됩니다.

  6. 게시자 페이지에서 필요에 따라 다른 게시자가 서버 A를 원격 배포자로 설정할 수 있습니다.

    다른 게시자가 서버 A를 원격 배포자로 설정하는 경우 게시자에서 배포자로의 연결에 대한 배포자 암호 페이지에서 암호를 입력해야 합니다.

  7. 마법사 작업 페이지에서 필요에 따라 구성 설정을 스크립팅합니다. 자세한 내용은 복제 스크립팅을 참조하십시오.

첫 번째 노드에서 게시를 만들려면

  1. SQL Server Management Studio 에서 서버 A로 연결한 다음 서버 노드를 확장합니다.

  2. 복제 폴더를 확장한 다음 로컬 게시 폴더를 마우스 오른쪽 단추로 클릭합니다.

  3. 새 게시를 클릭합니다.

  4. 새 게시 마법사의 게시 데이터베이스 페이지에서 게시하려는 데이터베이스를 선택합니다.

  5. 게시 유형 페이지에서 트랜잭션 게시를 선택합니다.

  6. 아티클 페이지에서 게시할 데이터베이스 개체를 선택합니다.

    아티클 속성을 클릭하여 아티클 속성을 보고 수정합니다. 다음 속성은 변경할 수 없습니다.

    • 대상 개체 이름
    • 대상 개체 소유자
    • <ACTION> 배달 형식 옵션(여기서 ACTION은 INSERT, UPDATE 또는 DELETE임)을 <ACTION> 문 또는 열 목록이 없는 <ACTION> 문으로 설정할 수 없습니다.
  7. 테이블 행 필터 페이지에서 필터를 정의할 수 없습니다. 피어 투 피어 게시 필터링은 지원되지 않습니다.

  8. 스냅숏 에이전트 페이지에서 즉시 스냅숏 만들기의 선택을 취소합니다.

  9. 에이전트 보안 페이지에서 스냅숏 에이전트 및 로그 판독기 에이전트에 대한 자격 증명을 지정합니다.

    각 에이전트에 필요한 사용 권한에 대한 자세한 내용은 복제 에이전트 보안 모델복제 보안을 위한 최선의 구현 방법을 참조하십시오.

  10. 마법사 작업 페이지에서 필요에 따라 게시를 스크립팅합니다. 자세한 내용은 복제 스크립팅을 참조하십시오.

  11. 마법사 완료 페이지에서 게시의 이름을 지정합니다. 게시 이름이 토폴로지 내에서 동일해야 피어 투 피어 토폴로지 구성 마법사에서 각 노드에 대한 게시를 만들 때 이 이름을 사용할 수 있습니다.

피어 투 피어 복제용 게시를 설정하려면

  1. 서버 A에서 복제 폴더를 확장한 다음 로컬 게시 폴더를 확장합니다.

  2. 생성된 게시를 마우스 오른쪽 단추로 클릭한 다음 속성을 클릭합니다.

  3. 게시 속성 - <Publication> 대화 상자의 구독 옵션 페이지에서 피어 투 피어 구독 허용 속성에 대해 True 값을 선택합니다.

  4. 확인을 클릭합니다. 

각 노드에서 스키마와 데이터를 초기화하려면

  • 다음 방법 중 하나로 피어를 초기화할 수 있습니다.

    • 수동. SSIS(Integration Services), 스크립트 또는 다른 방법을 사용하여 서버 A에서 서버 B서버 C로 스키마 및 데이터를 복사합니다. 이러한 서버를 피어로 구성하기 전에 서버 B서버 C의 스키마와 데이터가 서버 A의 스키마 및 데이터와 동일한지 확인합니다.
    • 서버 A의 게시 데이터베이스 백업을 서버 B서버 C로 복원. 데이터베이스 백업 및 복원 방법은 SQL Server의 데이터베이스 백업 및 복원을 참조하십시오.
      ms152536.note(ko-kr,SQL.90).gif중요:
      데이터베이스를 복원할 때 KEEP_REPLICATION 옵션(Transact-SQL 의 경우) 또는 복제 설정 유지 옵션(SQL Server Management Studio 의 경우)을 지정하지 않습니다. 피어 투 피어 토폴로지 구성 마법사를 실행하면 복제에서 데이터베이스를 적절히 구성합니다.
      백업에 전체 데이터베이스가 포함되어 있으므로 각 피어 데이터베이스가 초기화될 때 게시 데이터베이스의 완전한 복사본이 포함됩니다. 행 필터나 열 필터가 테이블에 지정된 경우에도 백업에 게시에 대한 아티클로 지정되지 않은 테이블 및 모든 데이터가 포함되어 있습니다. 백업이 복원된 후에 필요 없는 개체나 데이터를 제거하는 작업은 관리자나 응용 프로그램이 수행해야 합니다. 후속 동기화 시 데이터 변경 내용은 아티클로 지정된 테이블에 적용될 때만 복제됩니다.

초기 구성 과정에서 토폴로지에 노드를 추가하려면

  1. 서버 A에서 만든 게시를 마우스 오른쪽 단추로 클릭한 다음 피어 투 피어 토폴로지 구성을 클릭합니다. 피어 투 피어 구성 옵션을 보기 위해 게시 노드를 새로 고쳐야 하는 경우가 있을 수 있습니다.

  2. 피어 투 피어 토폴로지 구성 마법사의 게시 페이지에서는 서버 A에서 만든 게시가 선택됩니다.

  3. 피어 페이지에서 서버 B를 추가하고 나서 서버 C에 대해 이 프로세스를 반복합니다.

    1. SQL Server 추가를 클릭합니다.
    2. 서버에 연결 대화 상자에서 서버 B로 연결합니다. 이제 서버 B피어 서버 인스턴스 열에 표시됩니다.
    3. 피어 데이터베이스 메뉴에서 서버 B의 데이터베이스를 선택합니다.

    [!참고] 서버 A도 표시되지만 이미 구성되어 있으므로 서버 A에 대해서는 해당 확인란을 선택하지 않도록 합니다.

  4. 로그 판독기 에이전트 보안 페이지에서 각 노드의 로그 판독기 에이전트에 대한 자격 증명을 지정합니다.

    로그 판독기 에이전트에 필요한 사용 권한에 대한 자세한 내용은 복제 에이전트 보안 모델복제 보안을 위한 최선의 구현 방법을 참조하십시오.

  5. 배포 에이전트 보안 페이지에서 각 노드에 구독을 제공하는 배포 에이전트에 대한 자격 증명을 지정합니다.

    피어 투 피어 토폴로지 구성 마법사는 각각의 구독에 독립 에이전트가 지정되는 밀어넣기 구독을 만듭니다. 배포 에이전트는 배포자에서 실행됩니다. 3개의 노드로 구성된 토폴로지에서 각 노드는 다른 두 노드에 대한 구독을 포함하므로 각 배포자에서 두 개의 배포 에이전트가 실행됩니다.

    배포 에이전트에 필요한 사용 권한에 대한 자세한 내용은 복제 에이전트 보안 모델복제 보안을 위한 최선의 구현 방법을 참조하십시오.

  6. 새 피어 초기화 페이지에서 피어 데이터베이스를 수동으로 만들었거나,원래 게시 데이터베이스의 백업을 복원했고 백업 이후에 데이터베이스가 변경되지 않았습니다를 선택합니다.

  7. 마법사를 완료합니다. 피어 투 피어 토폴로지를 작성하는 중 페이지에서 서버 A에 대한 로그 판독기가 이미 존재한다는 경고가 발생합니다. 이 메시지는 정보 제공용이므로 별도의 작업은 필요하지 않습니다.

  8. 게시된 테이블에 ID 열이 있는 경우 사용자가 서버 A의 테이블에 할당한 ID 범위는 복원 후 서버 B서버 C의 테이블에서도 사용됩니다. DBCC CHECKIDENT를 사용하여 서버 B서버 C에 있는 테이블의 ID 초기값을 다시 설정하여 각 서버에 대해 다른 범위가 사용되도록 해야 합니다.

    ID 범위 관리 방법은 ID 열 복제의 "ID 범위 수동 관리를 위한 범위 할당" 섹션을 참조하십시오.

기존의 토폴로지에 노드 추가

다음 일련의 절차에서는 기존의 토폴로지에 새 노드를 추가하는 방법을 단계별로 설명합니다.

  • 첫 번째 세 개의 절차로 구성된 1단계에서는 서버 A서버 D 간의 구독을 만들어 서버 D를 토폴로지에 부분적으로 연결하는 방법을 설명합니다. 이렇게 하면 서버 A, 서버 B서버 C에서 계속해서 변경 내용이 발생할 수 있습니다. 서버 A서버 D 간의 구독이 생성되는 즉시 서버 D에서 변경이 시작될 수 있습니다.
  • 마지막 두 개의 절차로 구성된 2단계에서는 서버 B서버 D 간의 구독과 서버 C서버 D 간의 구독을 만들어 서버 D를 토폴로지에 완전히 연결하는 방법을 설명합니다. 이 단계에서 시스템을 중지해야 합니다.
    2단계가 필요하지는 않지만 이 단계를 실행하면 서버 A서버 D 사이만 연결되어 있을 때보다 내결함성이 향상될 수 있습니다.

[!참고] 토폴로지가 구성되면 SQL Server 에이전트가 각 노드에서 실행되고 있는지 여부와 로그 판독기 에이전트 및 배포 에이전트가 실행되고 있는지 여부를 확인하십시오. SQL Server 에이전트 시작 방법은 SQL Server 에이전트 시작을 참조하십시오. 복제 에이전트 시작 방법은 방법: 복제 에이전트 시작 및 중지(SQL Server Management Studio)를 참조하십시오.

새 노드에 대한 배포를 구성하려면

  • 이전 섹션의 절차를 참조합니다.

새 노드를 초기화하려면

  • 서버 D에서 서버 A의 최근 게시 데이터베이스 백업을 복원합니다. 서버 B 또는 서버 C의 백업도 복원할 수 있는데 이를 위해서는 서버 D를 추가할 때 해당 서버 및 데이터베이스를 피어 투 피어 토폴로지 구성 마법사의 게시 페이지에서 선택해야 합니다.

토폴로지에 새 노드를 추가하려면(서버 A와 서버 D 간의 구독 생성)

  1. 서버 A에서 만든 게시를 마우스 오른쪽 단추로 클릭한 다음 피어 투 피어 토폴로지 구성을 클릭합니다.

  2. 피어 투 피어 토폴로지 구성 마법사의 게시 페이지에서는 서버 A에서 만든 게시가 선택됩니다.

  3. 피어 페이지에서 다음과 같이 서버 D를 추가합니다.

    1. SQL Server 추가를 클릭합니다.
    2. 서버에 연결 대화 상자에서 서버 D로 연결합니다. 이제 서버 D피어 서버 인스턴스 열에 표시됩니다.
    3. 피어 데이터베이스 메뉴에서 서버 D의 데이터베이스를 선택합니다.

    [!참고] 서버 A도 표시되지만 이미 구성되어 있으므로 서버 A에 대해서는 해당 확인란을 선택하지 않도록 합니다.

  4. 로그 판독기 에이전트 보안 페이지에서 서버 D의 로그 판독기 에이전트에 대한 자격 증명을 지정합니다.

  5. 배포 에이전트 보안 페이지에서 서버 A서버 D의 배포 에이전트에 대한 자격 증명을 지정합니다.

  6. 새 피어 초기화 페이지에서 원래 게시 데이터베이스의 백업을 복원했고, 백업 이후에 게시 데이터베이스가 변경되었습니다를 선택합니다.

    이 옵션을 선택하면 서버 A의 백업에 포함되지 않은 변경 내용이 서버 D에서 복원된 데이터베이스로 배달됩니다. 피어 투 피어 복제용 게시를 설정하면 allow_initialize_from_backup 게시 속성은 True로 설정됩니다. 복제는 즉시 서버 A에 있는 게시 데이터베이스의 변경 내용을 추적하기 시작하므로 다른 피어는 복원 후에 최신 상태가 될 수 있습니다.

  7. 찾아보기 단추를 클릭하여 사용된 백업을 찾으면 복제는 백업에서 LSN(로그 시퀀스 번호)을 읽습니다. 서버 A의 게시 데이터베이스에서 LSN이 높은 모든 변경 내용은 서버 D로 배달됩니다.

  8. 마법사를 완료합니다.

  9. 게시된 테이블에 ID 범위가 있는 경우 서버 A의 각 테이블에 할당한 ID 범위는 서버 D에서도 사용됩니다. 시스템을 중지하고 모든 노드를 완전히 연결하지 않은 경우 다음 절차에 따라 서버 D의 각 테이블에 알맞은 적절한 범위를 할당합니다. 모든 노드를 완전히 연결한 경우에는 중지가 완료된 후에 범위를 할당할 수 있습니다.

    1. 서버 D에서 sp_requestpeerresponse(Transact-SQL)를 실행하고 출력 매개 변수 @request_id를 검색합니다.
    2. 기본적으로 배포 에이전트는 연속적으로 실행되도록 설정되므로 토큰이 모든 노드로 자동 전송됩니다. 배포 에이전트가 연속 모드로 실행되지 않을 경우에는 에이전트를 실행합니다. 자세한 내용은 Programming Replication Agent Executables 또는 방법: 복제 에이전트 시작 및 중지(SQL Server Management Studio)를 참조하십시오.
    3. sp_helppeerresponses(Transact-SQL)를 실행한 다음 b 단계에서 검색된 @request_id 값을 제공하여 모든 노드가 피어 요청을 받았음을 나타낼 때까지 기다립니다.
    4. DBCC CHECKIDENT를 사용하여 서버 D에 있는 각 테이블의 초기값을 다시 설정하고 적절한 범위가 사용되고 있는지 확인합니다.

토폴로지를 중지하려면

  1. 피어 투 피어 토폴로지에 게시된 테이블에 대한 모든 작업을 중지합니다.

  2. 서버 A, 서버 B, 서버 C서버 D의 데이터베이스에서 sp_requestpeerresponse(Transact-SQL)를 실행하고 출력 매개 변수 @request_id를 검색합니다.

  3. 기본적으로 배포 에이전트는 연속적으로 실행되도록 설정되므로 토큰이 모든 노드로 자동 전송됩니다. 배포 에이전트가 연속 모드로 실행되지 않을 경우에는 에이전트를 실행합니다. 자세한 내용은 Programming Replication Agent Executables 또는 방법: 복제 에이전트 시작 및 중지(SQL Server Management Studio)를 참조하십시오.

  4. sp_helppeerresponses(Transact-SQL)를 실행한 다음 2단계에서 검색된 @request_id 값을 제공하여 모든 노드가 피어 요청을 받았음을 나타낼 때까지 기다립니다.

  5. 새 ID 범위를 할당합니다(필요한 경우). 이제 나머지 구독을 추가하여 토폴로지를 완전히 연결할 수 있습니다.

새 노드에 대한 추가 구독을 만들려면

  1. 서버 A에서 만든 게시를 마우스 오른쪽 단추로 클릭한 다음 피어 투 피어 토폴로지 구성을 클릭합니다.

  2. 피어 투 피어 토폴로지 구성 마법사의 게시 페이지에서는 서버 A에서 만든 게시가 선택됩니다.

  3. 피어 페이지에서 서버 B를 추가하고 나서 서버 C서버 D에 대해 이 프로세스를 반복합니다.

    1. SQL Server 추가를 클릭합니다.
    2. 서버에 연결 대화 상자에서 서버 B로 연결합니다. 이제 서버 B피어 서버 인스턴스 열에 표시됩니다.
    3. 피어 데이터베이스 메뉴에서 서버 B의 데이터베이스를 선택합니다.

    [!참고] 서버 A도 표시되지만 이미 구성되어 있으므로 서버 A에 대해서는 해당 확인란을 선택하지 않도록 합니다.

  4. 로그 판독기 에이전트 보안 페이지에서 서버 B, 서버 C서버 D의 로그 판독기 에이전트에 대한 자격 증명을 지정합니다.

  5. 배포 에이전트 보안 페이지에서 서버 A, 서버 B, 서버 C서버 D의 배포 에이전트에 대한 자격 증명을 지정합니다.

  6. 새 피어 초기화 페이지에서 피어 데이터베이스를 수동으로 만들었거나,원래 게시 데이터베이스의 백업을 복원했고 백업 이후에 데이터베이스가 변경되지 않았습니다를 선택합니다. 모든 노드에 이미 데이터가 있지만 이 옵션을 지정하면 각 노드 간에 적절한 구독 관계가 설정됩니다.

  7. 마법사를 완료합니다.

참고 항목

개념

피어 투 피어 트랜잭션 복제
복제 에이전트 개요

도움말 및 정보

SQL Server 2005 지원 받기