使用docker搭建redis主從的方法步驟
1、創(chuàng)建 dockerfile
FROM centos:latestRUN groupadd -r redis && useradd -r -g redis redisRUN yum -y update && yum -y install epel-release && yum -y install redis && yum -y install net-toolsEXPOSE 6379
2、構建鏡像
docker build -t docker-test .
3、查看當前鏡像
docker iamgesREPOSITORY TAG IMAGE ID CREATED SIZEdocker-test latest ccebd30e466a 12 minutes ago 396MBcentos latest 470671670cac 7 weeks ago 237MB
4、查看docker默認的網絡類型
docker network lsNETWORK ID NAMEDRIVER SCOPEa43e79987e98 bridge bridge local6b73067403dc hosthostlocalb8ad4981e57e nonenulllocal
5、創(chuàng)建自定義網絡類型
docker network create --subnet=172.10.0.0/16 haveyb-network二、搭建 Redis 主從
1、創(chuàng)建 redis-master 容器
docker run -itd --name redis-master --net haveyb-network -p 6380:6379 --ip 172.10.0.2 docker-test
參數(shù)解釋:
-i: 以交互模式運行容器,通常與 -t 同時使用
-t: 為容器重新分配一個偽輸入終端,通常與 -i 同時使用
-d: 后臺運行容器,并返回容器ID;
--name: 為創(chuàng)建的容器命名
--net: 指定網絡模式(這里指定剛才創(chuàng)建的自定義網絡模式)
-p: 端口映射,格式為:主機(宿主)端口:容器端口
--ip: 為容器制定一個固定的ip
后面再指定一下使用的鏡像(這里使用的就是剛才創(chuàng)建的鏡像 docker-test)
2、查看運行中的容器
docker ps -a
CONTAINER ID IMAGE COMMAND CREATEDdc9344bbd25f docker-test '/bin/bash' 2 minutes ago STATUS PORTS NAMESUp 2 minutes 0.0.0.0:6380->6379/tcp redis-master
注:查看某個網絡下容器的ip地址
docker network inspect haveyb-network
3、創(chuàng)建 redis-slave1、redis-slave2 容器
docker run -itd --name redis-slave1 --net haveyb-network -p 6381:6379 --ip 172.10.0.3 docker-testdocker run -itd --name redis-slave2 --net haveyb-network -p 6382:6379 --ip 172.10.0.4 docker-test
4、配置 redis-master 容器
(1)進入redis-master 容器
docker exec -it redis-master bash
注:退出容器 `exit`
(2)修改redis.conf 配置文件
vi /etc/redis.conf
(3)修改參數(shù) bind 127.0.0.1 為 0.0.0.0
bind 0.0.0.0
(4)設置主redis 密碼
requirepass YourPasswordSettings
(5)啟動主redis
redis-server /etc/redis.conf &
(6)redis-cli
redis-cliauth yourPasswordSettings
5、配置 redis-slave1
(1)進入redis-slave1 容器
docker exec -it redis-slave1 bash
(2)修改redis.conf 配置文件
vi /etc/redis.conf
(3)修改參數(shù) bind 127.0.0.1 為 0.0.0.0
bind 0.0.0.0
(4)設置 masterauth,添加以下代碼(主redis設置密碼后,從redis連接需要此參數(shù)驗權)
masterauth yourPasswordSettings
(5)設置 slaveof (設置主 redis 的 ip 和 port)
slaveof 172.10.0.2 6379
(5)啟動從redis
redis-server /etc/redis.conf &
(6)redis 客戶端
redis-cli
6、配置 redis-slave2
同配置 redis-slave1
7、在redis -cli中執(zhí)行 `info replication` 可以查看主從信息
redis-master
127.0.0.1:6379> info replication# Replicationrole:masterconnected_slaves:2slave0:ip=172.10.0.3,port=6379,state=online,offset=3105,lag=1slave1:ip=172.10.0.4,port=6379,state=online,offset=3105,lag=1master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1master_replid2:0000000000000000000000000000000000000000master_repl_offset:3105second_repl_offset:-1repl_backlog_active:1repl_backlog_size:1048576repl_backlog_first_byte_offset:1repl_backlog_histlen:3105127.0.0.1:6379>
redis-slave1
127.0.0.1:6379> info replication # Replicationrole:slavemaster_host:172.10.0.2master_port:6379master_link_status:upmaster_last_io_seconds_ago:1master_sync_in_progress:0slave_repl_offset:3203slave_priority:100slave_read_only:1connected_slaves:0master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1master_replid2:0000000000000000000000000000000000000000master_repl_offset:3203second_repl_offset:-1repl_backlog_active:1repl_backlog_size:1048576repl_backlog_first_byte_offset:1repl_backlog_histlen:3203127.0.0.1:6379>
8、在 redis-master 中寫入key,redis-slave1 和 redis-slave2 已經可以獲取了
到此這篇關于使用docker搭建redis主從的方法步驟的文章就介紹到這了,更多相關docker搭建redis主從內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. Android SeekBar實現(xiàn)平滑滾動2. ASP.NET MVC視圖頁使用jQuery傳遞異步數(shù)據(jù)的幾種方式詳解3. XHTML 1.0:標記新的開端4. 詳解php如何合并身份證正反面圖片為一張圖片5. php設計模式之備忘模式分析【星際爭霸游戲案例】6. AJAX實現(xiàn)省市縣三級聯(lián)動效果7. php設計模式之模板模式實例分析【星際爭霸游戲案例】8. python字典通過值反查鍵的實現(xiàn)(簡潔寫法)9. Java基于redis和mysql實現(xiàn)簡單的秒殺(附demo)10. java必懂的冷知識點之Base64加密與解密
