Rumah >pangkalan data >Redis >Bagaimana untuk membina kluster Redis berdasarkan Docker
Persekitaran: Docker + (Redis:5.0.5 * 3)
docker pull redis:5.0.5
docker create --name redis-node1 -v /data/redis-data/node1:/data -p 6379:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf docker create --name redis-node2 -v /data/redis-data/node2:/data -p 6380:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf docker create --name redis-node3 -v /data/redis-data/node3:/data -p 6381:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf3 Mulakan dan bentuk gugusanMulakan bekas
: docker start
, anda boleh melihatnya melalui Exited (1) 3 seconds ago
: docker logs
chmod -R 777 /dataSelepas berjaya memulakan, seperti ditunjukkan di bawah: Tubuhkan kelompokLihat tiga Redis yang diperuntukkan dalam maklumat nod IP Docker:
执行「docker inspect redis-node1」得到 redis-node1 ip 信息为:172.17.0.4 执行「docker inspect redis-node2」得到 redis-node2 ip 信息为:172.17.0.3 执行「docker inspect redis-node3」得到 redis-node3 ip 信息为:172.17.0.2Selepas mendapat maklumat IP (maklumat IP setiap orang mungkin berbeza), kemudian masukkan bekas tertentu untuk membentuk kluster:
# 这里以进入 node1 为例 docker exec -it redis-node1 /bin/bash # 接着执行组建集群命令(请根据自己的ip信息进行拼接) redis-cli --cluster create 172.17.0.2:6379 172.17.0.3:6379 172.17.0.4:6379 --cluster-replicas 0ok, kini kluster telah disediakan, mari kita ujinya seterusnya. Kluster ujianGunakan perintah
untuk menyambung ke nod kluster, dan kemudian tetapkan nilai Selepas nilai yang ditetapkan, ia akan mengubah hala secara automatik ke alamat ip 0.2, dan kemudian mendapatkannya melalui mendapatkan untuk mendapatkan sijil kejayaan Kluster adalah sah. redis-cli -c
dsb. Jika projek menggunakan ip地址
tidak berada pada pelayan yang sama dengan kluster, maka projek itu tidak boleh menggunakan kluster kerana ia tidak boleh diakses. 172.17.0.2
redis集群
Satu penyelesaian ialah membenarkan
Docker menggunakan jenis sambungan rangkaian dan Dockerhost模式
menggunakan The kontena yang dicipta tidak mempunyai ruang nama rangkaian bebasnya sendiri Ia berkongsi ruang rangkaian dengan mesin fizikal, dan boleh berkongsi semua port dan IP host模式
mesin fizikal, supaya rangkaian awam boleh mengakses kontena secara terus. . Walaupun kaedah ini mempunyai risiko keselamatan, tiada mod lain yang boleh dilaksanakan telah ditemui. Mengenai masalah yang ada, kami mengguna pakai semula
host模式
1 Hentikan bekas yang sedang berjalan
docker stop redis-node1 redis-node2 redis-node3
docker rm redis-node1 redis-node2 redis-node3 # 清空上面创建的配置文件 rm -rf /data/redis-data/node*
docker create --name redis-node1 --net host -v /data/redis-data/node1:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf --port 6379 docker create --name redis-node2 --net host -v /data/redis-data/node2:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf --port 6380 docker create --name redis-node3 --net host -v /data/redis-data/node3:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf --port 6381
, --net
, dll. host
-p 6379:6379
-p 6379
-p 6380
# 启动命令 docker start redis-node1 redis-node2 redis-node3 # 进入某一个容器 docker exec -it redis-node1 /bin/bash # 组建集群,10.211.55.4为当前物理机的ip地址 redis-cli --cluster create 10.211.55.4:6379 10.211.55.4:6380 10.211.55.4:6381 --cluster-replicas 05
6. Uji gugusan
Gunakanroot@CentOS7:/data# redis-cli 127.0.0.1:6379> cluster nodes 72c291c32815194b64d1f6d0fdf771f5cc04e14a 10.211.55.4:6380@16380 master - 0 1590905997358 2 connected 5461-10922 6a595b67bbff15c94e5874c2d2cd556d6a6a6c17 10.211.55.4:6381@16381 master - 0 1590905998362 3 connected 10923-16383 4e3dbdc8f835dcbc38291c88f08165ee51d53d3d 10.211.55.4:6379@16379 myself,master - 0 1590905997000 1 connected 0-5460 127.0.0.1:6379>
redis-cli -c
Atas ialah kandungan terperinci Bagaimana untuk membina kluster Redis berdasarkan Docker. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!