Rumah  >  Artikel  >  pangkalan data  >  Bagaimana Docker-Compose membina gugusan Redis

Bagaimana Docker-Compose membina gugusan Redis

PHPz
PHPzke hadapan
2023-05-30 16:46:221704semak imbas

1. Konfigurasi Kluster

  • 3 master + 3 slave

  • Memandangkan ia hanya untuk ujian, saya hanya menggunakan 1 pelayan di sini Simulate

senarai redis

Bagaimana Docker-Compose membina gugusan Redis

2 Tulis redis.conf

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

3 Cipta fail redis.conf di bawah setiap folder redis-* dan tulis kandungan berikut:

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

4 Tulis fail docker-compose.yml

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

Bagaimana Docker-Compose membina gugusan Redis

5. Mulakan kluster

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

Bagaimana Docker-Compose membina gugusan Redis

Gambar berikut menunjukkan kejayaan.

Bagaimana Docker-Compose membina gugusan Redis

6 Ujian

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

6.1 untuk melihat sifat nod

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

Bagaimana Docker-Compose membina gugusan Redis

6.2 Lihat maklumat nod

cluster nodes

Bagaimana Docker-Compose membina gugusan Redis

Beri perhatian kepada hamba, tuan, diri saya dan kata kunci lain dalam gambar.

Bagaimana Docker-Compose membina gugusan Redis

6.3 Masukkan nilai

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>

Bagaimana Docker-Compose membina gugusan Redis

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.

7. Tambah kata laluan:

7.1 Edit fail redis.conf

#为redis.conf文件添加如下配置。这里设置密码为123456
masterauth 123456
requirepass 123456

7.2 Edit fail docker-compose.yml

#为docker-compose.yml中每个容器添加如下配置:
environment:
  - REDISCLI_AUTH=123456

7.3 Sambung ke kelompok

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!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Artikel sebelumnya:Apakah kaedah kegigihan Redis?Artikel seterusnya:Apakah kaedah kegigihan Redis?