1集群结构说明
集群中有三个主节点,三个从节点,一共六个结点。因此要构建六个redis的docker容器。在宿主机中将这六个独立的redis结点关联成一个redis集群。需要用到官方提供的ruby脚本。
2构建redis基础镜像
本文选择版本为redis-3.0.7,如果需要其他版本,直接修改wget后面地址中的版本号即可。
代码清单2-1 下载&编译redis源码包
# mkdir –p /usr/docker_root/redis_cluster # cd /usr/docker_root/redis_cluster # wget http://download.redis.io/releases/redis-3.0.7.tar.gz # tar zxvf redis-3.0.7.tar.gz # cd redis-3.0.7 # make
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文件中的对应参数值。
代码清单2-2 需要修改的配置参数
1 daemonize no 2 port 6379 3 logfile "/var/log/redis/redis-server.log" 4 appendonly yes 5 cluster-enabled yes 6 cluster-config-file nodes.conf 7 cluster-node-timeout 5000 8 bind 0.0.0.0
daemonize : 是否后台运行,将其设为no,表示前台运行。
port :redis服务监听的端口。
logfile : 指定日志文件路径。
appendonly : 是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。
cluster-node-timeout : 集群结点超时限制。
由于需要在内网其他服务器上连接redis服务器(192.168.1.110),本想直接在redis配置文件中加上目标的IP地址: bind 192.168.1.166 就可以了,实际上不正确。 redis bind表示的是指定本机可以接受连接的网卡地址,比如redis服务器上有一个公网IP(114.114.114.114),一个内网IP(192.168.1.110),如果该redis服务器需要被本机以外的服务器访问(比如说内网的服务器), 此时需要在redis 配置文件中配置: bind 192.168.1.110 意思是该redis使用该IP来接受外部的连接(注意:bind的意思不是绑定外部服务器的IP,而是绑定本机可以接受访问的IP)。 然而我这要配置后使用116依然连接不上,经多次排查发现我是使用 ./redis-server & 来启动redis的,启动时没有指定配置文件。(即使修改了redis安装目录下的配置文件也不生效) 所以指定配置文件路径的方式来启动: ./redis-server /usr/local/redis/redis.conf & 如果到这步还不能生效,可以在配置文件中将redis保护模式关闭,但记得使用密码来保证安全性(使用复杂密码)。 protected-mode no requirepass a1s2W3l4%G
下面构建redis基础镜像。以Dockerfile方式构建。
代码清单2-3 创建redis基础镜像的Dockerfile
# pwd /usr/docker_root/redis_cluster # vim Dockerfile
我们来看看Dockerfile的内容,如代码清单2-4所示。
FROM ubuntu:14.04 ADD redis-3.0.7.tar.gz / RUN mkdir -p /redis ADD redis.conf /redis/ RUN apt-get -yqq update RUN apt-get install -y gcc make WORKDIR /redis-3.0.7 RUN make RUN mv /redis-3.0.7/src/redis-server /redis/ WORKDIR / RUN rm -rf /redis-3.0.7 RUN apt-get remove --purge -y gcc make VOLUME ["/var/log/redis/"] EXPOSE 6379
1 将本地的redis源码包复制到镜像的根路径下,ADD命令会在复制过后自动解包。被复制的对象必须处于Dockerfile同一路径,且ADD后面必须使用相对路径。 2 将我们修改后的配置文件也复制到镜像内。 3 为编译源码包,需要安装gcc和make,安装之前先更新apt-get。更新和安装时间较长。 4 编译源码包。当然编译也需要一段时间。 5 编译后,容器中只需要可执行文件redis-server,所以将该文件移到/redis/路径下。现在redis-server 和redis.conf都在/redis/下。 6 将redis-3.0.7路径整个删除。 7 gcc和make也可以卸载掉。 8 指定数据卷,通过这个数据卷可以查看redis运行的日志文件。 9 公开redis默认端口6379。 10 因为不会执行这个镜像,所有没有包含ENTRYPOINT和CMD指令。我们基于这个镜像构建别的镜像。