使用docker搭建redis主從的方法步驟
一、構(gòu)建 Docker 環(huán)境
1、創(chuàng)建 dockerfile
FROM centos:latest RUN groupadd -r redis && useradd -r -g redis redis RUN yum -y update && yum -y install epel-release && yum -y install redis && yum -y install net-tools EXPOSE 6379
2、構(gòu)建鏡像
docker build -t docker-test .
3、查看當(dāng)前鏡像
docker iamges REPOSITORY TAG IMAGE ID CREATED SIZE docker-test latest ccebd30e466a 12 minutes ago 396MB centos latest 470671670cac 7 weeks ago 237MB
4、查看docker默認(rèn)的網(wǎng)絡(luò)類型
docker network ls NETWORK ID NAME DRIVER SCOPE a43e79987e98 bridge bridge local 6b73067403dc host host local b8ad4981e57e none null local
5、創(chuàng)建自定義網(wǎng)絡(luò)類型
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: 以交互模式運(yùn)行容器,通常與 -t 同時(shí)使用
-t: 為容器重新分配一個(gè)偽輸入終端,通常與 -i 同時(shí)使用
-d: 后臺(tái)運(yùn)行容器,并返回容器ID;
--name: 為創(chuàng)建的容器命名
--net: 指定網(wǎng)絡(luò)模式(這里指定剛才創(chuàng)建的自定義網(wǎng)絡(luò)模式)
-p: 端口映射,格式為:主機(jī)(宿主)端口:容器端口
--ip: 為容器制定一個(gè)固定的ip
后面再指定一下使用的鏡像(這里使用的就是剛才創(chuàng)建的鏡像 docker-test)
2、查看運(yùn)行中的容器
docker ps -a
CONTAINER ID IMAGE COMMAND CREATED dc9344bbd25f docker-test "/bin/bash" 2 minutes ago STATUS PORTS NAMES Up 2 minutes 0.0.0.0:6380->6379/tcp redis-master
注:查看某個(gè)網(wǎng)絡(luò)下容器的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-test docker run -itd --name redis-slave2 --net haveyb-network -p 6382:6379 --ip 172.10.0.4 docker-test
4、配置 redis-master 容器
(1)進(jìn)入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)設(shè)置主redis 密碼
requirepass YourPasswordSettings
(5)啟動(dòng)主redis
redis-server /etc/redis.conf &
(6)redis-cli
redis-cli auth yourPasswordSettings
5、配置 redis-slave1
(1)進(jìn)入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)設(shè)置 masterauth,添加以下代碼(主redis設(shè)置密碼后,從redis連接需要此參數(shù)驗(yàn)權(quán))
masterauth yourPasswordSettings
(5)設(shè)置 slaveof (設(shè)置主 redis 的 ip 和 port)
slaveof 172.10.0.2 6379
(5)啟動(dòng)從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 # Replication role:master connected_slaves:2 slave0:ip=172.10.0.3,port=6379,state=online,offset=3105,lag=1 slave1:ip=172.10.0.4,port=6379,state=online,offset=3105,lag=1 master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1 master_replid2:0000000000000000000000000000000000000000 master_repl_offset:3105 second_repl_offset:-1 repl_backlog_active:1 repl_backlog_size:1048576 repl_backlog_first_byte_offset:1 repl_backlog_histlen:3105 127.0.0.1:6379>
redis-slave1
127.0.0.1:6379> info replication # Replication role:slave master_host:172.10.0.2 master_port:6379 master_link_status:up master_last_io_seconds_ago:1 master_sync_in_progress:0 slave_repl_offset:3203 slave_priority:100 slave_read_only:1 connected_slaves:0 master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1 master_replid2:0000000000000000000000000000000000000000 master_repl_offset:3203 second_repl_offset:-1 repl_backlog_active:1 repl_backlog_size:1048576 repl_backlog_first_byte_offset:1 repl_backlog_histlen:3203 127.0.0.1:6379>
8、在 redis-master 中寫入key,redis-slave1 和 redis-slave2 已經(jīng)可以獲取了
到此這篇關(guān)于使用docker搭建redis主從的方法步驟的文章就介紹到這了,更多相關(guān)docker搭建redis主從內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Docker下redis的主從配置教程詳解
- 基于Docker搭建Redis一主兩從三哨兵的實(shí)現(xiàn)
- 使用Docker搭建Redis主從復(fù)制的集群
- 詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐
- 基于Docker搭建Redis主從集群的實(shí)現(xiàn)
- docker-compose啟動(dòng)redis多機(jī)集群的實(shí)現(xiàn)(6臺(tái)服務(wù)器3主3從)
- centos6使用docker部署redis主從數(shù)據(jù)庫操作示例
- docker搭建redis主從哨兵集群的實(shí)現(xiàn)步驟
- 基于Docker實(shí)現(xiàn)Redis主從+哨兵搭建的示例實(shí)踐
- Docker下Redis集群(主從+哨兵)安裝配置的實(shí)現(xiàn)步驟
- docker搭建redis三主三從集群的實(shí)現(xiàn)步驟
相關(guān)文章
docker實(shí)現(xiàn)重新打tag并刪除原tag的鏡像
這篇文章主要介紹了docker實(shí)現(xiàn)重新打tag并刪除原tag的鏡像,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-11-11docker環(huán)境中websocket?通過nginx代理不通解決方案
這篇文章主要介紹了docker環(huán)境中websocket?通過nginx代理不通解決方案,下面是一些可能會(huì)導(dǎo)致?WebSocket?代理失敗的問題以及相應(yīng)的解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05使用docker部署java項(xiàng)目運(yùn)行環(huán)境的實(shí)現(xiàn)步驟
本文主要介紹了使用docker部署java項(xiàng)目運(yùn)行環(huán)境的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01如何解決啟動(dòng)docker desktop報(bào)The network name ca
在使用Docker Desktop時(shí),可能遇到"The network name cannot be found"的錯(cuò)誤,解決這個(gè)問題的方法是打開管理員權(quán)限的終端,執(zhí)行重啟Docker Desktop的相關(guān)命令,如果遇到虛擬化未開啟的提示,需要執(zhí)行“bcdedit /set hypervisorlaunchtype auto”2024-10-10docker?swarm快速部署redis分布式集群的詳細(xì)過程
這篇文章主要介紹了docker?swarm快速部署redis分布式集群,只需要通過docker-compose.yml文件和一個(gè)啟動(dòng)命令就完成redis分布式部署的方式,讓其分別部署在不同機(jī)器上,并實(shí)現(xiàn)集群搭建,需要的朋友可以參考下2022-10-10詳解Docker 下開發(fā) hyperf 完整使用示例
這篇文章主要介紹了詳解Docker 下開發(fā) hyperf 完整使用示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01Docker部署nginx+php環(huán)境的全過程(簡單可用!)
最近在學(xué)docker,順便配置了一下docker中的nginx與php,發(fā)現(xiàn)網(wǎng)上的關(guān)于docker中配置nginx與php的資料很少,而且有的也很舊,沒有太多的參考性,下面這篇文章主要給大家介紹了關(guān)于Docker部署nginx+php環(huán)境的相關(guān)資料,需要的朋友可以參考下2023-02-02