百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

企业级redis生产环境实战(5)主从复制及安全设置(图文教程)

nanshan 2024-10-15 11:28 17 浏览 0 评论

redis主从复制及安全设置

环境介绍

主机信息

环境配置

系统版本

CentOS release 6.5 (Final)

其他设置

关闭防火墙、关闭selinux

redis主从复制简介

一个master可以有多个slave

一个slave还可以再有slave,所以支持链式复制

Master以非阻塞方式同步数据至salve,master可以同时处理多个slave的操作

redis主从复制实战

1、分别将"redis3.2.0"和"tcl8.6.1"拷贝到两台从库服务器

注:之所以能这样拷贝过来,是因为redis安装不需要什么依赖!另外,"tcl8.6.1"之前在编译安装redis的时候报错,需要安装tcl,所以一并拷贝过去

192.168.139.72主机

scp -r /usr/local/redis-3.2.0/ root@192.168.139.72:/usr/local/

scp -r /usr/local/tcl8.6.1/ root@192.168.139.72:/usr/local/

192.168.139.73主机

scp -r /usr/local/redis-3.2.0/ root@192.168.139.73:/usr/local/

scp -r /usr/local/tcl8.6.1/ root@192.168.139.73:/usr/local/

2、在两台从库服务器上分别创建redis日志文件和redis目录

mkdir -p /var/log/redis

touch redis.conf

mkdir -p /data/redis

3、分别修改两台从库的配置文件

vim /usr/local/redis-3.2.0/conf/redis.conf

修改内容如下:

bind 192.168.139.72

bind 192.168.139.73

4、分别启动两台从库

cd /usr/local/redis-3.2.0/bin/

./redis-server ../conf/redis.conf

5、查看从库是否启动

ps aux | grep redis

6、查看redis未进行主从复制前状态

192.138.139.71主机

./redis-cli -h 192.168.139.71 -a 123 -p 6379

info replication

192.138.139.72主机

./redis-cli -h 192.168.139.72 -a 123 -p 6379

info replication

192.138.139.73主机

./redis-cli -h 192.168.139.73 -a 123 -p 6379

info replication

注:默认情况下单个redis,角色都为master

7、在从库配置主从复制参数(两台改动一样)

cd /usr/local/redis-3.2.0/conf

vim redis.conf

修改如下信息:

slaveof <masterip> <masterport>

masterauth <master-password> #如果redis主库不设置密码,这里可以不需要改动

修改成:

slaveof 192.168.139.71 6379

masterauth 123

8、重启两台redis从库

192.138.139.72主机

ps aux | grep redis

kill -9 24661

./redis-server ../conf/redis.conf

ps aux | grep redis

重启完成!

192.138.139.73主机

ps aux | grep redis

kill -9 24584

./redis-server ../conf/redis.conf

ps aux | grep redis

重启完成!

9、在redis主库上查看主从同步信息

./redis-cli -h 192.168.139.71 -a 123 -p 6379

info replication

这时候可以看到redis的从库信息了!

10、验证主从复制是否成功

切换到0号库,设置一个key为:"ceshi";键值为:"123"的值

SELECT 0

set ceshi 123

分别登陆两个从库,看是否能看到这个值

从库192.168.139.72

get ceshi

从库192.168.139.73

get ceshi

至此redis的主从复制已经配置成功了!

在不重启服务器的情况下增加从库

这一步只需要在从库上执行,事实上redis的主从复制都是在从库上配置的!

在重新开启一台服务器(192.168.139.74),拷贝"redis3.2.0"和"tcl8.6.1"到该服务器上,并进行如下配置:

1、拷贝文件到新启动的服务器上

scp -r /usr/local/redis-3.2.0/ root@192.168.139.74:/usr/local/

scp -r /usr/local/tcl8.6.1/ root@192.168.139.74:/usr/local/

2、在两台从库服务器上分别创建redis日志文件和redis目录

mkdir -p /var/log/redis

touch redis.conf

mkdir -p /data/redis

3、分别修改从库的配置文件

修改配置文件:

cd /usr/local/redis-3.2.0/conf

vim redis.conf

修改如下信息:

bind 192.168.139.71

masterauth <master-password>

修改成:

bind 192.168.139.74

masterauth 123

4、启动从库

./redis-server ../conf/redis.conf

5、登陆主库查看主从复制信息

./redis-cli -h 192.168.139.71 -a 123 -p 6379

info replication

并未看到"192.168.139.74"的信息

6、登陆从库192.168.139.74

cd /usr/local/redis-3.2.0/bin

./redis-cli -h 192.168.139.74 -a 123 -p 6379

输入:

SLAVEOF 192.168.139.71 6379

7、再次到主库上查看主从复制信息

info replication

这时,可以看到新增从库192.168.139.74的信息!

注:该配置只是临时生效,重启计算机或是重启redis后,配置就消失了!

8、验证一下

重启服务器192.168.139.74

cd /usr/local/redis-3.2.0/bin/

./redis-server ../conf/redis.conf

ps aux | grep redis

在主库上查看redis从库信息,从库消失!

redis的安全设置

修改配置文件

vim /usr/local/redis-3.2.0/conf/redis.conf

1、设置监听ip,禁止外网访问redis

bind 127.0.0.1 2.2.2.2 #可以是多个ip,用空格分隔

2、设置监听端口

port 16000

3、设置密码

requirepass 123

4、以低权限运行 Redis 服务

为 Redis 服务创建单独的用户和家目录,并且配置禁止登陆

5、禁止或修改(改别名)一些高危命令

rename-command FLUSHALL ""

rename-command CONFIG ""

rename-command EVAL ""

注:双引号中不输入任何内容是禁用该命令,如果要使用别名则在双引号中输入别名如:rename-command FLUSHALL "aaa",那么"FLUSHALL"就变为"aaa"了。

在redis.conf最后加入要禁用的命令,如下图所示:

接着重启redis

ps aux | grep redis

kill -9 2214

cd /usr/local/redis-3.2.0/bin

./redis-server ../conf/redis.conf

注:这里会报错"Unknown command 'flushall' reading the append only file",如下图所示(查看日志命令:tailf /var/log/redis/redis.conf)

根据报错提示,将之前的"appendonly yes"改为"appendonly no",如下图所示:

接着重启redis成功!

登陆redis

./redis-cli -h 192.168.139.71 -p 6379 -a 123

使用flushall命令

这里可以看到flushall命令已经被禁用了!

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: