데이터 베이스 Redis Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

Jun 02, 2023 am 10:19 AM
redis docker sentinel

1. 개요

redis 클러스터는 Redis 노드 그룹 간에 고가용성과 샤딩을 달성할 수 있습니다. 클러스터에는 1개의 마스터 노드와 여러 개의 슬레이브 노드가 있습니다. 마스터 노드에 장애가 발생하면 슬레이브 노드가 새 마스터로 선택되어야 합니다. 그러나 Redis 자체(많은 클라이언트 포함)에는 자동 오류 검색을 구현하고 활성-대기 전환을 수행하는 기능이 없으며 자동 오류 복구를 달성하려면 외부 모니터링 솔루션이 필요합니다.

redis sentinel은 공식적으로 권장되는 고가용성 솔루션입니다. 이는 노드 모니터링, 알림, 자동 장애 복구 및 클라이언트 구성 검색 서비스를 제공할 수 있는 Redis 클러스터용 모니터링 및 관리 도구입니다.

2. 발생한 문제

1. Docker 호스트 네트워크

docker가 호스트 네트워크를 사용할 때 Windows 및 Mac에서는 작동하지 않으며(해결책 없음) 결국 Windows를 포기하고 Centos를 사용했습니다. 클러스터를 배포합니다.

2. 호스트 네트워크를 사용하지 않고 Sentinel 연결 문제

호스트 네트워크를 사용하지 않고 Sentinel 클러스터에 연결할 경우 마스터 노드 포트를 지정하면 연결이 정상적으로 될 수 있습니다. , sentinel은 마스터 노드에서 이를 획득합니다. 획득한 IP는 컨테이너의 가상 IP이므로 클러스터가 정상적으로 연결되지 않습니다.

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

3. 빌드 프로세스

1. 디렉토리 구조

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

2. sentinel 구성 파일 Docker를 기반으로 redis-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
로그인 후 복사

3、 sentinel3.conf

#端口号
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
로그인 후 복사

3, docker-compose.yml

#端口号
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
로그인 후 복사

4. centos를 사용하여 클러스터를 배포하고 효과를 테스트합니다

1 sentinel1


2을 통해 클러스터 연결을 테스트합니다.

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법3. 활성 및 대기 스위칭을 보려면 마스터를 닫으세요.

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

sentinel 일반 연결

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

마스터 노드는 16379에서 16381

으로 전환됩니다.

Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법

위 내용은 Docker를 기반으로 redis-sentinel 클러스터를 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker에서 거울을 만드는 방법 Docker에서 거울을 만드는 방법 Apr 15, 2025 am 11:27 AM

Docker 이미지 생성 단계 : 빌드 지침이 포함 된 Dockerfile을 작성하십시오. Docker 빌드 명령을 사용하여 터미널에 이미지를 빌드하십시오. Docker 태그 명령을 사용하여 이미지를 태그하고 이름과 태그를 지정하십시오.

Docker의 이미지를 업데이트하는 방법 Docker의 이미지를 업데이트하는 방법 Apr 15, 2025 pm 12:03 PM

Docker 이미지를 업데이트하는 단계는 다음과 같습니다. 최신 이미지 태그 가져 오기 새 이미지 특정 태그의 이전 이미지 삭제 (선택 사항) 컨테이너를 다시 시작하십시오 (필요한 경우)

Docker Desktop을 사용하는 방법 Docker Desktop을 사용하는 방법 Apr 15, 2025 am 11:45 AM

Docker Desktop을 사용하는 방법? Docker Desktop은 로컬 머신에서 Docker 컨테이너를 실행하는 도구입니다. 사용 단계는 다음과 같습니다. 1. Docker Desktop 설치; 2. Docker Desktop을 시작하십시오. 3. Docker 이미지를 만듭니다 (Dockerfile 사용); 4. Docker Image 빌드 (Docker 빌드 사용); 5. 도커 컨테이너를 실행하십시오 (Docker Run 사용).

Docker 이미지를 저장하는 방법 Docker 이미지를 저장하는 방법 Apr 15, 2025 am 11:54 AM

Docker에 이미지를 저장하려면 Docker Commit 명령을 사용하여 지정된 컨테이너의 현재 상태가 포함 된 새 이미지를 만들 수 있습니다. 구문 : Docker Commit [옵션] 컨테이너 ID 이미지 이름. 이미지를 저장소에 저장하려면 Docker Push 명령 인 Syntax : Docker 푸시 이미지 이름 [: tag]을 사용할 수 있습니다. 저장된 이미지를 가져 오려면 Docker Pull 명령 인 Syntax : Docker Pull Image Name [: Tag]을 사용할 수 있습니다.

Docker 버전을 읽는 방법 Docker 버전을 읽는 방법 Apr 15, 2025 am 11:51 AM

Docker 버전을 얻으려면 다음 단계를 수행 할 수 있습니다. Docker 명령 "Docker -version"을 실행하여 클라이언트 및 서버 버전을 볼 수 있습니다. Mac 또는 Windows의 경우 Docker Desktop GUI의 버전 탭 또는 Aff Docker Desktop 메뉴를 통해 버전 정보를 볼 수도 있습니다.

Docker의 파일을 외부로 복사하는 방법 Docker의 파일을 외부로 복사하는 방법 Apr 15, 2025 pm 12:12 PM

Docker의 외부 호스트에 파일을 복사하는 방법 : Docker CP 명령 사용 : Docker CP 실행 [옵션] & lt; 컨테이너 경로 & gt; & lt; 호스트 경로 & gt;. 데이터 볼륨 사용 : 호스트에서 디렉토리를 만들고 -V 매개 변수를 사용하여 양방향 파일 동기화를 달성하기 위해 컨테이너를 만들 때 컨테이너에 디렉토리를 장착하십시오.

Docker 컨테이너의 이름을 확인하는 방법 Docker 컨테이너의 이름을 확인하는 방법 Apr 15, 2025 pm 12:21 PM

단계를 따르면 Docker 컨테이너 이름을 쿼리 할 수 ​​있습니다. 모든 컨테이너 (Docker PS)를 나열하십시오. 컨테이너 목록을 필터링합니다 (GREP 명령 사용). 컨테이너 이름 ( "이름"열에 위치)을 가져옵니다.

Docker가 컨테이너를 빠져 나가는 방법 Docker가 컨테이너를 빠져 나가는 방법 Apr 15, 2025 pm 12:15 PM

도커 컨테이너를 종료하는 4 가지 명령 사용 Docker Kill & lt; Container_name & gt; 호스트 터미널의 명령 (힘 출구)

See all articles