Redis의 마스터-슬레이브 동기화 메커니즘은 Redis 마스터와 슬레이브 간의 데이터 동기화를 보장할 수 있습니다.
동기화 방법에는 전체 복사 및 증분 복사가 포함됩니다. >
슬레이브가 처음 시작하면 마스터에 접속해서 PSYNC를 보낸다. psync {runId} {offset} 형식
{runId} 为master的运行id;{offset}为slave自己的复制偏移量。 slave第一次连接master时,slave并不知道master的runId,也不知道自己偏移量,这时候slave会传一个问号和-1,告诉master节点是第一次同步。格式为psync ? -1마스터가 psync ? -1을 수신하고 슬레이브가 전체 복사를 원한다는 것을 알게 되면 슬레이브에 runId 및 오프셋을 알리고 fullresync {runId 명령으로 응답합니다. } {오프셋 }. 동시에 마스터는 bgsave 명령을 실행하여 rdb 파일을 생성하고 해당 기간 동안의 모든 쓰기 명령이 버퍼에 기록됩니다.
slave接受到master的回复命令后,会保存master的runId和offset,slave此时处于同步状态。 slave处于同步状态,如果此时收到请求,当配置参数slave-server-stale-data yes时,会响应当前请求;slave-server-stale-data no,返回错误。master bgsave가 실행되어 rdb 파일을 슬레이브로 보냅니다. rdb 파일이 전송된 후 버퍼에 있는 쓰기 명령이 슬레이브로 전송되기 시작합니다.
슬레이브는 rdb 파일을 수신하고 이전 데이터를 모두 삭제한 후 rdb 파일 로드를 시작합니다.
rdb 파일 동기화가 완료된 후 슬레이브는 마스터 버퍼에서 전송된 모든 쓰기 명령을 실행합니다.
이후에는 마스터가 쓰기 명령을 실행할 때마다 동일한 쓰기 명령을 슬레이브에 보냅니다.
증분 복사네트워크 중단이나 명령 손실 등의 비정상적인 상황이 발생하면 마스터-슬레이브 연결이 복원될 때 슬레이브 노드는 이전에 자체 복사된 오프셋과 마스터 노드의 실행 ID를 저장했습니다. 따라서 psync {runId} {offset} 형식의 부분 복제 작업이 필요한 psync 매개 변수로 마스터 노드에 전송됩니다.
psync 명령을 받은 후 마스터 노드는 먼저 매개 변수 runId가 자신과 일치하는지 확인합니다. 일치하는 경우 현재 마스터 노드가 이전에 복사된 다음 자체 복제 백로그 버퍼에서 검색한다는 의미입니다. 오프셋 이후의 데이터가 버퍼에 존재하면 +continue 응답이 슬레이브 노드로 전송되어 부분 복사가 수행될 수 있음을 나타내며 그렇지 않으면 전체 복사가 수행됩니다. 마스터 노드는 마스터-슬레이브 복제가 정상 상태로 진입하도록 오프셋에 따라 복제 백로그 버퍼의 데이터를 슬레이브 노드에 보냅니다.
위 내용은 Redis에서 데이터 동기화를 달성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!