1. 개요
redis 클러스터는 Redis 노드 그룹 간에 고가용성과 샤딩을 달성할 수 있습니다. 클러스터에는 1개의 마스터 노드와 여러 개의 슬레이브 노드가 있습니다. 마스터 노드에 장애가 발생하면 슬레이브 노드가 새 마스터로 선택되어야 합니다. 그러나 Redis 자체(많은 클라이언트 포함)에는 자동 오류 검색을 구현하고 활성-대기 전환을 수행하는 기능이 없으며 자동 오류 복구를 달성하려면 외부 모니터링 솔루션이 필요합니다.
redis sentinel은 공식적으로 권장되는 고가용성 솔루션입니다. 이는 노드 모니터링, 알림, 자동 장애 복구 및 클라이언트 구성 검색 서비스를 제공할 수 있는 Redis 클러스터용 모니터링 및 관리 도구입니다.
2. 발생한 문제
1. Docker 호스트 네트워크
docker가 호스트 네트워크를 사용할 때 Windows 및 Mac에서는 작동하지 않으며(해결책 없음) 결국 Windows를 포기하고 Centos를 사용했습니다. 클러스터를 배포합니다.
2. 호스트 네트워크를 사용하지 않고 Sentinel 연결 문제
호스트 네트워크를 사용하지 않고 Sentinel 클러스터에 연결할 경우 마스터 노드 포트를 지정하면 연결이 정상적으로 될 수 있습니다. , sentinel은 마스터 노드에서 이를 획득합니다. 획득한 IP는 컨테이너의 가상 IP이므로 클러스터가 정상적으로 연결되지 않습니다.
3. 빌드 프로세스
1. 디렉토리 구조
2. sentinel 구성 파일
1, sentin el2.conf#端口号 port 26379 dir /tmp # mymaster:自定义集群名,2:投票数量必须2个sentinel才能判断主节点是否失败 sentinel monitor mymaster <ip> <port> 2 # 指的是超过5000秒,且没有回复,则判定主节点不可达 sentinel down-after-milliseconds mymaster 5000 # 表示在故障转移的时候最多有numslaves在同步更新新的master sentinel parallel-syncs mymaster 1 # 故障转移超时时间 sentinel failover-timeout mymaster 5000
#端口号 port 26380 dir /tmp # mymaster:自定义集群名,2:投票数量必须2个sentinel才能判断主节点是否失败 sentinel monitor mymaster <ip> <port> 2 # 指的是超过5000秒,且没有回复,则判定主节点不可达 sentinel down-after-milliseconds mymaster 5000 # 表示在故障转移的时候最多有numslaves在同步更新新的master sentinel parallel-syncs mymaster 1 # 故障转移超时时间 sentinel failover-timeout mymaster 5000
#端口号 port 26381 dir /tmp # mymaster:自定义集群名,2:投票数量必须2个sentinel才能判断主节点是否失败 sentinel monitor mymaster <ip> <port> 2 # 指的是超过5000秒,且没有回复,则判定主节点不可达 sentinel down-after-milliseconds mymaster 5000 # 表示在故障转移的时候最多有numslaves在同步更新新的master sentinel parallel-syncs mymaster 1 # 故障转移超时时间 sentinel failover-timeout mymaster 5000
1 sentinel1
2을 통해 클러스터 연결을 테스트합니다.
3. 활성 및 대기 스위칭을 보려면 마스터를 닫으세요.
sentinel 일반 연결
마스터 노드는 16379에서 16381
으로 전환됩니다.
위 내용은 Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!