使用Docker构建redis集群--最靠谱的版本
2016-11-08 16:23
666 查看
1集群结构说明
集群中有三个主节点,三个从节点,一共六个结点。因此要构建六个redis的docker容器。在宿主机中将这六个独立的redis结点关联成一个redis集群。需要用到官方提供的ruby脚本。2构建redis基础镜像
本文选择版本为redis-3.0.7,如果需要其他版本,直接修改wget后面地址中的版本号即可。代码清单2-1下载&编译redis源码包
PS:如果你连#也复制了,那你还是别看了……
我们已经在宿主机编译好了redis源码,在src路径下有我们需要的可执行文件:redis-cli,redis-server和redis-trib.rb。redis-trib.rb是redis官方提供的ruby脚本,用来构建redis集群
修改redis.conf。在redis-3.0.7的根路径下有redis的配置文件redis.conf。将其移动到上一级路径/usr/docker_root/redis_cluster/下。
依据代码清单2-2,修改redis.conf文件中的对应参数值。
daemonize:是否后台运行,将其设为no,表示前台运行。
port:redis服务监听的端口。
logfile:指定日志文件路径。
appendonly:是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。
cluster-node-timeout:集群结点超时限制。
代码清单2-2需要修改的配置参数
下面构建redis基础镜像。以Dockerfile方式构建。
代码清单2-3创建redis基础镜像的Dockerfile
#pwd
/usr/docker_root/redis_cluster
#vimDockerfile
我们来看看Dockerfile的内容,如代码清单2-4所示。
将本地的redis源码包复制到镜像的根路径下,ADD命令会在复制过后自动解包。被复制的对象必须处于Dockerfile同一路径,且ADD后面必须使用相对路径。
将我们修改后的配置文件也复制到镜像内。
为编译源码包,需要安装gcc和make,安装之前先更新apt-get。更新和安装时间较长。
编译源码包。当然编译也需要一段时间。
编译后,容器中只需要可执行文件redis-server,所以将该文件移到/redis/路径下。现在redis-server和redis.conf都在/redis/下。
将redis-3.0.7路径整个删除。
gcc和make也可以卸载掉。
指定数据卷,通过这个数据卷可以查看redis运行的日志文件。
公开redis默认端口6379。
因为不会执行这个镜像,所有没有包含ENTRYPOINT和CMD指令。我们基于这个镜像构建别的镜像。
现在我们构建redis基础镜像
代码清单2-5构建redis基础镜像
#dockerbuild-tredis:3.0.7.
构建过程与网络带宽有关,十分钟左右,构建完成。成功构建镜像之后,运行dockerimages,可以看见zcq/redis_base镜像,如图2-2所示,镜像size有290.4MB。
3构建redis结点镜像
我们继续构建redis结点镜像,这个镜像将会用于生成提供redis服务的docker容器。代码清单3-1创建redis结点镜像的Dockerfile
#mkdirredis_node
#cdredis_node
#vimDockerfile
Dockerfile如代码清单3-2所示。
构建redis结点镜像。
代码清单3-3构建redis结点镜像
#dockerbuild-tredis-cluster:3.0.7.
查看redis结点镜像redis-cluster:3.0.7,如上图。
4创建redis结点容器
依次创建六个redis结点容器,如代码清单4-1所示。代码清单4-1创建redis结点
#dockerrun-d--nameredis02redis-cluster:3.0.7
#dockerrun-d--nameredis03redis-cluster:3.0.7
#dockerrun-d--nameredis04redis-cluster:3.0.7
#dockerrun-d--nameredis05redis-cluster:3.0.7
#dockerrun-d--nameredis06redis-cluster:3.0.7
docker-compose.yml
version:"2"
services:
redis01:
image:redis-cluster:3.0.7
ports:
-6379:6379
container_name:redis01
redis02:
image:redis-cluster:3.0.7
container_name:redis02
redis03:
image:redis-cluster:3.0.7
container_name:redis03
redis04:
image:redis-cluster:3.0.7
container_name:redis04
redis05:
image:redis-cluster:3.0.7
container_name:redis05
redis06:
image:redis-cluster:3.0.7
container_name:redis06
启动:COMPOSE_PROJECT_NAME=testdocker-composeup-d
是不是很奇怪第一个容器的打开方式有点不一样,第一个容器做了端口映射,是专门留给客户端访问的,这样客户端就可以通过宿主机的30001端口访问redis集群了。
查看各容器IP地址
代码清单4-2查看redis结点IP
#dockerinspectredis01redis02redis03redis04redis05redis06|grep\"IPAddress\"|grep172
"IPAddress":"172.19.0.16",
"IPAddress":"172.19.0.17",
"IPAddress":"172.19.0.15",
"IPAddress":"172.19.0.19",
"IPAddress":"172.19.0.14",
"IPAddress":"172.19.0.18",
5搭建redis集群
前文已经提到,要构建集群需要使用官方提供的ruby脚本,也就是redis-3.0.7/src/redis-trib.rb,因此需要先安装ruby的环境。一般需要安装ruby1.9的版本,可以自己下载安装。
代码清单5-1安装ruby环境
#yuminstallruby
#yuminstallrubygems
手动安装步骤:
tar-xzfruby-1.9.3-p194.tar.gz解压安装包
./configure--prefix=/usr/local/ruby
由于redhat新版本(redhat5.4不报错,开发环境会报错)默认openssl的配置变更取消了对EC_xx的支持,make会出错,
此时需要修改ext/openssl/ossl_pkey_ec.c代码,修改的内容如下
修改762行开始处:
if(id==s_GFp_simple){
method=EC_GFp_simple_method();
}elseif(id==s_GFp_mont){
method=EC_GFp_mont_method();
}elseif(id==s_GFp_nist){
method=EC_GFp_nist_method();
#if!defined(OPENSSL_NO_EC2M)
}elseif(id==s_GF2m_simple){
method=EC_GF2m_simple_method();
#endif
修改817行开始处:
if(id==s_GFp){
new_curve=EC_GROUP_new_curve_GFp;
#if!defined(OPENSSL_NO_EC2M)
}elseif(id==s_GF2m){
new_curve=EC_GROUP_new_curve_GF2m;
#endif
}else{
ossl_raise(rb_eArgError,"unknownsymbol,mustbe:GFpor:GF2m");
}
修改完成后执行如下命令
make
makeinstall
安装完成后设置PATH路径,把安装的ruby放在系统PATH前面,
避免调用操作系统自带的ruby(开发环境REDHAT自带为1.8版本,而1.8版本不能用于redis集群的部署,至少用1.9以上),
修改~/.bash_profile
#PATH=$PATH:$HOME/bin—原来的配置
PATH=/usr/local/ruby/bin:$PATH:$HOME/bin—修改后的配置
修改后保存,并执行source~/.bash_profile生效
执行ruby-v查看ruby版本
运行redis-trib.rb脚本还需要安装redis的ruby包。
由于源的原因,可能下载失败,那就手动下载下来安装
download地址:http://rubygems.org/gems/redis/versions/3.0.7
代码清单5-3手动下载&安装redis的ruby包
#geminstall-lredis-3.0.7.gem
一切准备就绪,开始搭建redis集群吧!参照代码清单5-4,但是你还是要修改一下IP地址,你的容器地址应该不可能和我的一毛一样吧。
代码清单5-4搭建redis集群
#cd/usr/docker_root/redis_cluster/redis-3.0.7/src/
[root@localhostsrc]#./redis-trib.rbcreate--replicas1172.19.0.16:6379\
172.19.0.17:6379\
172.19.0.15:6379\
172.19.0.19:6379\
172.19.0.14:6379\
172.19.0.18:6379
执行结果代码代码清单5-5所示
代码清单5-5搭建redis集群输出结果
>>>Creatingcluster
>>>Performinghashslotsallocationon6nodes...
Using3masters:
172.19.0.16:6379
172.19.0.17:6379
172.19.0.15:6379
Addingreplica172.19.0.19:6379to172.19.0.16:6379
Addingreplica172.19.0.14:6379to172.19.0.17:6379
Addingreplica172.19.0.18:6379to172.19.0.15:6379
M:6dd5bbcb3866b26d84d237de94d706c5612195bc172.19.0.16:6379
slots:0-5460(5461slots)master
M:3bd685c9e976cff50148b4cf432079bf5c82b132172.19.0.17:6379
slots:5461-10922(5462slots)master
M:001c39d6516064496ea257dab40e9089632e3226172.19.0.15:6379
slots:10923-16383(5461slots)master
S:9dbc596a889579f3efff3e89c868ff4bd6ab46bd172.19.0.19:6379
replicates6dd5bbcb3866b26d84d237de94d706c5612195bc
S:060ace103346ca3a14446c092c324cb587847914172.19.0.14:6379
replicates3bd685c9e976cff50148b4cf432079bf5c82b132
S:bb81d9eb1084df2ce66ea3cc38ca4be7a6b009fe172.19.0.18:6379
replicates001c39d6516064496ea257dab40e9089632e3226
CanIsettheaboveconfiguration?(type'yes'toaccept):yes
>>>Nodesconfigurationupdated
>>>Assignadifferentconfigepochtoeachnode
>>>SendingCLUSTERMEETmessagestojointhecluster
Waitingfortheclustertojoin...
>>>PerformingClusterCheck(usingnode172.19.0.16:6379)
M:6dd5bbcb3866b26d84d237de94d706c5612195bc172.19.0.16:6379
slots:0-5460(5461slots)master
M:3bd685c9e976cff50148b4cf432079bf5c82b132172.19.0.17:6379
slots:5461-10922(5462slots)master
M:001c39d6516064496ea257dab40e9089632e3226172.19.0.15:6379
slots:10923-16383(5461slots)master
M:9dbc596a889579f3efff3e89c868ff4bd6ab46bd172.19.0.19:6379
slots:(0slots)master
replicates6dd5bbcb3866b26d84d237de94d706c5612195bc
M:060ace103346ca3a14446c092c324cb587847914172.19.0.14:6379
slots:(0slots)master
replicates3bd685c9e976cff50148b4cf432079bf5c82b132
M:bb81d9eb1084df2ce66ea3cc38ca4be7a6b009fe172.19.0.18:6379
slots:(0slots)master
replicates001c39d6516064496ea257dab40e9089632e3226
[OK]Allnodesagreeaboutslotsconfiguration.
>>>Checkforopenslots...
>>>Checkslotscoverage...
[OK]All16384slotscovered.
使用redis-cli连接redis集群,注意有–c
代码清单5-6连接redis集群
127.0.0.1:30001>info
下面显示集群的相关信息
#Server
redis_version:3.0.7
redis_git_sha1:00000000
redis_git_dirty:0
(省略一部分……)
#CPU
used_cpu_sys:2.21
used_cpu_user:1.63
used_cpu_sys_children:0.00
used_cpu_user_children:0.00
#Cluster
cluster_enabled:1
#Keyspace
127.0.0.1:30001>
做个set操作试试,见图5-1.
图5-1set操作
看到了吗?Redirectedtoslot[15495]locatedat172.17.0.67:6379。a的value被存储到172.17.0.67:6379结点上的槽[15495]里。下面的地址也变成了172.17.0.67:6379>。再试试get操作。
图5-2get操作
大功告成!祝贺!!!
转载自:http://www.2cto.com/net/201608/532256.html
本人做了微调。不过实现的结果不变。
相关文章推荐
- 使用Docker构建redis集群--最靠谱的版本
- 使用Docker构建redis集群
- 使用Docker构建redis集群
- Docker 构建 redis 集群
- 使用Docker构建ELK Docker集群日志收集系统
- 在 Web 项目中使用 Redis 快速构建系统缓存(单机版/集群版)
- Redis-使用redis-trib构建集群
- 使用Docker构建持续集成与自动部署的Docker集群
- 实战案例:构建docker容器集群 (解决方案一:使用自定义网桥连接跨主机容器)
- 从docker入门到使用docker搭建redis哨兵集群
- Docker构建Redis集群
- 使用jenkins、docker、consul、nginx搭建支持自动化构建部署以及弹性伸缩的集群系统详细教程
- 使用Docker如何构建Flink集群?
- 用 Docker 构建分布式 Redis 集群
- 在DOCKER中构建使用RUBY2.1及以上版本的镜像
- 使用Docker swarm构建wordpress集群 推荐
- 使用redis-trib.rb构建redis集群
- 使用Docker Compose部署基于Sentinel的高可用Redis集群
- Redis-使用redis-trib构建集群
- 使用Docker Compose部署基于Sentinel的高可用Redis集群