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

相关推荐
朱包林22 分钟前
day45-nginx复杂跳转与https
linux·运维·服务器·网络·云计算
孙克旭_24 分钟前
day045-nginx跳转功能补充与https
linux·运维·nginx·https
陌殇殇31 分钟前
SpringBoot整合SpringCache缓存
spring boot·redis·缓存
Amy187021118232 小时前
赋能低压分布式光伏“四可”建设,筑牢电网安全新防线
分布式
孞㐑¥2 小时前
Linux之Socket 编程 UDP
linux·服务器·c++·经验分享·笔记·网络协议·udp
DCTANT4 小时前
【原创】国产化适配-全量迁移MySQL数据到OpenGauss数据库
java·数据库·spring boot·mysql·opengauss
M4K05 小时前
Linux百度网盘优化三板斧
linux
June bug6 小时前
【软考中级·软件评测师】下午题·面向对象测试之架构考点全析:分层、分布式、微内核与事件驱动
经验分享·分布式·职场和发展·架构·学习方法·测试·软考
好奇的菜鸟6 小时前
如何在 Ubuntu 24.04 (Noble) 上使用阿里源
linux·运维·ubuntu
程序员岳焱6 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化