3 master + 3 slave
Memandangkan ia hanya untuk ujian, saya hanya menggunakan 1 pelayan di sini Simulate
senarai redis
Buat direktori pada pelayan untuk Store redis. fail penempatan kelompok. Laluan yang saya letakkan di sini ialah /root/redis-cluster
Buat redis-1, redis-2, redis-3, redis-4, redis-5 dalam direktori /opt/docker/redis-cluster, folder redis-6
mkdir -p /opt/docker/redis-cluster/{redis-1,redis-2,redis-3,redis-4,redis-5,redis-6} #创建持久化目录 mkdir -p /opt/docker/redis-cluster/redis-1/data mkdir -p /opt/docker/redis-cluster/redis-2/data mkdir -p /opt/docker/redis-cluster/redis-3/data mkdir -p /opt/docker/redis-cluster/redis-4/data mkdir -p /opt/docker/redis-cluster/redis-5/data mkdir -p /opt/docker/redis-cluster/redis-6/data
cluster-enabled yes # 开启集群 cluster-config-file nodes.conf # 集群配置文件 cluster-node-timeout 5000 # 集群节点多少时间未响应视为该节点丢失 appendonly yes port 6379 # redis监听端口 masterauth passwd123 #设置master节点密码 requirepass passwd123 #设置密码
Nota: Nilai port tidak boleh semuanya 6379 , mengikut nombor port yang ditetapkan dalam senarai redis di atas, tetapkan nombor port 6379~6384 untuk redis-1 ~ redis-6 dalam urutan
Gunakan daocloud terus di sini Alamat imej redis yang disediakan ialah daocloud.io/library/redis:6.0.4
Buat fail docker-compose.yml dalam folder /root/redis-cluster.
kandungan fail docker-compose.yml adalah seperti berikut:
version: '3.1' services: # redis1配置 redis1: image: daocloud.io/library/redis:6.0.4 container_name: redis-1 restart: always network_mode: "host" volumes: - /opt/docker/redis-cluster/redis-1/data:/data - /opt/docker/redis-cluster/redis-1/redis.conf:/usr/local/etc/redis/redis.conf command: ["redis-server", "/usr/local/etc/redis/redis.conf"] # redis2配置 redis2: image: daocloud.io/library/redis:6.0.4 container_name: redis-2 restart: always network_mode: "host" volumes: - /opt/docker/redis-cluster/redis-2/data:/data - /opt/docker/redis-cluster/redis-2/redis.conf:/usr/local/etc/redis/redis.conf command: ["redis-server", "/usr/local/etc/redis/redis.conf"] # redis3配置 redis3: image: daocloud.io/library/redis:6.0.4 container_name: redis-3 restart: always network_mode: "host" volumes: - /opt/docker/redis-cluster/redis-3/data:/data - /opt/docker/redis-cluster/redis-3/redis.conf:/usr/local/etc/redis/redis.conf command: ["redis-server", "/usr/local/etc/redis/redis.conf"] # redis4配置 redis4: image: daocloud.io/library/redis:6.0.4 container_name: redis-4 restart: always network_mode: "host" volumes: - /opt/docker/redis-cluster/redis-4/data:/data - /opt/docker/redis-cluster/redis-4/redis.conf:/usr/local/etc/redis/redis.conf command: ["redis-server", "/usr/local/etc/redis/redis.conf"] # redis5配置 redis5: image: daocloud.io/library/redis:6.0.4 container_name: redis-5 restart: always network_mode: "host" volumes: - /opt/docker/redis-cluster/redis-5/data:/data - /opt/docker/redis-cluster/redis-5/redis.conf:/usr/local/etc/redis/redis.conf command: ["redis-server", "/usr/local/etc/redis/redis.conf"] # redis6配置 redis6: image: daocloud.io/library/redis:6.0.4 container_name: redis-6 restart: always network_mode: "host" volumes: - /opt/docker/redis-cluster/redis-6/data:/data - /opt/docker/redis-cluster/redis-6/redis.conf:/usr/local/etc/redis/redis.conf command: ["redis-server", "/usr/local/etc/redis/redis.conf"]
Mulakan bekas dan laksanakan arahan:
#启动容器 docker-compose -f xxx.yaml up -d
Cari mana-mana bekas untuk masuk Di sini saya memilih redis-1 untuk masuk. Selepas memasuki bekas, masukkan arahan berikut untuk memulakan kluster:
redis-cli --cluster create 192.168.66.180:6379 \ 192.168.66.180:6380 \ 192.168.66.180:6381 \ 192.168.66.180:6382 \ 192.168.66.180:6383 \ 192.168.66.180:6384 \ --cluster-replicas 1
Gambar berikut menunjukkan kejayaan.
Gunakan arahan redis-cli untuk menyambung ke mana-mana nod dalam kelompok. Saya baru sahaja mengujinya pada komputer yang boleh ping alamat IP kluster Di sini saya menggunakan komputer tempatan
redis-cli -c -h 192.168.66.180 -p 6379 192.168.66.180:6379> cluster info
seperti yang ditunjukkan di bawah, iaitu kesihatan. of the cluster. Status
cluster nodes
Beri perhatian kepada hamba, tuan, diri saya dan kata kunci lain dalam gambar.
192.168.66.180:6379> set test 'hello world' -> Redirected to slot [6918] located at 192.168.66.180:6380 OK 192.168.66.180:6380>
Nota: Di sini, nod tempat serpihan data berada ditukar secara automatik berdasarkan kepingan pada, jadi anda boleh melihat di bawah bahawa nod yang disambungkan telah berubah kepada 192.168.1.4:6380
dapatkan ujian
168.66.180:6379> set test 'hello world' -> Redirected to slot [6918] located at 192.168.66.180:6380 OK 192.168.66.180:6380> get test "hello world" 192.168.66.180:6380>
Di sini, kerana pertanyaan dilakukan pada shard di mana data terletak, nod yang disambungkan tidak berubah.
#为redis.conf文件添加如下配置。这里设置密码为123456 masterauth 123456 requirepass 123456
#为docker-compose.yml中每个容器添加如下配置: environment: - REDISCLI_AUTH=123456
redis-cli -c -h 192.168.66.180 -p 6379 -a 123456
Atas ialah kandungan terperinci Bagaimana Docker-Compose membina gugusan Redis. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!