2024年最新Redis内存数据库主从复制、哨兵模式、集群部署等详细教程(更新中)

Centos 安装 Redis

检查安装 GCC 环境

[root@VM-4-17-centos ~]# gcc --version
gcc (GCC) 8.5.0 20210514 (Red Hat 8.5.0-4)
Copyright (C) 2018 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

防火墙操作

Firewall(防火墙)是一种网络安全设备或系统,其主要功能是根据预定的安全策略监视、过滤和控制传入和传出网络的流量,以保护一个网络区域免受来自另一个网络区域的网络攻击和网络入侵行为。

关闭防火墙 systemctl stop firewalld.service
查看防火墙状态 firewall-cmd --state
卸载防火墙 remove firewall

使用 yum 安装 GCC 环境

GCC 是由 GNU(GNU’s Not Unix)组织开发的编程语言编译器集合,最初代表 “GNU C Compiler”,主要支持C语言。随着发展,GCC扩展了对其他编程语言的支持,包括 C++、Fortran、Java、Ada、Pascal、Go 和 D 语言等,并重新定义为 “GNU Compiler Collection”。

yum install gcc

创建 redis 安装目录

mkdir -p /opt/software/redis
cd /opt/software/redis

使用 wget 下载 redis 软件包

wget 是一个在 Unix 和 Linux 系统中广泛使用的命令行工具,用于从网络上自动下载文件。它支持 HTTP、HTTPS 和 FTP 协议,并具备丰富的下载选项和高级功能,如断点续传、限速下载、递归下载等。

限制下载速度 wget --limit-rate=100k http://example.com/path/to/largefile.zip
断点续传 wget -c http://example.com/path/to/largefile.zip
下载并重命名文件 wget -O newname.zip http://example.com/path/to/file.zip

下载 redis 软件包

在这里插入图片描述

wget https://download.redis.io/redis-stable.tar.gz

解压安装 redis 软件包

tar -zxf redis-stable.tar.gz
cd redis-state
make install

make install 命令在 Linux 系统中是一个非常重要的命令,它通常用于将编译好的程序或库文件安装到系统的相应目录中。通过 ./configure、make 和 make install 三个步骤,用户可以自定义编译选项、编译源码,并将编译好的程序安装到系统中。

make install 命令会将编译好的可执行文件、库文件等复制到系统的标准目录下,如 /usr/local/bin(可执行文件)、/usr/local/lib(库文件)等。在某些情况下,make install 还会在适当的位置创建指向实际文件的符号链接,并在 /usr/local/etc 等目录下创建配置文件,以便用户进行配置。

Centos 配置启动 Redis

查看 redis 目录

[root@VM-4-17-centos redis-stable]# ll
total 296
-rw-rw-r--  1 lighthouse lighthouse   9854 Jul 29 13:31 00-RELEASENOTES
-rw-rw-r--  1 lighthouse lighthouse     51 Jul 29 13:31 BUGS
-rw-rw-r--  1 lighthouse lighthouse   5023 Jul 29 13:31 CODE_OF_CONDUCT.md
-rw-rw-r--  1 lighthouse lighthouse   7178 Jul 29 13:31 CONTRIBUTING.md
drwxrwxr-x  8 lighthouse lighthouse   4096 Sep 21 20:10 deps
-rw-r--r--  1 root       root          105 Sep 21 20:57 dump.rdb
-rw-rw-r--  1 lighthouse lighthouse     11 Jul 29 13:31 INSTALL
-rw-rw-r--  1 lighthouse lighthouse  37493 Jul 29 13:31 LICENSE.txt
-rw-rw-r--  1 lighthouse lighthouse    151 Jul 29 13:31 Makefile
-rw-rw-r--  1 lighthouse lighthouse   6888 Jul 29 13:31 MANIFESTO
-rw-rw-r--  1 lighthouse lighthouse  23845 Jul 29 13:31 README.md
-rw-rw-r--  1 lighthouse lighthouse 108982 Sep 21 20:55 redis.conf
-rw-rw-r--  1 lighthouse lighthouse   1805 Jul 29 13:31 REDISCONTRIBUTIONS.txt
-rwxrwxr-x  1 lighthouse lighthouse    279 Jul 29 13:31 runtest
-rwxrwxr-x  1 lighthouse lighthouse    283 Jul 29 13:31 runtest-cluster
-rwxrwxr-x  1 lighthouse lighthouse   1804 Jul 29 13:31 runtest-moduleapi
-rwxrwxr-x  1 lighthouse lighthouse    285 Jul 29 13:31 runtest-sentinel
-rw-rw-r--  1 lighthouse lighthouse   1480 Jul 29 13:31 SECURITY.md
-rw-rw-r--  1 lighthouse lighthouse  14700 Jul 29 13:31 sentinel.conf
drwxrwxr-x  4 lighthouse lighthouse  16384 Sep 21 20:13 src
drwxrwxr-x 11 lighthouse lighthouse   4096 Jul 29 13:31 tests
-rw-rw-r--  1 lighthouse lighthouse   3628 Jul 29 13:31 TLS.md
drwxrwxr-x  9 lighthouse lighthouse   4096 Jul 29 13:31 utils

启动 redis 服务器

在这里插入图片描述

redis.conf 配置文件

在这里插入图片描述
配置 redis (redis.conf 配置文件)通过 :i 进行编辑,通过 :wq 保存退出。

vim redis.conf 

常见配置信息

bind * -::* 										修改bind项,* -::* 支持远程连接
daemonize yes										开启守护进程,后台运行。
logfile /opt/software/redis/redis-stable/redis.log  指定日志文件目录
dir /opt/software/redis								指定工作目录。
requirepass huanxingshouwan							给默认用户设置密码,主要是使用 redis-cli 连接redis-server 时,需要通过密码连接数据库。
protected-mode no									允许远程连接。如果不设置密码必须讲此设置关闭。

通过 redis.conf 配置文件启动 redis 数据库(daemonize yes)

[root@VM-4-17-centos redis-stable]# redis-server redis.conf

连接测试

[root@VM-4-17-centos redis-stable]# redis-cli
127.0.0.1:6379> set name hello
OK
127.0.0.1:6379> get name
"hello"

关闭 redis 数据库服务

[root@VM-4-17-centos redis-stable]# redis-cli
127.0.0.1:6379> shutdown
not connected> 

查看 redis 运行日志

需要配置 logfile /opt/software/redis/redis-stable/redis.log 指定日志文件目录

在这里插入图片描述

配置 redis 工作目录(dump.rdb)

dir /opt/software/redis 指定工作目录

在这里插入图片描述

[root@VM-4-17-centos redis-stable]# cat redis.log
1863691:C 21 Sep 2024 21:09:36.282 * oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
1863691:C 21 Sep 2024 21:09:36.282 * Redis version=7.4.0, bits=64, commit=00000000, modified=1, pid=1863691, just started
1863691:C 21 Sep 2024 21:09:36.282 * Configuration loaded
1863691:M 21 Sep 2024 21:09:36.283 * monotonic clock: POSIX clock_gettime
1863691:M 21 Sep 2024 21:09:36.284 * Running mode=standalone, port=6379.
1863691:M 21 Sep 2024 21:09:36.284 * Server initialized
1863691:M 21 Sep 2024 21:09:36.284 * Loading RDB produced by version 7.4.0
1863691:M 21 Sep 2024 21:09:36.284 * RDB age 6 seconds
1863691:M 21 Sep 2024 21:09:36.284 * RDB memory usage when created 0.99 Mb
1863691:M 21 Sep 2024 21:09:36.284 * Done loading RDB, keys loaded: 1, keys expired: 0.
1863691:M 21 Sep 2024 21:09:36.284 * DB loaded from disk: 0.000 seconds
1863691:M 21 Sep 2024 21:09:36.284 * Ready to accept connections tcp

yum 软件包管理器

yum(全称 Yellowdog Updater, Modified)是一个在 Fedora、RedHat、CentOS 等基于 RPM 包管理系统的 Linux 发行版中广泛使用的 Shell 前端软件包管理器。简单来说 yum 是一个能够自动处理 RPM 软件包依赖关系,并从指定的服务器自动下载 RPM 包进行安装的软件包管理器。

yum 常用命令功能描述

功能命令描述
安装软件包yum install [软件包名]安装指定的软件包和其所有依赖项到系统中。
更新软件包yum update [软件包名]升级指定软件包到最新版本(如果不指定软件包名,则升级所有可更新的软件包)。
更新软件包yum upgrade [软件包名]类似于 update,但主要用于跨版本升级软件包(在某些发行版中可能与 update 命令有细微差别)。
删除软件包yum remove [软件包名]从系统中卸载指定的软件包。
删除软件包yum erase [软件包名]remove 命令相同,用于删除系统中的指定软件包。
查询软件包信息yum info [软件包名]显示指定软件包的详细信息,包括版本、描述、依赖关系等。
搜索软件包yum search [关键词]在可用的软件仓库中搜索包含指定关键词的软件包。
列出已安装的软件包yum list installed列出系统上当前已安装的所有软件包列表。
清理缓存yum clean [all / packages / headers / oldheaders]清理 yum 的缓存目录。all 表示清理所有缓存,packages 清理软件包缓存,headers 清理头文件缓存,oldheaders 清理旧的头文件缓存。

Redis 远程连接

redis-cli 连接远程 redis 服务器

要使用 redis-cli 连接到另一台服务器上的 Redis 实例,你需要指定远程服务器的 IP 地址、端口(如果使用了非默认端口),以及(可选地)密码(如果 Redis 实例配置了 requirepass)。

redis-cli -h <remote_server_ip> -p <port> -a <remote_server_requirepass>
root@hcss-ecs-c6d0:~# redis-cli -h xxx.xxx.xxx.xxx -p 6379
xxx.xxx.xxx.xxx:6379> set name hello
(error) NOAUTH Authentication required.

常见问题

root@hcss-ecs-c6d0:~# redis-cli -h xxx.xxx.xxx.xxx -p 6379 -a edgehacker
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
xxx.xxx.xxx.xxx:6379> set name hello
OK

当你看到警告 Warning: Using a password with ‘-a’ or ‘-u’ option on the command line interface may not be safe. 时,这意味着在命令行中直接使用 -a 选项来传递密码可能不是一个安全的做法,因为这样做可能会使密码在进程列表、shell 历史或其他地方以明文形式可见,从而增加被未授权访问的风险。

root@hcss-ecs-c6d0:~# redis-cli -h xxx.xxx.xxx.xxx -p 6379 -a huanxingshouwan
xxx.xxx.xxx.xxx:6379> AUTH huanxingshouwan

Redis 主从复制部署

主从复制是指将一台 Redis 服务器的数据,复制到其他的 Redis 服务器。前者称为主节点(Master),后者称为从节点(Slave)。数据的复制是单向的,只能由主节点到从节点。默认情况下,每台 Redis 服务器都是主节点,且一个主节点可以有多个从节点(或没有从节点),但一个从节点只能有一个主节点。
在这里插入图片描述

主从复制作用

数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式。

故障恢复:当主节点出现问题时,可以由从节点提供服务,实现快速的故障恢复。实际上是一种服务的冗余。

负载均衡:在主从复制的基础上,配合读写分离,可以由主节点提供写服务,由从节点提供读服务(即写 Redis 数据时应用连接主节点,读 Redis 数据时应用连接从节点),分担服务器负载。尤其是在写少读多的场景下,通过多个从节点分担读负载,可以大提高 Redis 服务器的并发量。

高可用基石:除了上述作用以外,主从复制还是哨兵和集群能够实施的基础,因此说主从复制是 Redis 高可用的基础。

配置主从复制部署

主节点 redis 数据库配置不需要做任何改变,从节点 redis 数据库都需要修改配置加上主节点信息,配置完成后,可以再主库检查从节点信息。

redis.conf 添加主节点信息

replicaof xxx.xxx.xxx.xxx 6379

配置密码 auth 主从复制部署

如果主 Redis 服务器配置了密码(也称为requirepass),则在从服务器上设置 slaveof 时,还需要配置 masterauth 指令来指定连接主服务器时使用的密码。这样,从服务器在尝试与主服务器建立连接并进行数据同步时,就会使用指定的密码进行身份验证。

# 指定主服务器的IP地址和端口号  
replicaof xxx.xxx.xxx.xxx 6379  # 指定连接主服务器时使用的密码  
masterauth huanxingshouwan

熟悉使用宝塔面板也可以通过 bt 面板快速设置

在这里插入图片描述
运行启动 redis-server 服务

运行 从节点 redis 服务器 info replication

127.0.0.1:6379> info replication
# Replication
role:slave
master_host:xxx.xxx.xxx.xxx
master_port:6379
master_link_status:down
master_last_io_seconds_ago:-1
master_sync_in_progress:0
slave_read_repl_offset:1
slave_repl_offset:1
master_link_down_since_seconds:-1
slave_priority:100
slave_read_only:1
replica_announced:1
connected_slaves:0
master_failover_state:no-failover
master_replid:6f509bbb151a1560121b4ee760ed2eef0116b5e7
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:0
second_repl_offset:-1
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0

这个错误信息 (error) READONLY You can’t write against a read only replica. 表示你正在尝试向一个设置为只读模式的 Redis 从服务器(replica)写入数据。在 Redis 的主从复制架构中,从服务器默认是只读的,以防止数据不一致的情况发生。

127.0.0.1:6379> set name hello
(error) READONLY You can't write against a read only replica.

运行 主节点 redis 服务器 info replication

常见问题

127.0.0.1:6379> info repulication
NOAUTH Authentication required.

解决方案

[root@VM-4-17-centos redis-stable]# redis-cli
127.0.0.1:6379> AUTH huanxingshouwan (requirepass 密码)
OK
127.0.0.1:6379> info replication
# Replication
role:master
connected_slaves:1
slave0:ip=xxx.xxx.xxx.xxx,port=6379,state=wait_bgsave,offset=0,lag=0
master_failover_state:no-failover
master_replid:93e8811d9d2b24a9b81cd9e423021144c333a61b
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:462
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:462

slaveof 和 replicaof 常见版本问题

slaveof 和 replicaof 在 Redis 数据库都用于配置主从复制关系。在 Redis 的早期版本中(Redis 5.0 之前),通常使用 slaveof 命令或配置选项来设置从服务器(slave)与主服务器(master)之间的复制关系。从 Redis 5.0 版本开始,slaveof 命令和配置选项被替换为 replicaof。这一变化旨在更准确地描述从服务器(replica)的角色,并避免和 “slave”(奴隶)这一可能带有负面含义的词汇相关联。

主从复制缺点

复制延时,信号衰减。由于所有的写操作都是现在主节点 master 上操作,然后同步更新到从节点 slave 上,所以从主节点 master 同步到从节点 slave 机器上有一定的延迟,当系统很繁忙的时候,延迟问题会更加严重,从节点 slave 机器数量的增加也会使这个问题更加严重。如果 master 挂了,默认情况下,不会在 slave 节点中自动重选一个主节点 master,并且每次都要人工干预。

Redis 哨兵模式部署

哨兵模式原理

Redis哨兵模式是通过在独立的哨兵节点上运行特定的哨兵进程来实现的。这些哨兵进程监控主从节点的状态,并在发现故障时自动完成故障发现和转移,并通知应用方,实现高可用性。

在这里插入图片描述

sentinel.conf 配置。

protected-mode no											关闭保护模式
daemonize yes												指定 sentinel 后台启动
logfile "/opt/software/redis/redis-stable/sentinel.log"		指定日志存放路径
dir /opt/software/redis										指定数据库存放路径
sentinel monitor mymaster xxx.xxx.xxx.xxx 6379 2			指定该哨兵节点监控主节点信息(配置2,就是2个哨兵发现问题就完成主节点转移,若配置1,就是1个哨兵发现问题就完成主节点转移)
sentinel down-after-milliseconds mymaster 30000				判定服务器 down 掉的时间周期,默认30000毫秒			
sentinel failover-timeout mymaster 180000					故障节点的最大超时时间为180000毫秒

启动哨兵服务

sentinel-server sentinel.conf

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

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

相关文章

深入理解前端拖拽:从基础实现到事件冒泡与委托的应用【面试真题】

在前端开发中&#xff0c;拖拽功能是一项常见的交互需求。通过监听鼠标或触摸事件&#xff0c;用户可以拖动元素并将其放置到指定位置。理解拖拽的底层实现、如何判断拖拽的是子元素还是父元素&#xff0c;以及事件冒泡和事件委托的原理&#xff0c;可以帮助我们更好地实现复杂…

mybatis 和 mybatis-plus

mybatis 配置 1.新建MAVEN项目 2.配置mybatis依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocatio…

嵌入式面试学习笔记(入门1)

目录 指针的大小问题 sizeof和strlen C语言分配内存的方式 数组&#xff08;的&#xff09;指针和指针&#xff08;的&#xff09;数组 union 指针的大小问题 指针对于不少新手而言是一道难关&#xff0c;但是不必恐惧于指针。他的本质其实就是一个地址。请冷静下来仔细思…

人工智能开发实战辅助诊断应用解析

内容导读 项目分析预备知识项目实战 一、项目分析 1、提出问题 随着人们生活水平的提升和健康意识的增强&#xff0c;民众定期进行身体健康体检已成为常态&#xff0c;这种早期的疾病检测和筛查可以及早发现身体里已经出现的异常体征信息&#xff0c;做出正确诊断和有效处理…

信息安全数学基础(15)欧拉定理

前言 欧拉定理是数论中的一个重要定理&#xff0c;它建立了模运算下指数与模的互质关系。这个定理在密码学、信息安全等领域有着广泛的应用&#xff0c;特别是在公钥密码体制&#xff08;如RSA加密算法&#xff09;中。 一、表述 设 n 是一个正整数&#xff0c;a 是一个与 n 互…

万字长文——ConvNeXt(2022CVPR),卷积网络的顶峰之作,在Transformer盛行的当下,卷积网络还能再战!

ConvNext:A ConvNet for the 2020s ConvNext:2020 年代的卷积神经网络 论文地址: https://arxiv.org/pdf/2201.03545 自从Transformer成功应用在视觉领域并且取得显著成绩后,很多人开始抛弃卷积网络架构,转而使用Transformer。然而有的大佬不认为卷积过时了,于是有了这篇…

Sigmoid引发的梯度消失爆炸及ReLU引起的神经元参数失效问题思考

Sigmoid和ReLU激活函数思考&#xff09; 引文Sigmoid函数梯度消失问题梯度爆炸问题解决方案 ReLU函数简化模型示例场景设定前向传播对反向传播的影响总结 内容精简版 引文 梯度消失和梯度爆炸是神经网络训练中常见的两个问题&#xff0c;特别是在使用Sigmoid激活函数时。这些问…

图形化编程012(变量-倒计时)

案例展示 点击绿旗&#xff0c;使用空格键控制鳐鱼&#xff0c;按下空格向上游&#xff0c;松开下落。 在舞台右侧会出现障碍物从右向左移动&#xff0c;移动到左侧边缘发出声音并隐藏。 鳐鱼碰到障碍停止全部脚本&#xff0c;坚持60秒程序结束。 一、逻辑思维 通过读题将大…

鸿蒙媒体开发系列09——OpenSL ES音频录制

如果你也对鸿蒙开发感兴趣&#xff0c;加入“Harmony自习室”吧&#xff01;扫描下方名片&#xff0c;关注公众号&#xff0c;公众号更新更快&#xff0c;同时也有更多学习资料和技术讨论群。 1、概述 OpenSL ES全称为Open Sound Library for Embedded Systems&#xff0c;是一…

【我的 PWN 学习手札】tcache extend

目录 前言 一、利用手法 二、流程演示 &#xff08;1&#xff09;三块物理相邻的堆块 &#xff08;2&#xff09;溢出修改 size &#xff08;3&#xff09;释放该 chunk &#xff08;4&#xff09;重新申请该 chunk &#xff08;5&#xff09;释放第三块 chunk&#x…

vcs/verdi常用命令(持续更新)

1. 操作rtl 1.1 加载rtl命令 verdi -dbdir simv.daidir的目录 1.2 显示某时刻rtl的值 首先鼠标左键在波形上选中某个特定时刻&#xff0c;然后鼠标选中rtl代码文件&#xff0c;按x就会显示&#xff0c;再按x就会退出显示。 1.3 查找字符串 按/ 1.4 vcs将rtl的信号加载到…

DNS是什么?怎么设置

NS是什么意思?有什么用呢?专业的说DNS就是域名系统 (Domain Name System)的简称&#xff0c;也就是IT人士常说的域名解析系统。主要是让用户在互联网上通过域名找到域名对应的IP地址&#xff0c;因为IP地址都是一串数字(例如&#xff1a;192.168.0.1)不方便记忆&#xff0c;便…

与 CESS Network 共探去中心化创新:重塑数据基础设施,驱动未来变革

随着互联网的快速发展和数据量的爆炸式增长&#xff0c;如何有效管理、存储和保护数据成为了一个日益重要的课题。传统的中心化平台&#xff0c;如 YouTube&#xff0c;虽然为用户提供了便捷的服务&#xff0c;但数据的所有权和控制权往往掌握在平台手中&#xff0c;用户的内容…

口腔检测系统源码分享

口腔检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vision …

Memory Controller Unit (MCU)内存控制器介绍

文章目录 Memory Controller Unit (MCU)内存控制器介绍1. MCU基本概念和功能地址映射读写操作缓存控制内存刷新1.1 地址映射1.2 读写操作1.3 缓存控制1.4 内存刷新 2. MCU的工作原理接收CPU的请求地址转换执行操作管理缓存 3. MCU的类型SDRAM控制器DDR控制器Flash控制器 4. MCU…

嵌入式 开发技巧和经验分享

文章目录 前言嵌入式 开发技巧和经验分享目录1.1嵌入式 系统的 定义1.2 嵌入式 操作系统的介绍1.3 嵌入式 开发环境1.4 编译工具链和优化1.5 嵌入式系统软件开发1.6 嵌入式SDK开发2.1选择移植的系统-FreeRtos2.2FreeRtos 移植步骤2.3 系统移植之中断处理2.4系统移植之内存管理2…

与姜妍同款冰箱,容声516WILL养鲜冰箱领“鲜”上市

9月20日&#xff0c;容声冰箱在“养鲜新净界”——2024年容声新品上市发布会上推出了WILL系列的最新力作——516WILL养鲜冰箱。 据「TMT星球」了解&#xff0c;此次新品搭载了升级版的WILL自然养鲜技术&#xff0c;并以60CM整机平嵌一体&#xff0c;完美融入现代家居美学&…

Mapper代理开发

目的 解决原生方式中的硬编码简化后期执行SQL 步骤 1&#xff0c; 整体目录结构 2&#xff0c; UserMapper.xml 设置SQL映射文件的namespace属性为Mapper接口全限定名 <?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE mapperPUBLIC &quo…

P9235 [蓝桥杯 2023 省 A] 网络稳定性

*原题链接* 最小瓶颈生成树题&#xff0c;和货车运输完全一样。 先简化题意&#xff0c; 次询问&#xff0c;每次给出 &#xff0c;问 到 的所有路径集合中&#xff0c;最小边权的最大值。 对于这种题可以用kruskal生成树来做&#xff0c;也可以用倍增来写&#xff0c;但不…