1.Redis安装和配置
1 | # 先安装编译环境 |
2.修改配置
1 | vi redis.conf |
bind 192.168.1.100
port 6379
daemonize yes # 是否需要以守护进程启动(如果为no, 启动后在前台, ctrl-c退出进程, 可以使用nohub的方式转入后台)
pidfile /var/run/redis_6379.pid # 可以自行选择目录, 但是确保已经建立好指定的目录再启动服务, 否则启动报错
logfile “/var/redis/log/6379.log” # 日志目录, 确保存在否则启动报错
dir /var/redis/data # 数据存放目录(RDB和AOF共用), 确保存在否则启动报错
dbfilename 6379.rdb # rdb数据持久化文件
appendonly yes # 打开aof
appendfilename “6379.aof” # aof数据持久化文件
cluster-enabled yes # 集群配置, 开启时单实例机无法执行数据操作(get | set 等)
cluster-config-file nodes-6379.conf # 自动生成, 保存到上面指定的data目录
其他配置保持默认即可.
####启动服务推荐使用redis/utils/redis_init_script
为启动脚本建立软连接方便使用
1 | ln -s $PWD/utils/redis_init_script /usr/bin/redis |
以上步骤顺利完成后, 就可以开始集群配置了, redis集群至少要求3主3从, 所以至少需要6个单实例服务, 可以通过单机6个配置的方式, 或多个宿主机的方式配置.
3.集群配置
单机多配置
只需要拷贝多份配置文件和启动脚本, 将这两个文件中的端口对应的值替换为不同的端口
特别需要注意的是单机配置多个redis时, 时刻记得–>改端口,改端口,改端口<– 不能两个服务重复使用同一个端口
1 | mkdir ../redis2 |
多机配置
每个主机上运行一个redis其实没什么好写的,就是步骤1 和 2, 安装完成后开启服务就好了
4.安装ruby环境
redis对ruby的版本有要求, 目前CentOS7的仓库版本还是很低, 需要到官网下载安装
1 | # 如果当前系统已经附带了一个低版本的ruby 需要先卸载 |
至此, ruby环境也装好了, 可以开始建集群了
5. 创建集群
1 | redis-trib create --replicas 1 192.168.1.100:6379 192.168.1.100:7379 192.168.1.100:8379 192.168.1.100:9379 192.168.1.100:10379 192.168.1.100:11379 |
6.问题解决
#### 6.1 问题1
创建集群出现如下错误
rubygems/core_ext/kernel_require.rb:59:in `require’: cannot load such file – redis (LoadError)
这种还没开始执行创建就已经脚本错误的情况, 一般是没为ruby安装redis组件引起的, 参考 第4步
#### 6.2 问题2
创建集群的时候出现如下错误
Can I set the above configuration? (type ‘yes’ to accept): yes
/usr/local/lib/ruby/gems/2.4.0/gems/redis-4.0.2/lib/redis/client.rb:119:in `call’: ERR Slot 0 is already busy (Redis::CommandError)也就是提示槽xxx繁忙的时候, 将建立集群的每个节点清除数据并重置
1 | [root@leader1 redis]# redis-cli -h leader1 6379 |
7.使用集群
使用客户端连接时, 添加一个参数 -c
1 | [root@leader1 redis2]# redis-cli -h 192.168.1.100 -p 6379 -c |
整个搭建流程到此结束了, 祝君好运.