이 문서는 지원되지 않는 버전의 PostgreSQL을위한 것입니다.
당신은에 대해 같은 페이지를 보려고 할 수 있습니다PostgreSQL : 문서 : 17 : 53.5. 논리 스트리밍 복제 와이즈 토토버전 또는 위에 나열된 다른 지원 버전 중 하나입니다.

52.5. 논리 스트리밍 복제 윈 토토

이 섹션은 논리적 복제 윈 토토을 설명합니다.start_replication 슬롯 slot_name 논리복제 명령.

논리 스트리밍 복제 프로토콜은 물리적 스트리밍 복제 프로토콜의 프리미티브를 기반으로합니다.

PostgreSQL논리 디코딩은 출력 플러그인을 지원합니다.pgoutput내장 된 논리 복제에 사용되는 표준입니다.

52.5.1. 논리 스트리밍 복제 매개 변수

사용start_replication명령,pgoutput다음 옵션을 수락합니다.

proto_version

프로토콜 버전. 현재 전용 버전1지원됩니다. 유효한 버전이 필요합니다.

publication_names

구독 할 출판 이름 목록 (변경 사항을 수신). 개별 간행물 이름은 표준 객체 이름으로 취급되며 필요와 동일하게 인용 할 수 있습니다. 적어도 하나의 출판물 이름이 필요합니다.

52.5.2. 논리 복제 프로토콜 메시지

개별 프로토콜 메시지는 다음 하위 섹션에서 설명합니다. 개별 메시지는에 설명되어 있습니다.PostgreSQL : 문서 : 12 : 52.9. 논리 복제 토토 캔 형식.

모든 최상위 윈 토토 메시지는 메시지 유형 바이트로 시작합니다. 코드로 캐릭터로 표시되지만 이것은 인코딩이 관련된 서명 된 바이트입니다.

스트리밍 복제 윈 토토은 메시지 길이를 제공하기 때문에 최상위 윈 토토 메시지가 헤더에 길이를 포함 할 필요가 없습니다.

52.5.3. 논리 복제 프로토콜 메시지 흐름

제외start_replication명령 및 재생 진행 메시지, 모든 정보는 백엔드에서 프론트 엔드로만 흐릅니다.

논리적 복제 프로토콜은 개별 트랜잭션을 하나씩 보냅니다. 이것은 시작과 커밋 메시지 쌍 사이의 모든 메시지가 동일한 트랜잭션에 속함을 의미합니다.

모든 전송 트랜잭션에는 0 이상의 DML 메시지가 포함됩니다 (삽입, 업데이트, 삭제). 계단식 설정의 경우 원점 메시지가 포함될 수도 있습니다. 원점 메시지는 트랜잭션이 다른 복제 노드에서 시작되었음을 나타냅니다. 논리적 복제 프로토콜의 범위의 복제 노드는 거의 무엇이든 할 수 있으므로 유일한 식별자는 원점 이름입니다. 필요한 경우 (필요한 경우) 이것을 처리하는 것은 다운 스트림의 책임입니다. Origin 메시지는 트랜잭션의 DML 메시지 전에 항상 전송됩니다.

모든 DML 메시지에는 관련 OID가 포함되어 있으며, 발행인의 관계를 식별합니다. 주어진 관계 OID에 대한 첫 번째 DML 메시지 전에 해당 관계의 스키마를 설명하는 관계 메시지가 전송됩니다. 그 후, 마지막 관계 메시지가 전송 된 이후 관계의 정의가 변경되면 새로운 관계 메시지가 전송됩니다. (윈 토토은 클라이언트가 필요에 따라 많은 관계에 대해이 메타 데이터를 기억할 수 있다고 가정합니다.)

관계 메시지는 OID로 열 유형을 식별합니다. 내장 유형의 경우 클라이언트가 해당 유형 OID를 로컬로 찾을 수 있다고 가정하므로 추가 데이터가 필요하지 않습니다. 구축되지 않은 유형 OID의 경우 해당 OID와 관련된 유형 이름을 제공하기 위해 관계 메시지 전에 유형 메시지가 전송됩니다. 따라서 관계 열의 유형을 구체적으로 식별 해야하는 클라이언트는 유형 메시지의 내용을 캐시하고 먼저 해당 캐시를 참조하여 유형 OID가 정의되어 있는지 확인해야합니다. 그렇지 않은 경우 로컬에서 유형 OID를 찾아보십시오.