参考
https://www.cnblogs.com/caoweixiong/p/14235807.html
https://blog.csdn.net/qq_35937724/article/details/106906244
二、服务器设置
设置主机名:
hostnamectl set-hostname node1/node2/node3
配置映射:
vi /etc/hosts
192.168.146.199 node1
192.168.146.200 node2
192.168.146.201 node3
时区调整,时间校准:
date -R
timedatectl set-timezone Asia/Shanghai
yum -y install ntp
# ntpdate ntp1.aliyun.com
关闭selinux:
vi /etc/sysconfig/selinux
SELINUX=disabled
重启服务器并验证:
getenforce
关闭防火墙:
service iptables stop
chkconfig iptables off
内核设置
1,chmod +x /etc/rc.d/rc.local
2、 将 vm.overcommit_memory = 1 添加到/etc/sysctl.conf中,然后重启服务器或运行命令sysctl vm.overcommit_memory = 1使其立即生效。
vim /etc/sysctl.conf
vm.overcommit_memory = 1
3、 确保禁用Linux内核功能透明的大页面,它将以负面的方式极大地影响内存使用和延迟。这可以通过以下命令完成:
先直接执行(临时生效):
echo never> /sys/kernel/mm/transparent_hugepage/enabled
再执行以下命令(永久生效):
vim /etc/rc.local
追加:echo never>/sys/kernel/mm/transparent_hugepage/enabled
4、 解决问题:【TCP backlog设置值,511没有成功,因为 /proc/sys/net/core/somaxconn这个设置的是更小的128】
先直接执行(临时生效):
echo 511 > /proc/sys/net/core/somaxconn
再执行以下命令(永久生效):
vim /etc/rc.local
追加:echo 511 > /proc/sys/net/core/somaxconn
vim /etc/rc.local
echo 511 > /proc/sys/net/core/somaxconn
echo never>/sys/kernel/mm/transparent_hugepage/enabled
5、 重启服务器。
reboot
1、gcc版本问题避免
Redis是c语言开发的。安装redis需要c语言的编译环境。
安装redis6最主要的一点是要用GCC5以上,而CentOS6.9的GCC版本为4.8.x, 所以安装之前必须升级GCC(使用命令gcc --version查看版本)。
yum -y install gcc tcl
yum -y install centos-release-scl
yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils
查看gcc版本:
gcc -v
scl只是临时启用,退出shell后会恢复原系统gcc版本:
scl enable devtoolset-9 bash
如下命令表示永久启用:
echo "source /opt/rh/devtoolset-9/enable" >> /etc/profile
查看gcc版本:
gcc -v
下载安装
cd /opt
wget http://download.redis.io/releases/redis-6.0.9.tar.gz
tar -xvf redis-6.0.9.tar.gz
cd redis-6.0.9
make MALLOC=libc
make install PREFIX=/usr/local/redis
查看/usr/local/redis/bin,如看见redis具工表示redis已安装成功:
ls /usr/local/redis/bin
3、Redis配置
建立安裝Redis時会用到的文件夹:
mkdir -p /usr/local/redis/run
mkdir -p /usr/local/redis/log
mkdir -p /usr/local/redis/data/7000
mkdir -p /usr/local/redis/conf
设置redis配置文件:
cp /opt/redis-6.0.9/redis.conf /usr/local/redis/conf/redis_7000.conf
vi /usr/local/redis/conf/redis_7000.conf
bind 192.168.146.199 #添加本机的ip
port 7000 #端口
pidfile /usr/local/redis/run/redis_7000.pid #pid存储目录
logfile /usr/local/redis/log/redis_7000.log #日志存储目录
dir /usr/local/redis/data/7000 #数据存储目录,目录要提前创建好
cluster-enabled yes #开启集群
cluster-config-file nodes-7000.conf #集群节点配置文件,这个文件是不能手动编辑的。确保每一个集群节点的配置文件不通
cluster-node-timeout 15000 #集群节点的超时时间,单位:ms,超时后集群会认为该节点失败
appendonly yes #持久化
daemonize yes #守护进程
4、建立不同端口实例
由于我们的机器有限,我们将采用一台机器多个端口的方式搭建我们的Redis集群。
复制配置文件:
cp /usr/local/redis/conf/redis_7000.conf /usr/local/redis/conf/redis_7001.conf
mkdir -p /usr/local/redis/data/7001
vi /usr/local/redis/conf/redis_7001.conf
bind 192.168.146.199 #添加本机的ip
port 7001 #端口
pidfile /usr/local/redis/run/redis_7001.pid #pid存储目录
logfile /usr/local/redis/log/redis_7001.log #日志存储目录
dir /usr/local/redis/data/7001 #数据存储目录,目录要提前创建好
cluster-enabled yes #开启集群
cluster-config-file nodes-7001.conf #集群节点配置文件,这个文件是不能手动编辑的。确保每一个集群节点的配置文件不通
cluster-node-timeout 15000 #集群节点的超时时间,单位:ms,超时后集群会认为该节点失败
appendonly yes #持久化
daemonize yes #守护进程
#requirepass password #密码
redis-cli -h 127.0.0.1 -a password
5、制作启动配置文件
cd /usr/local/redis/bin
启动脚本:
vi cluster_start.sh
#!/bin/bash
./redis-server ../conf/redis_7000.conf
./redis-server ../conf/redis_7001.conf
chmod +x cluster_start.sh
关闭脚本:
vi cluster_shutdown.sh
#!/bin/bash
pgrep redis-server | xargs -exec kill -9
chmod +x cluster_shutdown.sh
6、启动&关闭Redis:
启动redis:
./cluster_start.sh
ps -ef|grep redis
关闭redis:
./cluster_shutdown.sh
1、创建集群
在redis3.0和4.0版本中,创建集群还是使用redis-trib.rb方式去创建,但是在5.0之后,可以直接使用redis-cli直接创建集群,本文redis版本为6.0,所以创建集群的方式为redis-cli方式直接创建。
用以下命令创建集群,--cluster-replicas 1 参数表示希望每个主服务器都有一个从服务器,这里则代表3主3从,前3个代表3个master,后3个代表3个slave。
通过该方式创建的带有从节点的机器不能够自己手动指定主节点,redis集群会尽量把主从服务器分配在不同机器上。
redis-cli --cluster create 192.168.146.199:7000 192.168.146.200:7000 192.168.146.201:7000 192.168.146.199:7001 192.168.146.200:7001 192.168.146.201:7001 --cluster-replicas 1
>>> Performing hash slots allocation on 6 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
Adding replica 192.168.146.200:6380 to 192.168.146.199:7000
Adding replica 192.168.146.201:6380 to 192.168.146.200:7000
Adding replica 192.168.146.199:6380 to 192.168.146.201:7000
M: 7a0af6d896222c60b582c8ecb16d1369a5ef33b4 192.168.146.199:7000
slots:[0-5460] (5461 slots) master
M: 825e26272e82f4900f2b99bb05cc8efa87f2c238 192.168.146.200:7000
slots:[5461-10922] (5462 slots) master
M: e52b4a755ab35381931ba89cf0399ac2657c0d93 192.168.146.201:7000
slots:[10923-16383] (5461 slots) master
S: caed0e5b336cb31d6d6b29874170075a21e6923b 192.168.146.199:7001
replicates e52b4a755ab35381931ba89cf0399ac2657c0d93
S: c155299d628e705565915cec624faf67946556a5 192.168.146.200:7001
replicates 7a0af6d896222c60b582c8ecb16d1369a5ef33b4
S: d9bca2b5cabb426aa2e296e6696e60e35ef4bebe 192.168.146.201:7001
replicates 825e26272e82f4900f2b99bb05cc8efa87f2c238
2、查看集群状态
redis-cli -c -h 192.168.146.199 -p 7000 cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3
cluster_current_epoch:6
cluster_my_epoch:1
cluster_stats_messages_ping_sent:482
cluster_stats_messages_pong_sent:488
cluster_stats_messages_sent:970
cluster_stats_messages_ping_received:483
cluster_stats_messages_pong_received:482
cluster_stats_messages_meet_received:5
cluster_stats_messages_received:970
查看集群节点
redis-cli -c -h 192.168.146.199 -p 7000 cluster nodes
五、测试用例
[root@node1 redis-6.0.9]# redis-cli -c -h 192.168.146.199 -p 7000
192.168.146.199:7000> set name node1
-> Redirected to slot [5798] located at 192.168.146.200:7000
OK
[root@node2 redis-6.0.9]# redis-cli -c -h 192.168.146.200 -p 7000
192.168.146.200:7000> get name
"node1"
root@node3 redis-6.0.9]# redis-cli -c -h 192.168.146.201 -p 7000
192.168.146.201:7000> get name
-> Redirected to slot [5798] located at 192.168.146.200:7000
"node1"
192.168.146.201:7000> del name
-> Redirected to slot [5798] located at 192.168.146.200:7000
(integer) 1
192.168.146.201:7000> get name
-> Redirected to slot [5798] located at 192.168.146.200:7000
(nil)
#单节点常用配置
daemonize yes port 6379 pidfile /home/app/redis/redis.pid bind 0.0.0.0 logfile /home/app/redis/logs/redis.log dir /home/app/redis/data dbfilename dump.rdb appendonly yes #默认不开启aof模式,可根据需求调整,开启时改为yes appendfilename appendonly.aof #可修改aof默认文件名 requirepass Password #开启密码验证,并设置密码
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!