基于docker容器搭建redis集群(3主三从)
一、容器准备
从镜像仓库拉取centos基础镜像,然后创建容器后初始化环境,安装gcc、tar、ssh、telnet等一些常用命令和环境依赖,然后创建test01用户并设置密码。然后将初始化好的容器打包为镜像作为真正的基础镜像。上述操作步骤不再描述,请自行百度。
本次3主3从分别部署于三台服务器,ip和端口分配为10.25.27.116的20100和20101
10.25.27.117的20100和20101
10.25.27.118的20100和20101
1、创建docker局域网
docker network create --subnet=10.25.27.0/24 mynet1
# mynet1为网桥名称,可以自定义,10.25.27.0/24为网段,可以根据自己需要进行调整。
2、根据基础镜像创建三个服务器容器并指定ip
docker run -d --name centos01 -it --net mynet1 --ip 10.25.27.116 --privileged=true -p 20010:22 my-centos:1.0 /usr/sbin/init
# centos01为容器名称,--net是将容器加入到mynet1局域网中,--ip是为容器指定固定ip(要在mynet1网段中),--privileged=true是为了防止容器中的systemctl命令报错,-p 20010:22是将宿主机的20100端口映射到容器的22端口便于远程ssh登录,my-centos:1.0是提前准备好的基础镜像和版本号。
#另外两台同上,修改ip和容器名称及映射端口。
docker run -d --name centos02 -it --net mynet1 --ip 10.25.27.117 --privileged=true -p 20011:22 my-centos:1.0 /usr/sbin/init
docker run -d --name centos03 -it --net mynet1 --ip 10.25.27.118 --privileged=true -p 20012:22 my-centos:1.0 /usr/sbin/init
#设置容器开机自启
docker update --restart=always centos01
docker update --restart=always centos02
docker update --restart=always centos03
#至此,容器创建完毕。
3、登入容器检查容器内部环境
# 使用docker exec命令逐个登录容器,并使用ifconfig查看ip是否为创建容器时设置的固定ip,然后使用ping命令测试容器之间、容器和宿主机、容器和互联网的连通性。
docker exec -it centos01 /bin/bash
#查看本机ip
ifconfig | grep -10 eth0
#测试连通性
ping 10.25.27.118
ping www.baidu.com
#测试ssh远程登录
ssh 10.25.27.117 -p 22
#本地测试宿主机端口映射
ssh 192.168.200.129 -p20010
二、软件准备
#使用su命令切换到test01用户
su test01
#在/home/test01目录下创建software文件夹用于存放需要的文件
cd /home/test01
mkdir software
#然后将软件使用sftp工具上传到该目录下
三、安装编译ruby和gem(三台之中的一台就行)
使用10.25.27.116这台来安装ruby并编译redis
1、解压ruby并进入文件夹
tar -zxvf ruby-3.0.0.tar.gz
cd ruby-3.0.0
2、设置安装路径并编译安装
./configure --prefix=/home/test01/ruby
# 一起执行报错的话,make和make install可以分开执行
make & make install
3、查看执行结果
进入/home/test01目录下使用ls命令查看ruby目录已经存在。
4、安装gem
gem是ruby相关的包
进入/home/test01/ruby/bin
#执行下面命令,redis-3.3.3.gem包要提前上传到/home/test01/software/目录下
./gem install -l /home/test01/software/redis-3.3.3.gem
四、安装redis配置redis
1、编译安装redis
# 进入/home/test01/software目录下,解压redis安装包
tar -zxvf redis-5.0.4.tar.gz
#进入redis-5.0.4目录下,编译reids并指定安装路径
make PREFIX=/home/test01/redis
#安装redis
make install
如果make test提示下面的错误,需要安装tcl依赖,不提示就跳过下面的步骤
2、配置redis配置
安装完成后/home/test01目录下会有redis文件夹
在redis文件夹下创建20100和20101目录
在两个目录下分别创建config和data目录
将/home/test01/software/redis-5.0.4/redis.conf文件复制到config下然后配置文件
依次进入/home/test01/redis/20100/config和/home/test01/20101/config修改redis.conf
# 每个节点的端口号
port 20100
# 开启后台启动
daemonize yes
# 绑定当前机器IP
bind 0.0.0.0
# 数据文件存放位置
dir /home/test01/redis/20100/data
# 设置pid文件存放位置
pidfile /home/test01/redis/20100/redis.pid
# 启动集群模式
cluster-enabled yes
# 集群配置文件
cluster-config-file nodes-20100.conf
# 集群节点超时时间
cluster-node-timeout 15000
appendonly yes
使用scp命令将redis文件夹复制到另外两台服务器中的/home/test01目录下
cd /home/test01
scp -r test01@10.25.27.116:/home/test01/redis ./
3、配置环境变量
使用vi或vim编辑器编辑当前用户的.bash_profile文件
vim ~/.bash_profile
export PATH=/home/test01/ruby/bin:$PATH
export REDIS_HOME=/home/test01/redis
export PATH=$REDIS_HOME/bin:$PATH
source ~/.bash_profile
五、启动redis并搭建集群
1、启动redis(每台服务器都执行)
cd /home/test01/redis/bin
./redis-server /home/test01/redis/20100/config/redis.conf
./redis-server /home/test01/redis/20101/config/redis.conf
# 检查启动情况
netstat -an | grep 20100
netstat -an | grep 20101
2、集群组网
在刚才装了ruby的那台机器上执行如下命令进行集群组网
cd /home/test01/redis/bin
./redis-cli --cluster create 10.25.27.116:20100 10.25.27.117:20100 10.25.27.118:20100 10.25.27.116:20101 10.25.27.117:20101 10.25.27.118:20101 --cluster-replicas 1
注意:防火墙一定要开放监听的redis端口,否则会创建失败。如果创建失败并试图再次创建时,可能会出现类似“ERR Slot 0 is already busy (Redis::CommandError)”错误,此时运行如下命令来清楚前次的一些痕迹后再试:
./redis-cli -h 127.0.0.1 -p 20100
127.0.0.1:20100>flushall
127.0.0.1:20100>cluster reset
3、验证集群
# 在116的服务器执行下面命令
cd /home/test01/redis/bin
# -c表示以集群模式打开
./redis-cli -c -h 10.25.27.117 -p 20100
# 输入cluster nodes查看集群节点信息
10.25.27.117:20100> cluster nodes
如图所示:118的主节点的从节点在116,116的主节点的从节点在117,117的主节点的从节点在118,每台服务器都有一台主节点和一台从节点,主节点的端口是20100,从节点的端口是20101,主节点和从节点不在同一台服务器上,至此基于docker的三主三从redis集群搭建成功。