찾다
데이터 베이스RedisCentOS7에서 Redis 클러스터를 구축하는 방법

1. 수동 구성

1. 노드 준비

CentOS7 및 Redis 설치

완전하고 가용성이 높은 클러스터를 보장하려면 노드 수가 6 이상이어야 합니다.

(1) 디렉터리 구조

cluster
├── 9001
│   ├── data
│   │   ├── appendonly.aof
│   │   └── nodes-9001.conf
│   ├── redis-9001.conf
│   └── redis-9001.log
├── 9002
│   ├── data
│   │   ├── appendonly.aof
│   │   └── nodes-9002.conf
│   ├── redis-9002.conf
│   └── redis-9002.log
...

(2 ) 구성 파일 준비

cd cluster
mkdir -p 9001/data 9002/data 9003/data 9004/data 9005/data 9006/data
cp ../redis-6.0.9/redis.conf 9001/redis-9001.conf
vi 9001/redis-9001.conf
    port 9001
    daemonize yes
    bind 192.168.11.40
    dir /root/cluster/9001/data/
    pidfile /var/run/redis_9001.pid
    cluster-enabled yes  # 集群模式运行
    cluster-config-file nodes-9001.conf
    cluster-node-timeout 15000
    # appendonly yes
    logfile "/root/cluster/9001/redis-9001.log"

복사 및 바꾸기: :%s/9001/9002/g:%s/9001/9002/g

(3) 启动服务

/usr/local/redis/bin/redis-server /root/cluster/9001/redis-9001.conf
...
tail 9001/redis-9001.log
kill `cat /var/run/redis_9001.pid`

启动后会自动在 data 目录创建集群配置文件nodes-9001.conf

(3) 서비스 시작

$ cat 9001/data/nodes-9001.conf
8ccdb0963411ebd05ce21952bdd4b7597825afdc :0@0 myself,master - 0 0 0 connected
vars currentEpoch 0 lastVoteEpoch 0
$ /usr/local/redis/bin/redis-cli -h 192.168.11.40 -p 9001
192.168.11.40:9001> cluster nodes
8ccdb0963411ebd05ce21952bdd4b7597825afdc :9001@19001 myself,master - 0 0 0 connected
시작 후 자동으로 클러스터 구성 파일이 생성됩니다.

데이터 디렉터리 -9001.conf의 노드. 클러스터의 노드 정보가 변경되면 노드는 자동으로 클러스터 상태를 이 구성 파일에 저장합니다. 수동으로 수정하지 않는 것이 가장 좋습니다. 시작 시 클러스터 구성 파일이 있는 경우 노드는 구성 파일 콘텐츠를 사용하여 클러스터 정보

$ /usr/local/redis/bin/redis-cli -h 192.168.11.40 -p 9001
192.168.11.40:9001> cluster meet 192.168.11.40 9002
OK
192.168.11.40:9001> cluster nodes
8ccdb0963411ebd05ce21952bdd4b7597825afdc 192.168.11.40:9001@19001 myself,master - 0 0 0 connected
5786e3237c7fa413ed22465d15be721f95e72cfa 192.168.11.40:9002@19002 master - 0 1620703357871 1 connected

노드 ID

를 초기화합니다. 노드 ID

: 클러스터의 노드를 고유하게 식별하는 데 사용되는 40자리 16진수 문자열입니다. 노드 ID는 한 번만 생성되며 다시 시작할 때마다 실행 ID가 변경됩니다2. 노드 핸드쉐이크

    노드 핸드쉐이크 클러스터 모드에서 실행되는 노드들은 서로를 인식하기 위해 Gossip 프로토콜을 통해 서로 통신합니다
  • 192.168.11.40:9001> set hello world
    (error) CLUSTERDOWN Hash slot not served
    192.168.11.40:9001> cluster info
    cluster_state:fail
    cluster_slots_assigned:0
    cluster_slots_ok:0
    cluster_slots_pfail:0
    cluster_slots_fail:0
    cluster_known_nodes:6
    cluster_size:0
    ...

    cluster Meet는

    Asynchronous
  • 명령으로, 노드끼리 상태 데이터 정보를 교환하고, 실행 후 즉시 반환하며, 내부적으로 대상 노드와 핸드셰이크 통신을 수행하는 기능입니다.
  • Node 9001은 9002 노드 정보를 생성합니다. 로컬로 객체를 전송하고 Meet 메시지를 보냅니다
  • Node 9002 Meet 메시지를 받은 후 9001 노드 정보를 저장하고 pong 메시지에 응답합니다

이후 노드 9001과 9002는 ping/pong을 통해 정기적으로 서로 통신합니다. 메시지

클러스터에서

Any

노드는 클러스터 미팅 명령을 실행할 수 있습니다. 새 노드에 참여하기 위해 핸드셰이크 상태는 메시지를 통해 클러스터 내에 전파됩니다. 다른 노드는 자동으로 새 노드를 검색하고 핸드셰이크 프로세스를 시작합니다

노드가 핸드셰이크를 설정한 후에는 클러스터가 정상적으로 작동할 수 없습니다. 이때 클러스터는 오프라인 상태이며 모든 데이터 읽기 및 쓰기가 금지됩니다. 슬롯이 노드에 할당되지 않았기 때문에 클러스터는 슬롯을 노드에 매핑을 완료할 수 없습니다

/usr/local/redis/bin/redis-cli -h 192.168.11.40 -p 9001 cluster addslots {0..5461}
/usr/local/redis/bin/redis-cli -h 192.168.11.40 -p 9002 cluster addslots {5462..10922}
/usr/local/redis/bin/redis-cli -h 192.168.11.40 -p 9003 cluster addslots {10923..16383}
3. 슬롯 할당

Redis 클러스터는 모든 데이터를

16384

슬롯에 매핑합니다. 모든 슬롯

이 노드에 할당된 경우에만 클러스터가 온라인 상태로 들어갑니다.

슬롯 할당:

192.168.11.40:9001> cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3
...
192.168.11.40:9001> cluster nodes
cebb7ed63d469748d4015ede6b4a0f5ff59c9322 192.168.11.40:9006@19006 master - 0 1620704406746 0 connected
1b7785f80c4712c6ba4abd71cc93027fa85a02f8 192.168.11.40:9005@19005 master - 0 1620704406000 4 connected
8ccdb0963411ebd05ce21952bdd4b7597825afdc 192.168.11.40:9001@19001 myself,master - 0 1620704404000 2 connected 0-5461
9408059de8b2dd712f0a9381a3b7aad561aef206 192.168.11.40:9004@19004 master - 0 1620704407753 5 connected
85ceb9826e8aa003169c46fb4ba115c72002d4f9 192.168.11.40:9003@19003 master - 0 1620704407000 3 connected 10923-16383
5786e3237c7fa413ed22465d15be721f95e72cfa 192.168.11.40:9002@19002 master - 0 1620704408763 1 connected 5462-10922

클러스터 정보 보기:

192.168.11.40:9004> cluster replicate 8ccdb0963411ebd05ce21952bdd4b7597825afdc
OK
192.168.11.40:9005> cluster replicate 5786e3237c7fa413ed22465d15be721f95e72cfa
OK
192.168.11.40:9006> cluster replicate 85ceb9826e8aa003169c46fb4ba115c72002d4f9
OK

슬롯 처리를 담당하는 각 노드에는 슬레이브 노드가 있어야 나중에 복원할 수 있습니다. 자동 장애 조치가 실패합니다

처음 시작한 노드와 슬롯에 할당된 노드가 모두 마스터 노드입니다. 슬레이브 노드는 마스터 노드 슬롯 정보 및 관련 데이터를 복사하는 역할을 담당합니다

192.168.11.40:9001> cluster nodes
cebb7ed63d469748d4015ede6b4a0f5ff59c9322 192.168.11.40:9006@19006 slave 85ceb9826e8aa003169c46fb4ba115c72002d4f9 0 1620704825926 3 connected
1b7785f80c4712c6ba4abd71cc93027fa85a02f8 192.168.11.40:9005@19005 slave 5786e3237c7fa413ed22465d15be721f95e72cfa 0 1620704825000 1 connected
8ccdb0963411ebd05ce21952bdd4b7597825afdc 192.168.11.40:9001@19001 myself,master - 0 1620704824000 2 connected 0-5461
9408059de8b2dd712f0a9381a3b7aad561aef206 192.168.11.40:9004@19004 slave 8ccdb0963411ebd05ce21952bdd4b7597825afdc 0 1620704824921 2 connected
85ceb9826e8aa003169c46fb4ba115c72002d4f9 192.168.11.40:9003@19003 master - 0 1620704824000 3 connected 10923-16383
5786e3237c7fa413ed22465d15be721f95e72cfa 192.168.11.40:9002@19002 master - 0 1620704823914 1 connected 5462-10922
wget https://cache.ruby-lang.org/pub/ruby/2.7/ruby-2.7.3.tar.gz
tar -zxvf ruby-2.7.3.tar.gz
cd ruby-2.7.3
./configure --prefix=/usr/local/ruby
make
make install
cd /usr/local/ruby
cp bin/ruby /usr/local/bin
cp bin/gem /usr/local/bin

2. redis-trib.rb를 사용합니다. 클러스터 구축(구식)

【Redis5.0 이후 클러스터 구축을 위해 redis-cli 사용】

redis-trib.rb는 Ruby로 구현된 Redis

클러스터 관리 도구

입니다. 클러스터 관련 명령은 클러스터 생성, 검사, 슬롯 마이그레이션 및 밸런싱과 같은 일반적인 운영 및 유지 관리 작업을 단순화하는 데 도움이 되도록 내부적으로 사용됩니다.
wget http://rubygems.org/downloads/redis-4.2.5.gem
gem install -l redis-4.2.5.gem
gem list

해결하세요(openssl(openssl과 유사)

$ gem install -l redis-4.2.5.gem
ERROR:  Loading command: install (LoadError)
	cannot load such file -- zlib
ERROR:  While executing gem ... (NoMethodError)
    undefined method `invoke_with_build_args' for nil:NilClass

redis-trib.rb

yum -y install zlib-devel
cd ruby-2.7.3/ext/zlib
ruby ./extconf.rb
make
make install

2 설치. 클러스터 만들기

cp /{redis_home}/src/redis-trib.rb /usr/local/bin
redis-trib.rb

가 자동으로 노드 핸드셰이크 및 슬롯 할당 프로세스를 완료합니다.

  • 이 마스터 노드와 슬레이브 노드가 동일한 시스템에 할당되지 않도록 하는 것이 가장 좋습니다. 아래 노드 목록의 순서는 마스터-슬레이브 역할을 결정하는 데 사용되며 그 다음은 슬레이브 노드여야 합니다. 슬롯/데이터가 포함되지 않은 노드. 그렇지 않으면 클러스터 생성이 거부됩니다. 3. redis-cli를 사용하여 클러스터를 구축하세요

    # --replicas 1:指定集群中每个主节点配备几个从节点
    redis-trib.rb create --replicas 1 192.168.11.40:9001 192.168.11.40:9002 192.168.11.40:9003 192.168.11.40:9004 192.168.11.40:9005 192.168.11.40:9006
    # 集群完整性检查
    redis-trib.rb check 192.168.11.40:9001

위 내용은 CentOS7에서 Redis 클러스터를 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Redis 거래를 처리하는 방법Redis 거래를 처리하는 방법Apr 10, 2025 pm 05:24 PM

REDIS 거래는 원자력, 일관성, 격리 및 지속성 (산) 속성을 보장하고 다음과 같이 작동합니다. 트랜잭션 시작 : 다중 명령을 사용하십시오. 레코드 명령 : redis 명령을 여러 개 실행합니다. 커밋 또는 롤백 트랜잭션 : exec 명령을 사용하여 트랜잭션을 커밋하거나 Discard 명령을 사용하여 거래를 롤백합니다. 커밋 : 오류가 없으면 EXEC 명령은 트랜잭션을 저지르고 모든 명령은 데이터베이스에 원자 적으로 적용됩니다. 롤백 : 오류가 있으면 Discard 명령이 트랜잭션을 롤백하고 모든 명령이 폐기되고 데이터베이스 상태는 변경되지 않았습니다.

Redis 명령을 다시 시작하는 방법Redis 명령을 다시 시작하는 방법Apr 10, 2025 pm 05:21 PM

Redis는 두 가지 방식으로 다시 시작할 수 있습니다. 서비스를 중단하지 않고 원활한 다시 시작하여 클라이언트가 운영을 계속할 수 있습니다. 하드 재시작은 프로세스를 즉시 종료하여 클라이언트가 데이터를 분리하고 손실하게 만듭니다. 심각한 오류를 수정하거나 데이터를 정리 해야하는 경우에만 대부분의 경우 원활한 재시작을 사용하는 것이 좋습니다.

Redis 클러스터를 다시 시작하는 방법Redis 클러스터를 다시 시작하는 방법Apr 10, 2025 pm 05:18 PM

Redis 클러스터 재시작 단계는 다음과 같습니다. 닫고 명확한 데이터 및 로그. 시드 노드를 시작하십시오. 새 클러스터를 만듭니다. 나머지 노드를 추가하십시오. 클러스터 상태를 확인하십시오.

Redis의 다른 사례가 어떻게 의사 소통하는지Redis의 다른 사례가 어떻게 의사 소통하는지Apr 10, 2025 pm 05:15 PM

Redis 인스턴스 간의 커뮤니케이션을위한 몇 가지 메커니즘이 있습니다 : Pub/Sub : Publish/Sub Mode, 효율적이고 낮은 긴장 메시징이 가능합니다. 클러스터 모드 : 분산 배포 방법, 고 가용성 및 결함 공차를 제공합니다. 크로스 인스턴스 명령 : 임시 운영 또는 관리 목적에 적합한 명령을 다른 인스턴스로 직접 전송할 수 있습니다.

Redis로 멀티 스레딩을 구현하는 방법Redis로 멀티 스레딩을 구현하는 방법Apr 10, 2025 pm 05:12 PM

Redis는 원자로 모드, 스레드 풀 및 내부 멀티 스레딩 메커니즘을 영리하게 결합하여 멀티 스레딩을 통해 멀티 코어 CPU를 효과적으로 활용하여 처리량 개선, 리소스 활용 최적화, 낮은 지연성 유지 및 확장 성 향상 및 다양한 부하 요구를 충족시켜야합니다.

현재 Redis 버전을 보는 방법현재 Redis 버전을 보는 방법Apr 10, 2025 pm 05:09 PM

이 안내서는 현재 Redis 버전을 결정하는 두 가지 방법을 제공합니다. 정보 명령을 사용하여 버전 번호를 얻습니다. -version 옵션을 사용하여 버전 번호를 직접 표시하십시오. 버전 번호는 기본 버전 번호, 보조 버전 번호 및 개정 번호로 구성되며 각각 주요 버전 업데이트, 기능 향상 및 사소한 버그 수정을 나타냅니다.

Redis로 모든 데이터를 정리하는 방법Redis로 모든 데이터를 정리하는 방법Apr 10, 2025 pm 05:06 PM

모든 Redis 데이터를 청소하는 방법 : Redis 2.8 이상 : Flushall 명령은 모든 키 값 쌍을 삭제합니다. Redis 2.6 이상 : DEL 명령을 사용하여 키를 하나씩 삭제하거나 Redis 클라이언트를 사용하여 메소드를 삭제하십시오. 대안 : Redis 서비스를 다시 시작하거나 (주의해서 사용) Redis 클라이언트 (예 : Flushall () 또는 FlushDB ())를 사용하십시오.

목록 유형 Redis를 저장하는 방법목록 유형 Redis를 저장하는 방법Apr 10, 2025 pm 05:03 PM

Redis는 내부 배열을 사용하여 목록 유형을 저장하고 배열의 각 요소는 멤버를 나타내는 문자열 값입니다. Redis는 또한 배열의 요소 수를 추적하는 카운터를 유지합니다. LPUSH 또는 RPUSH 명령을 사용하는 경우 Redis는 카운터를 업데이트하고 새로운 요소를 배열에 삽입하거나 추가합니다. LRANGE 명령은 주어진 범위 내에서 멤버를 반환하고 LSET는 지정된 인덱스에서 멤버를 업데이트하고 LREM은 주어진 값과 일치하는 멤버를 제거합니다. Redis의 목록 유형 저장 메소드는 효율적인 삽입, 삭제 및 검색 작업을 지원합니다.

See all articles

핫 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를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.