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

redis主从搭建、发现阻塞、内存管理优化(四)

wptr33 2025-06-10 18:36 5 浏览

一、redis主从搭建

1、下载安装指定版本redis

$ cd /opt/web_app
$ mkdir esheng
$ cd esheng
$ wget http://download.redis.io/releases/redis-3.0.7.tar.gz  ##下载指定版本redis
$ tar -zxvf redis-3.0.7.tar.gz
$ ln -s redis-3.0.7 redis; ##建立软连接
$ cd ./redis/
$ make ##安装redis,安装完执行将在./redis/src目录下,新增redis-cli、redis-server、redis-sentinel等命令。
$ make install ##致使此版本命令添加到linux的环境变量,例如redis-cli 与 redis-server在任何目录均可执行。
注:环境变量只能配置一个版本的,其他redis版本不行,需要用本版本绝对路径执行相关命令。

2、配置启动主节点

1、修改redis.conf配置文件

$ vi redis/redis.conf
$ daemonize yes
$ port 7000
$ requirepass password ##当前服务密码
$ logfile "redis7000.log"
$ dbfilename dump-redis7000.rdb
$ dir ./ ##日志,以及持久化数据路径可不修改

2、启动主节点

$ redis-server redis.conf
##验证是否启动成功
$ redis-cli -p 7000 -a kcpt ping
PONG

3、配置启动从节点

1、修改redis.conf配置文件

$ vi redis/redis.conf
$ daemonize yes
$ port 7000
$ requirepass password ##当前服务密码
$ masterauth password ##主节点密码
$ slaveof 172.17.47.176 7000
$ logfile "redis7000.log"
$ dbfilename dump-redis7000.rdb
$ dir ./ ##日志,以及持久化数据路径可不修改

2、启动从节点

$ redis-server redis.conf
##验证是否启动成功
$ redis-cli -p 7000 -a kcpt ping
PONG

4、确认主从关系

1、主节点视角

$ redis-cli -p 7000 -a kcpt info replication
# Replication
role:master
connected_slaves:1
slave0:ip=172.17.47.177,port=7000,state=online,offset=255,lag=0
...

2、从节点视角

$ redis-cli -p 7000 -a kcpt info replication
# Replication
role:slave
master_host:172.17.47.176
master_port:7000
master_link_status:up
...


二、redis噩梦、阻塞

1、发现阻塞

内在阻塞原因:不合理使用API或数据结构,CPU饱和,持久化阻塞。

外在阻塞原因:CPU竞争,内存交换。网络问题

检测:通过java的logback或者log4j检测redis阻塞异常,如果redis集群,需要打印出redis的ip与端口。

2、内在原因

1、API使用不合理:尽量不使用时间复杂度O(n)的命令,例如:getall 、hgetall

发现慢查询:slowlog get n 获取最近n条慢查询命令,修复低时间复杂度命令,如getall改为hmget ,禁止keys、sort命令。大对象数据分解为小对象。

发现大对象:redis-cli --bigkeys 把历史扫描过的最大对象统计出来。

2、cpu饱和

top:查看cpu使用率,

redis-cli --stat:获取当前redis使用情况

info commandstats:分析命令执行耗时,查看不合理命令耗时

3、持久化阻塞

fork阻塞、AOF刷盘阻塞、HugePage写操作阻塞。


三、内存管理优化

1、内存消耗

1、内存使用统计:info memory

·

2、内存管理

redis主要通过控制内存上限与回收策略实现内存管理。

回收内存策略:删除到达过期时间的键对象,内存使用达到maxmemory上限时触发内存溢出控制策略。

控制内存溢出策略:默认策略,不删除任何数据,拒绝所有写入操作,并返回客户端错误信息,此时redis只响应读操作。

避免过频繁的内存回收策略

3、内存优化

redis存储的所有值对象在内部定义为redisObject结构体

缩减键值的长度:

key长度:user:userId 简化为 u:userId

value长度:把业务对象序列化为二进制数组放入redis,业务对象中去除无用字段。

共享对象池:value值为整数,同一个redisObject对应多个key引用

字符串优化:

编码优化:

控制键数量:根据建规模在客户端通过分组映射到一组hash对象中,hash的field作为记录原始key字符串。

相关推荐

Linux文件系统操作常用命令(linux文件内容操作命令)

在Linux系统中,有一些常用的文件系统操作命令,以下是这些命令的介绍和作用:#切换目录,其中./代表当前目录,../代表上一级目录cd#查看当前目录里的文件和文件夹ls#...

别小看tail 命令,它难倒了技术总监

我把自己以往的文章汇总成为了Github,欢迎各位大佬star...

lnav:基于 Linux 的高级控制台日志文件查看器

lnav是一款开源的控制台日志文件查看器,专为Linux和Unix-like系统设计。它通过自动检测日志文件的格式,提取时间戳、日志级别等关键信息,并将多个日志文件的内容按时间顺序合并显示,...

声明式与命令式代码(声明模式和命令模式)

编程范式中的术语和差异信不信由你,你可能已经以开发人员的身份使用了多种编程范例。因为没有什么比用编程理论招待朋友更有趣的了,所以这篇文章可以帮助您认识代码中的流行范例。命令式编程命令式编程是我们从As...

linux中的常用命令(linux常用命令和作用)

linux中的常用命令linux中的命令统称shell命令shell是一个命令行解释器,将用户命令解析为操作系统所能理解的指令,实现用户与操作系统的交互shell终端:我们平时输入命令,执行程序的那个...

提高工作效率的--Linux常用命令,能够决解95%以上的问题

点击上方关注,第一时间接受干货转发,点赞,收藏,不如一次关注评论区第一条注意查看回复:Linux命令获取linux常用命令大全pdf+Linux命令行大全pdf...

如何限制他人操作自己的电脑?(如何控制别人的电脑不让发现)

这段时间,小猪罗志祥正处于风口浪尖,具体是为啥?还不知道的小伙伴赶紧去补一下最近的娱乐圈八卦~简单来说,就是我们的小罗同事,以自己超强的体力,以及超强的时间管理能力,重新定义了「多人运动」的含义,重新...

最通俗易懂的命令模式讲解(命令模式百科)

我们先不讲什么是命令模式,先通过一个场景来引出命令模式,看看命令模式能解决什么样的问题。现在有一个渣男张三,他有还几个女朋友,你现在是不是还是单身狗,你就说你气不气?然后他需要每天分别叫几个女朋友起床...

互联网大厂后端必看!Spring Boot 中Runtime执行与停止命令?

你是否曾在使用SpringBoot开发项目时,遇到需要执行系统命令的场景?比如调用脚本进行文件处理,又或是启动外部程序?很多后端开发人员会使用Processexec=Runtime.get...

Linux 常用命令(linux常用的20个命令面试)

日志排查类操作命令...

Java字节码指令:if_icmpgt(0xA3)(java字节码使用的汇编语言)

if_icmpgt是Java字节码中的一条条件跳转指令,其全称是"IfIntegerCompareGreaterThan"。它用于比较两个整数值的大小。如果栈顶的第一个...

外贸干货|如何增加领英的曝光量和询盘

#跨境电商#...

golang执行linux命令(golang调用shell脚本)

需求需要通过openssl生成rsa秘钥,然后保存该秘钥。代码实例packagemainimport("io/ioutil""bytes"&...

LINUX磁盘挂载(linux磁盘挂载到windows)

1、使用root用户查看磁盘挂载情况:fdisk-l2、使用df查看当前磁盘挂载情况,根据和fdisk-l的结果进行对比,查看还有那些磁盘未使用3、挂载:mount磁盘挂载路径...

Linux命令学习——nl命令(linux ln命令的使用)

nl命令主要功能为每一个文件添加行号,每一个输入的文件添加行号后发送到标准输出。当没有文件或文件为-时,读取标准输入...