linux中,redis分布式集群搭建

复制代码
redis分布式集群(分布式存储)

	1.redis分布式高可用存储概念
		核心概念:哈希槽
			crc算法计算key值,对16384取余,值在0-16383之间
			crc % int = ...
		结论:判断redis集群是否高可用的标准,哈希槽是否完全利用

	2.redis分布式高可用集群搭建	

		(1)修改并同步配置文件
		(2)使用命令创建集群

		(1)修改并同步配置文件:/etc/redis.conf
			69  bind 0.0.0.0		#ip地址
			838 cluster-enabled yes	#启用集群
			846 cluster-config-file nodes-6379.conf	#存储集群信息文件
			852 cluster-node-timeout 15000	#超时时间
	
			--for循环同步文件:(远程连接+命令)
			for i in 192.168.88.5{2..6}; 
			do 
				scp /etc/redis.conf $i:/etc/; 
				ssh $i "systemctl enable redis --now"; 
			done
			--
			for i in 192.168.88.5{1..6}; do redis-cli -h $i info cluster; done
	
		(2)创建集群 --cluster create --cluster-replicas 1
	
			redis-cli --cluster create --cluster-replicas 1 \
			192.168.88.51:6379 192.168.88.52:6379 192.168.88.53:6379 \
			192.168.88.54:6379 192.168.88.55:6379 192.168.88.56:6379
				--cluster-replicas 1#指定副本
	
		(3)连接集群使用,(数据存储)
			redis-cli -c -h 任意节点IP -p 任意节点端口
			 	    -c 启用集群模式,


	3.集群操命令:redis-cli --cluster help
		
		(1)--cluster create  创建集群
			redis-cli --cluster create --cluster-replicas 1 <host1>:<port> ...<hostN>:<port>

		(2)--cluster check  检查集群状态
			redis-cli --cluster check  <host>:<port>
			<host>:<port> 是集群中任意一个节点的 IP 地址和端口号

		(3)--cluster info 查看集群信息
			redis-cli --cluster info <host>:<port>

		(4)--cluster fix  修复集群
			redis-cli --cluster fix <host>:<port>

		(5)--cluster call  在集群中执行命令(比如查看集群的key数据)

			redis-cli --cluster call <host>:<port> <command>
			[root@host51 ~]#  redis-cli --cluster call 192.168.88.51:6379 keys \*
			
		(6)--cluster  add-node    集群扩容

			redis-cli --cluster add-node <newhost>:<port>  <existhost>:<port> 

			redis-cli --cluster add-node <newhost>:<port> <existhost>:<port> \
			--cluster-slave --cluster-master-id <master-node-id>
		说明:
		add-node:向集群中添加一个新节点。
		<newhost>:<port>:新节点的地址,格式为 ip:port。
		<existhost>:<port> :集群中已存在的任意一个节点的地址,格式为 ip:port。这个节点用于告知集群管理系统新节点应该加入到哪个集群中。添加新节点时,必须指定集群中的一个现有节点,以便将新节点加入到正确的集群中。
		--cluster-slave:新添加的节点将作为一个从节点(slave)加入到集群中,而不是作为一个独立的主节点(master)。
		--cluster-master-id:指定新从节点将要复制的主节点的 ID。<master-node-id> 是目标主节点的唯一标识符,通常是一串十六进制数字。
		--cluster-master-id,--cluster-slave:不添加后面两个选项,则扩容位主节点


		(7)--cluster del-node      集群缩容
			redis-cli --cluster del-node <host>:<port> <node-id>
			<host>:<port>:集群中任意一个节点的 IP 地址和端口号。
			<node-id>:你要从集群中移除的节点的唯一标识符(ID)。

		(8)--cluster rehard 重新分配槽位

			redis-cli --cluster reshard <host>:<port>
		
			Redis 集群内部会协调整个重新分配过程

		(9)--cluster rebalance 平衡集群槽位
			redis-cli --cluster rebalance <host>:<port> 
			  

		(10)--cluster set-timeout     整个集群的超时时间
			redis-cli --cluster set-timeout <host>:<port> <milliseconds>

		(11)--cluster backup         备份集群rdb文件
			redis-cli -h <host> -p <port> --rdb /path/to/backup.rdb SAVE

4.redis分布式集群(分布式存储)

1.redis分布式高可用存储概念

核心概念:哈希槽

crc算法计算key值,对16384取余,值在0-16383之间

crc % int = ...

结论:判断redis集群是否高可用的标准,哈希槽是否完全利用

2.redis分布式高可用集群搭建

(1)修改并同步配置文件

(2)使用命令创建集群

(1)修改并同步配置文件:/etc/redis.conf

69 bind 0.0.0.0 #ip地址

838 cluster-enabled yes #启用集群

846 cluster-config-file nodes-6379.conf #存储集群信息文件

852 cluster-node-timeout 15000 #超时时间

--for循环同步文件:(远程连接+命令)

for i in 192.168.88.5{2..6};

do

scp /etc/redis.conf $i:/etc/;

ssh $i "systemctl enable redis --now";

done

--

for i in 192.168.88.5{1..6}; do redis-cli -h $i info cluster; done

(2)创建集群 --cluster create --cluster-replicas 1

redis-cli --cluster create --cluster-replicas 1 \

192.168.88.51:6379 192.168.88.52:6379 192.168.88.53:6379 \

192.168.88.54:6379 192.168.88.55:6379 192.168.88.56:6379

--cluster-replicas 1#指定副本

(3)连接集群使用,(数据存储)

redis-cli -c -h 任意节点IP -p 任意节点端口

-c 启用集群模式,

3.集群操命令:redis-cli --cluster help

(1)--cluster create 创建集群

redis-cli --cluster create --cluster-replicas 1 <host1>:<port> ...<hostN>:<port>

(2)--cluster check 检查集群状态

redis-cli --cluster check <host>:<port>

<host>:<port> 是集群中任意一个节点的 IP 地址和端口号

(3)--cluster info 查看集群信息

redis-cli --cluster info <host>:<port>

(4)--cluster fix 修复集群

redis-cli --cluster fix <host>:<port>

(5)--cluster call 在集群中执行命令(比如查看集群的key数据)

redis-cli --cluster call <host>:<port> <command>

root@host51 \~\]# redis-cli --cluster call 192.168.88.51:6379 keys \\\* (6)--cluster add-node 集群扩容 redis-cli --cluster add-node \:\ \:\ redis-cli --cluster add-node \:\ \:\ \\ --cluster-slave --cluster-master-id \ 说明: add-node:向集群中添加一个新节点。 \:\:新节点的地址,格式为 ip:port。 \:\ :集群中已存在的任意一个节点的地址,格式为 ip:port。这个节点用于告知集群管理系统新节点应该加入到哪个集群中。添加新节点时,必须指定集群中的一个现有节点,以便将新节点加入到正确的集群中。 --cluster-slave:新添加的节点将作为一个从节点(slave)加入到集群中,而不是作为一个独立的主节点(master)。 --cluster-master-id:指定新从节点将要复制的主节点的 ID。\ 是目标主节点的唯一标识符,通常是一串十六进制数字。 --cluster-master-id,--cluster-slave:不添加后面两个选项,则扩容位主节点 (7)--cluster del-node 集群缩容 redis-cli --cluster del-node \:\ \ \:\:集群中任意一个节点的 IP 地址和端口号。 \:你要从集群中移除的节点的唯一标识符(ID)。 (8)--cluster rehard 重新分配槽位 redis-cli --cluster reshard \:\ Redis 集群内部会协调整个重新分配过程 (9)--cluster rebalance 平衡集群槽位 redis-cli --cluster rebalance \:\ (10)--cluster set-timeout 整个集群的超时时间 redis-cli --cluster set-timeout \:\ \ (11)--cluster backup 备份集群rdb文件 redis-cli -h \ -p \ --rdb /path/to/backup.rdb SAVE

相关推荐
趁你还年轻_20 分钟前
Redis大量key集中过期怎么办
数据库·redis·缓存
MyY_DO25 分钟前
通讯录实现(Linux+Cpp)
linux·运维·服务器
独行soc27 分钟前
2025年渗透测试面试题总结-腾讯[实习]玄武实验室-安全工程师(题目+回答)
linux·安全·web安全·面试·职场和发展·渗透测试·区块链
艾露z1 小时前
深度解析Mysql中MVCC的工作机制
java·数据库·后端·mysql
predisw1 小时前
Kafka broker 写消息的过程
分布式·kafka
全职计算机毕业设计1 小时前
SpringBoot+Mysql实现的停车场收费小程序系统+文档
spring boot·mysql·小程序
AirMan2 小时前
SQL语句中,为什么group by能够提前"预知"select的别名?
mysql
自动驾驶小卡2 小时前
ubuntu 常用操作指令(与域控制器交互相关)
linux·ubuntu·操作指令
意如流水任东西2 小时前
Linux开发工具(apt,vim,gcc)
linux·服务器
XMAIPC_Robot2 小时前
基于RK3568的多网多串电力能源1U机箱解决方案,支持B码,4G等
linux·fpga开发·能源·边缘计算