redis高可用集群数据库的安装部署(6.2.12版本)

news2024/11/24 11:05:53

第三阶段基础

时  间:2023年7月3日

参加人:全班人员

内  容:

6.2.12版本redis集群部署

目录

一、环境配置:【两台服务器】

二、redis多实例配置:

三、构建redis cluster集群

四、创建主从

五、故障转移实验

六、拓  展


安装部署:(一台主机,三主三从,redis版本为6.2.12)

实验基本条件:

服务器huyang2

主 库

Node1

Node2

Node3

8001

8002

8003

192.168.59.138

从 库

Node4

Node5

Node6

8004

8005

8006

一、环境配置:【两台服务器】

 1、关闭防火墙

systemctl stop firewalld

iptables -F

setenforce 0

2.安装相关基础环境

 yum -y install wget gcc gcc-c++ make tar openssl

openssl-devel cmake

3.上传相关软件安装包

rz  redis-6.2.12.tar.gz  

4.解压安装包并调整位置

mkdir /usr/local/redis

tar xf redis-6.2.12.tar.gz -C /usr/local/redis

5、编译、配置、安装

cd /usr/local/redis

make  && make install

6、验证redis的安装

./src/redis-server redis.conf

7、优化redis程序命令

mkdir -p /usr/local/redis_cluster

cd /usr/local/redis_cluster

mkdir -p 8001/data 8002/data 8003/data

8004/data 8005/data 8006/data

mkdir bin

cd /usr/local/redis/redis-6.2.12/src

cp mkreleasehdr.sh redis-benchmark redis-check-aof

redis-cli redis-server redis-trib.rb /usr/local/redis_cluster/bin

 ln -s  /usr/local/redis_cluster/bin*

/usr/local/bin/

8.系统调优配置

echo never >

/sys/kernel/mm/transparent_hugepage/enabled

echo never >

/sys/kernel/mm/transparent_hugepage/defrag

echo 'echo never >

/sys/kernel/mm/transparent_hugepage/enabled' >>

/etc/rc.local

echo 'echo never >

/sys/kernel/mm/transparent_hugepage/defrag' >>

/etc/rc.local

echo "* - nofile 10240" >> /etc/security/limits.conf        --文件并发数

echo "net.core.somaxconn = 10240" >> /etc/sysctl.conf    --监听队列

echo "vm.overcommit_memory = 1" >> /etc/sysctl.conf    -- 0内存不够,就会拒绝申请

1物理内存都允许分配给你,只要有内存就给你用,这样可以避免申请内存失败的问题。

sysctl -p

二、redis多实例配置:

主库配置

步骤一:复制配置文件并修改

cp   /usr/local/redis/redis-6.2.12/redis.conf

/usr/local/redis_cluster/8001

cp redis.conf{,.bak}

egrep -v "^$|^#" redis.conf.bak > conf/redis.conf

步骤二:修改配置文件

vim 8001/redis.conf

修改配置如下:

cluster-enabled yes

bind 0.0.0.0

port 8001

pidfile /data/redis-cluster/8001/redis.pid

logfile "/data/redis-cluster/8001/redis.log"

dir /data/redis-cluster/8001/

tcp-backlog 1024

daemonize yes

同理,将8002和8003配置文件修改,与上述端口不一,其他一致

步骤三:启动服务

redis-server 8001/redis.conf

redis-server 8002/redis.conf

redis-server 8003/redis.conf

netstat -antup | grep redis-server

从库配置:

步骤一:复制配置文件并修改

cp   /usr/local/redis/redis-6.2.12/redis.conf

/usr/local/redis_cluster/8004

cp redis.conf{,.bak}

egrep -v "^$|^#" redis.conf.bak > conf/redis.conf

步骤二:修改配置文件

vim 8004/redis.conf

修改配置如下:

cluster-enabled yes

bind 0.0.0.0

port 8004

pidfile /data/redis-cluster/8004/redis.pid

logfile "/data/redis-cluster/8004/redis.log"

dir /data/redis-cluster/8004/

tcp-backlog 1024

daemonize yes

同理,将8005和8006配置文件修改,与上述端口不一,其他一致

步骤三:启动服务

redis-server 8004/redis.conf

redis-server 8005/redis.conf

redis-server 8006/redis.conf

netstat -antup | grep redis-server

三、构建redis cluster集群

步骤一:创建集群节点

redis-cli -p 8001 -c  (以集群模式登录任意节点)

cluster  meet    ip+端口 

(把其他实例全部添加到集群中,登录进集群内操作)

cluster nodes 查看集群节点信息

步骤二:分配槽(退出集群操作)

redis-cli  -p 8001 cluster addslots   {0..5000}        

redis-cli  -p 8002 cluster addslots {5001..10000}

redis-cli  -p 8003 cluster addslots {10001..16383}

cluster nodes 查看集群节点信息,都有了槽

步骤三:验证加入集群和未加入集群的区别

创建数据:

redis-cli -p 8001 -c 登录集群

set name huyang1

查看数据:

可以发现,加入到集群之中的节点和创建数据本省的节点可以查看数据之外,其余未加入集群的节点不可以查看数据,由此可见集群的特性。

四、创建主从

步骤一:添加从库节点进入集群

redis-cli -p 8001 -c

cluster  meet    192.168.59.138 8004

cluster  meet    192.168.59.138 8005

cluster  meet    192.168.59.138 8006

都为主库

步骤二:退出集群,命令行操作

redis-cli  -p 端口 cluster replicate id号

例:redis-cli  -p 8004 cluster replicate

cbcc0afc179ffe4b1626b26b2ceb9ecab9c29e96

登录集群,查看信息

redis-cli  -p 8004 -c

cluster nodes

同理,将8005,8006添加为8002,8003的从库

五、故障转移实验

实验一:模拟主库8001宕机,查看变化

登录集群,查看信息

故障转移,如下:

实验二:使用不同ip地址的不同端口接入集群

观察变化

变化:

实验三:使用集群中的两条主库,进入新的集群

特性,

两个主库居然合在一起共用一个数据库!!!!

六、拓  展

(一)添加节点

集群伸缩-添加节点

redis-cli --cluster add-node  加新节点IP:端口   

原任意节点IP/:端口

例:

redis-cli --cluster add-node 192.168.59.137:7005  192.168.59.137:7002

可以发现,以上述方法添加的节点都为主库

(二)删除节点

redis-cli --cluster del-node IP:端口号  id号

例:

redis-cli --cluster del-node 192.1 68.59.137:7005 9c73cbfbbc09b214f6136d6a337d052911290914

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/719446.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IT安全部门应如何平衡企业内外部文件交换的业务效率与安全性?

在日常运营经营中,很多企业存在与外部客户的业务数据往来,如生产型企业与上下游供应链间的制造设计相关文件交换、金融企业与外部监管机构和合作方间的重要客户数据收发、文化娱乐产业内外部关于作品素材的传输交流等。当内外部数据文件交换较为频繁、且…

什么是Web3.0?

鲁迅先生曾言:“人一旦有钱,智商和情商都会是高86.4%,烦恼也会消失100%。”然而,问题来了,钱从哪里来?他只留下了一串数字Dle577。同时,莎士比亚也指出,这个世界上只有少数人能够把握…

《安全软件开发框架(SSDF) 1.1:降低软件漏洞风险的建议》解读(四)

安全软件开发框架SSDF是由美国国家标准与技术研究院发布的关于安全软件开发的一组实践,帮助开发组织减少发布的软件中的漏洞数量,减少利用未检测到或未解决的漏洞的潜在影响,从根本上解决漏洞防止再次发生。本文根据《Secure Software Develo…

防火墙基本原理详解

概要 防火墙是可信和不可信网络之间的一道屏障,通常用在LAN和WAN之间。它通常放置在转发路径中,目的是让所有数据包都必须由防火墙检查,然后根据策略来决定是丢弃或允许这些数据包通过。例如: 如上图,LAN有一台主机和一…

【业务功能篇38】上篇:Springboot+activiti7 工作流引擎 增加网关组件、Assignment分配权限

在前面的一篇文章中,简单举例了一个 工单电子流,【业务功能篇36】Springbootactiviti7 工作流引擎_studyday1的博客-CSDN博客仅有一个子任务,这种一般是针对比较简单的一个遗留问题记录场景,今天再介绍一个,相对比较复…

为什么放弃Java后,没有使用Kotlin,新的开发语言正在席卷而来

放弃Java后,没有使用Kotlin 从 Java 到Kotlin,Kotlin作为Android官方支持语言,获得了更多的关注和采用! 这几年,Kotlin的发展势头很猛,可以说由 Java 转 Kotlin 早已势不可挡。 那么Kotlin有哪些优势可以…

AI视觉赢未来|深眸科技出席元宇宙装备展,“智与质”实现双重升级

6月29日,2023昆山元宇宙国际装备展在昆山国际会展中心圆满落幕,此次展会不仅为我们呈现最先进的元宇宙装备、最前沿的元宇宙技术、最潮流的元宇宙应用,还为工业元宇宙的发展蓄势赋能。 浙江深眸科技有限公司(以下简称深眸科技&am…

数据太大了?快来试试这款地理空间数据云管理平台

四维轻云是一款网页版地理空间数据云管理平台,用户能够在线管理、浏览及分享倾斜模型(.osgb)、激光点云(.las)、正射影像(dom)、数字高程模型(dem)等数据。目前,平台具有数据管理、场景编辑、空间测量、团队协作、加密分享、素材库等功能。 项目管理 四…

【Linux】什么是文件系统及inode?如何创建软硬链接?软硬链接有什么作用?

inode软硬链接创建软硬链接理解硬链接理解软链接 inode 了解一下文件系统: Linux ext2文件系统,上图为磁盘文件系统图(内核内存映像肯定有所不同),磁盘是典型的块设备,硬盘分区被 划分为一个个的block。…

【Qt】程序异常结束。The process was ended forcefully.(解决方法不一样哦)

环境 系统:win10 64bit Qt:5.14.1 编译器:MinGW 32-bit 问题 Qt工程编译正常,但无法调试,报错:程序异常结束。The process was ended forcefully. 步骤 已尝试网上方法仍然不行的,可以直接…

为什么JDK动态代理只能代理接口?

在Java中,动态代理是一种机制,允许在运行时动态地创建代理对象来代替某个实际对象,从而在其前后执行额外的逻辑。 为什么JDK动态代理只能代理接口实现类,原因是JDK动态代理是基于接口实现的。 当你使用Proxy类创建代理对象时&am…

第一章:Linux常用命令+VIM+SSH介绍+SSH密钥登录

目录 一、Linux常用命令 1)# 与 $ 提示的区别 2)ifconfig 3) su 4) cd 5) 目录查看 6) 查看文件内容 7)创建目录及文件 8)复制和移动 9)其他 10) …

Git 上传Github 超时问题

提交代码到GitHub总是超时,偶尔会直接上传成功。 提供一下解决方案 1.首先找到网络 2. 找到代理 3. 把自动检查设置全部关闭,然后打开手动设置代理,然后输入ip地址和你代理的端口号,保存即可。 4. 最后使用git push origin mast…

多边形偏移算法【Polygon Offsetting】

在本教程中,我们将描述一种膨胀或收缩多边形的算法。 推荐:用 NSDT设计器 快速搭建可编程3D场景。 1、一般形式的同调 为了简单起见,让我们从一个形状开始,一个正方形。 我们可能熟悉通过放大或缩小形状来缩放形状的想法。 从技术…

Jmeter实现生成全局参数-随机数

我在做项目的过程中,用的比较多的是【前置处理中】-用户参数 步骤一:添加参数处理器 步骤二:填写项目中可能会用到的一些参数(固定的或者随机的都可以) teacher_name${__RandomString(1,赵钱孙李周吴郑王冯陈褚卫蒋沈…

Python指定函数参数和返回值的类型

先看一个简单的示例: # name指定为str类型,返回值为str类型 def greeting(name: str) -> str:return hello: nameif __name__ __main__:print(函数参数类型、返回值类型基本使用)s greeting(张三)print(s)try:s greeting(123) # 可以传递其他类…

学习网页设计html个人总结

学习网页设计html个人总结篇一 我在网上进行的逻辑教学工作已经完成了,闲暇无事之余,便想将个人的主页——《思东书屋》重新进行一下规划和设计,为此购买了几本有关网页设计和制作的书籍,开始学习网页的基本语言HTML。尽管网页制作…

postgresql 数据库 索引 介绍

postgresql 数据库 索引 介绍 文章目录 postgresql 数据库 索引 介绍前言一 什么是索引?二 简介三 索引的种类B-treeHash索引GiST索引GIN 索引BRIN 索引SP-GiST索引 CREATE INDEX1.大纲2.描述3. 参数UNIQUECONCURRENTLYIF NOT EXISTSINCLUDEnameONLYmethodcolumn_na…

Mysql之账号管理、建库以及四大引擎详解

目录 一、MySql数据库引擎 1.1 什么是数据库引擎? 1.2 MySQL常见数据库引擎 1.2.1.InnoDB(MySQL默认引擎) 1.2.2.MyISAM 1.2.3.MEMORY(Heap) 1.3 存储引擎查看 二、建库 2.1.默认数据库介绍 2.2.建库 2.3.查看数据库 2.4.删除数…

【嵌入式Qt开发入门】如何使用Qt进行文本读写——QFile读写文本

在很多时候我们需要读写文本文件进行读写,比如写个 Mp3 音乐播放器需要读 Mp3 歌词里的文本,比如修改了一个 txt 文件后保存,就需要对这个文件进行读写操作。本文介绍简单的文本文件读写,内容精简,让大家了解文本读写的…