docker下redis集群的搭建

1.安装docker并配置镜像源

​ 参考 https://www.jianshu.com/p/827a242730e5

2.拉取镜像源

docker search redis
001.png
docker pull redis
002.png
docker images
003.png

3.准备配置文件

由于redis支持include语法,我们搭建的又是一台机器的伪集群,故将统一的配置放在template文件中 供大家引用

mkdir -p /opt/redis-cluster
cd /opt/redis-cluster
mkdir redis-6379 redis-6380 redis-6381
touch template.conf
vim template.conf

/opt/redis-cluster/template.conf

#是否以守护进程启动 docker如果使用-d命令启动的话必须设置为no 否则会冲突报错
daemonize no
#当Redis以守护进程方式运行时,Redis默认会把pid写入/var/run/redis.pid文件,可以通过pidfile指定
pidfile /data/redis.pid
#端口 各配置自己定义
# port 6379

tcp-backlog 1024
#超时时间,空闲时间超过该值则断开客户端的连接 为0表示关闭该功能
timeout 3000

tcp-keepalive 60
#日志等级和日志文件路径配置
loglevel notice
logfile "/data/redis.log"
 
# 是否开启保护模式 可以和密码配合使用
protected-mode no 
 
databases 16
 
#指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合
#指定为空表示不同步到数据文件
save ""
#可以通过多个条件组合的方式设置同步规则
#save 900 1  
#save 300 10  
#save 60 10000  
 
stop-writes-on-bgsave-error yes
 
rdbcompression yes
rdbchecksum yes
 
#rdb文件名称
dbfilename dump.rdb
#数据文件存储目录
dir /data/
 
slave-serve-stale-data yes
slave-read-only yes
repl-disable-tcp-nodelay no
slave-priority 100
 
appendonly yes
appendfilename "appendonly.aof"
# appendfsync always  
appendfsync everysec
# appendfsync no  
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
 
lua-time-limit 5000
 
slowlog-log-slower-than 1000
slowlog-max-len 1000
 
latency-monitor-threshold 0
notify-keyspace-events ""
 
# 指定在超过一定的数量或者最大的元素超过某一临界值时,采用一种特殊的哈希算法
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-entries 512
list-max-ziplist-value 64
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
 
#指定是否激活重置哈希,默认为开启
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
 
hz 10
aof-rewrite-incremental-fsync yes

单独的配置文件 这里设置6380作为master节点,6379和6381作为slave节点

/opt/redis-cluster/redis-6379/redis.conf

# 这里template是容器内的绝对路径
include /usr/local/etc/redis/template.conf
# 设置端口
port 6379
# 设置master节点的ip和端口
replicaof 172.16.10.202 6380

/opt/redis-cluster/redis-6380/redis.conf

# 这里template是容器内的绝对路径
include /usr/local/etc/redis/template.conf
# 6380就是主节点 不需要设置replicaof
# 设置端口
port 6380

/opt/redis-cluster/redis-6381/redis.conf

# 这里template是容器内的绝对路径
include /usr/local/etc/redis/template.conf
# 设置端口
port 6381
# 设置复制数据的来源 也就是master节点的ip和端口
replicaof 172.16.10.202 6380

4.运行脚本

需要注意:

1.docker使用-d启动所以配置文件一定要设置daemon为no

2.先启动master节点 再启动slave节点

# 官方镜像运行(一主两从)  daemon一定要改成no 不然会和-d冲突导致启动不成功
docker run -it -d --net host --name redis-6380 \
-v /opt/redis-cluster/redis-6380/data/:/data \
-v /opt/redis-cluster/redis-6380/redis.conf:/usr/local/etc/redis/redis.conf \
-v /opt/redis-cluster/template.conf:/usr/local/etc/redis/template.conf \
redis:latest redis-server /usr/local/etc/redis/redis.conf

docker run -it -d --net host --name redis-6381 \
-v /opt/redis-cluster/redis-6381/data/:/data \
-v /opt/redis-cluster/redis-6381/redis.conf:/usr/local/etc/redis/redis.conf \
-v /opt/redis-cluster/template.conf:/usr/local/etc/redis/template.conf \
redis:latest redis-server /usr/local/etc/redis/redis.conf

docker run -it -d --net host --name redis-6379 \
-v /opt/redis-cluster/redis-6379/data/:/data \
-v /opt/redis-cluster/redis-6379/redis.conf:/usr/local/etc/redis/redis.conf \
-v /opt/redis-cluster/template.conf:/usr/local/etc/redis/template.conf \
redis:latest redis-server /usr/local/etc/redis/redis.conf

验证

docker ps
image.png

可以看到三个端口的redis都启动了.
下面我们通过info replication命令查看下主从服务器的情况。

[root@kf202 redis-cluster]# redis-cli -p 6379
127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> info replication
# Replication
role:slave
master_host:172.16.10.202
master_port:6380
master_link_status:up
master_last_io_seconds_ago:9
master_sync_in_progress:0
slave_repl_offset:5628
slave_priority:100
slave_read_only:1
connected_slaves:0
master_replid:1632817c6e6a7b631395065a3d2a978cbe2f3513
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:5628
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:15
repl_backlog_histlen:5614
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> set user1 zjtx
(error) READONLY You can't write against a read only replica.
127.0.0.1:6379> exit

可以看到 6379端口是以slave存在的 master节点正是我们设置的6380端口。

master_host:172.16.10.202
master_port:6380

由于配置了从节点只读的属性,因此执行添加数据的时候提示了只读的错误。

READONLY You can't write against a read only replica.

一些重要信息解释如下:

role: 角色 可以是slave或者master
master_host/master_port 主节点IP和端口
master_link_status 连接到主节点的状态 可以是UP 和 DOWN
connected_slaves:0  连接的从节点个数
slave_read_only:1  从节点是否只读 1 表示只读

我们再看下6380端口的信息

[root@kf202 ~]# redis-cli -p 6380
127.0.0.1:6380> info replication
# Replication
role:master
connected_slaves:2
slave0:ip=172.16.10.202,port=6381,state=online,offset=25171,lag=1
slave1:ip=172.16.10.202,port=6379,state=online,offset=25171,lag=1
master_replid:ae7153909cd7f892074b1f6617fc60fb236313e1
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:25453
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:25453
127.0.0.1:6380> set user1 zjtx2018
OK
127.0.0.1:6380> keys *
1) "user1"
127.0.0.1:6380> get user1
"zjtx2018"
127.0.0.1:6380> 

可以看到6380对应的role是master 有两个slave连接,同时可以正常操作数据。

我们再验证下数据同步的情况。

[root@kf202 redis-cluster]# redis-cli -p 6379
127.0.0.1:6379> keys *
1) "user1"
127.0.0.1:6379> get user1
"zjtx2018"
127.0.0.1:6379> exit
[root@kf202 redis-cluster]# redis-cli -p 6381
127.0.0.1:6381> keys *
1) "user1"
127.0.0.1:6381> get user1
"zjtx2018"

可以看到6379 和 6381 的数据都可以正常同步。

至此一主两从的redis集群环境搭建成功。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,402评论 6 499
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,377评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,483评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,165评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,176评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,146评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,032评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,896评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,311评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,536评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,696评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,413评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,008评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,815评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,698评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,592评论 2 353