热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

部署rediscluster

1、环境准备☆每个Redis节点采用相同的相同的Redis版本、相同的密码、硬件配置☆所有Redis服务器必须没有任何数据#所有主从节点执行:[root@ubuntu2004~]#
1、环境准备

☆ 每个Redis 节点采用相同的相同的Redis版本、相同的密码、硬件配置

☆ 所有Redis服务器必须没有任何数据

#所有主从节点执行:

[[email protected] ~]#bash install_redis.sh

#脚本参考:https://blog.51cto.com/dayu/5805274

2、启用 redis cluster 配置

#所有主从节点执行:

#每个节点修改redis配置,必须开启cluster功能的参数
[[email protected] ~]#vim /apps/redis/etc/redis.conf

bind 0.0.0.0

masterauth 123456 #建议配置,否则后期的master和slave主从复制无法成功,还需再配置

requirepass 123456

cluster-enabled yes #取消此行注释,必须开启集群,开启后 redis 进程会有cluster标识

cluster-config-file nodes-6379.conf #取消此行注释,此为集群状态数据文件,记录主从关系及slot范围信息,由redis cluster 集群自动创建和维护

cluster-require-full-coverage no #默认值为yes,设为no可以防止一个节点不可用导致整个cluster不可用

#验证当前Redis服务状态:

[[email protected] ~]#ss -ntl

State Recv-Q Send-Q Local Address:Port Peer Address:Port Process

LISTEN 0 511 0.0.0.0:6379 0.0.0.0:*

LISTEN 0 4096 127.0.0.53%lo:53 0.0.0.0:*

LISTEN 0 128 0.0.0.0:22 0.0.0.0:*

LISTEN 0 511 0.0.0.0:16379 0.0.0.0:*

LISTEN 0 511 [::1]:6379 [::]:*

LISTEN 0 128 [::]:22 [::]:*

LISTEN 0 511 [::1]:16379 [::]:*
#开启了16379的cluster的端口,实际的端口=redis port + 10000

3、创建集群

#10.0.0.101:

[[email protected] ~]#redis-cli -a 123456 --cluster create 10.0.0.101:6379 10.0.0.102:6379 10.0.0.103:6379 10.0.0.18:6379 10.0.0.28:6379 10.0.0.38:6379 --cluster-replicas 1

#命令redis-cli的选项 --cluster-replicas 1 表示每个master对应一个slave节点

4、验证集群

#查看主从状态

[[email protected] ~]#redis-cli -a 123456 -c info replication

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

# Replication

role:master

connected_slaves:1

slave0:ip=10.0.0.28,port=6379,state=online,offset=602,lag=0

......
#查看对应关系

[[email protected] ~]#redis-cli -a 123456 cluster nodes

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

c58b6d30550a3d6d682d2a4f7563efabf470bd82 10.0.0.38:[email protected] slave 139317befd252551e1135b27d32ce557133ec71a 0 1667098745948 2 connected

......
#验证集群状态

[[email protected] ~]#redis-cli -a 123456 cluster info

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

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 #三个集群

......
#查看任意节点的集群状态

[[email protected] ~]#redis-cli -a 123456 --cluster info 10.0.0.38:6379

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

10.0.0.102:6379 (139317be...) -> 0 keys | 5462 slots | 1 slaves.

10.0.0.101:6379 (98df8874...) -> 0 keys | 5461 slots | 1 slaves.

10.0.0.103:6379 (8d72bbb5...) -> 0 keys | 5461 slots | 1 slaves.

[OK] 0 keys in 3 masters.

0.00 keys per slot on average.
[[email protected] ~]#redis-cli -a 123456 --cluster check 10.0.0.38:6379

5、测试写入数据

[[email protected] ~]#redis-cli -a 123456 -h 10.0.0.102 set k1 wang

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

(error) MOVED 12706 10.0.0.103:6379 #槽位不在当前node所以无法写入
[[email protected] ~]#redis-cli -a 123456 -h 10.0.0.103 set k1 wang

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

OK
[[email protected] ~]#redis-cli -a 123456 -h 10.0.0.103 get k1

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

"wang"

[[email protected] ~]#redis-cli -a 123456 -h 10.0.0.103 get k1

Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.

"wang"
#使用选项-c 以集群模式连接

[[email protected] ~]#redis-cli -c -h 10.0.0.18 -a 123456 --no-auth-warning

10.0.0.18:6379> cluster keyslot test

(integer) 6918

10.0.0.18:6379> set test mylove

-> Redirected to slot [6918] located at 10.0.0.102:6379

OK

10.0.0.102:6379> get test

"mylove"

10.0.0.102:6379> exit

[[email protected] ~]#redis-cli -h 10.0.0.102 -a 123456 --no-auth-warning get test

"mylove"


部署redis-cluster的相关教程结束。



推荐阅读
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Python开发过程中,随着项目数量的增加,不同项目依赖于不同版本的库,容易引发依赖冲突。为了避免这些问题,并保持开发环境的整洁,可以使用Virtualenv和Virtualenvwrapper来创建和管理多个隔离的Python虚拟环境。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • openGauss每日一练:第6天 - 模式的创建、修改与删除
    本篇笔记记录了openGauss数据库中关于模式(Schema)的创建、修改和删除操作。通过这些操作,用户可以更好地管理和控制数据库对象。实验环境为openGauss 2.0.0,并使用由墨天轮提供的线上环境。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 本文详细探讨了如何在Docker环境中实现单机部署Redis集群的方法,提供了详细的步骤和配置示例,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 在Fedora 31上部署PostgreSQL 12
    本文详细介绍如何在Fedora 31操作系统上安装和配置PostgreSQL 12数据库。包括环境准备、安装步骤、配置优化以及安全设置,确保数据库能够稳定运行并提供高效的性能。 ... [详细]
  • 在编译BSP包过程中,遇到了一个与 'gets' 函数相关的编译错误。该问题通常发生在较新的编译环境中,由于 'gets' 函数已被弃用并视为安全漏洞。本文将详细介绍如何通过修改源代码和配置文件来解决这一问题。 ... [详细]
  • 在Ubuntu 16.04 LTS上配置Qt Creator开发环境
    本文详细介绍了如何在Ubuntu 16.04 LTS系统中安装和配置Qt Creator,涵盖了从下载到安装的全过程,并提供了常见问题的解决方案。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
author-avatar
Panzerkampfwagen-VI_238
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有