Redis swap空间(虚拟内存)的使用详解

 更新时间:2021年03月25日 11:33:45   作者:AsiaYe  
这篇文章主要介绍了Redis swap空间的使用示例,帮助大家更好的理解和学习使用Redis数据库,感兴趣的朋友可以了解下

   swap空间对于操作系统来说比较重要,当我们使用操作系统的时候,如果系统内存不足,常常会将一部分内存数据页进行swap操作,以解决临时的内存困境。swap空间由磁盘提供,对于高并发场景下,swap空间的使用会严重降低系统性能,因为它引入了磁盘IO操作。

   在Linux中,提供了free命令来查询操作系统的内存使用情况,free 命令的结果中也包含了swap相关的情况,例如下面的结果中:

[root@VM-0-14-centos ~]# free -ht
       total    used    free   shared buff/cache  available
Mem:      1.8G    1.3G     72M    692K    433M    283M
Swap:      0B     0B     0B
Total:     1.8G    1.3G     72M

我们可以看到swap的值都是0,说明当前的内存是没有配置swap空间的,目前的操作系统的内存是足够的,通常情况下swap一行的used列应该是0B比较好,它证明你的操作系统内存充足,没有发生swap空间的交换操作。

实时查看swap的使用

Linux中还为我们封装了vmstat这个命令来查看系统的相关性能指标,其中也包含swap空间,其中和swap有关的指标是si和so,分别代表swap in和swap out,我们看看vmstat的执行结果:

[root@VM-0-14-centos ~]# vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r b  swpd  free  buff cache  si  so  bi  bo  in  cs us sy id wa st
 4 0   0 73712 84464 362016  0  0   7  26  7  1 1 1 98 0 0

查看执行进程占用swap的情况

在Linux操作系统中,/proc/pid/smaps这个文件记录了当前进程所对应的内存映像信息,这个信息对于查询指定进程的swap使用情况很有帮助。下面以一个Redis实例进行说明:

[root@VM-0-14-centos ~]# ps -ef|grep redis  
root   1711   1 0 Jul20 ?    00:20:15 src/redis-server 127.0.0.1:21243
root   2370   1 0 Jul20 ?    00:20:18 src/redis-server 127.0.0.1:21244
root   2371   1 0 Jul20 ?    00:20:13 src/redis-server 127.0.0.1:21263
root   7815 5781 0 23:39 pts/3  00:00:00 grep --color=auto redis
root   14804   1 0 Jul20 ?    00:20:39 redis-server *:6379
我们以14804这个redis进程为例
[root@VM-0-14-centos ~]# cat /proc/14804/smaps | grep Swap
Swap:         0 kB
Swap:         0 kB
Swap:         0 kB
.....
Swap:         0 kB
Swap:         0 kB
Swap:         0 kB

通常情况下,Linux服务器不会等到所有物理内存都被使用完再使用swap空间,它引入swapiness这个变量来决定操作系统使用swap空间的倾向程度,它的取值是0~100,值越大,表示操作系统使用swap的可能性越高,反之则越低。swapiness变量值存在于系统配置文件/proc/sys/vm/swappiness 和/etc/sysctl.conf中,其前面的文件在重启之后,就失效了,只有将这个值写入后面的文件,才能长久的保存下去。

[root@VM-0-14-centos ~]# cat /proc/sys/vm/swappiness 
30

写入/etc/sysctl.conf的方法如下:

echo vm.swappiness={value} >> /etc/sysctl.conf

Redis在不同版本下,对于swapiness的建议配置也不一样,通常情况下,swapness的值可以设置为:0、1、60、100这几个。

其中:

设置为60是默认值,

设置为100则操作系统会主动使用swap空间,

设置成为0的话,在Linux3.4以及更早的Linux版本中,内存不够时,倾向使用swap而不是OOM killer,在Linux3.5以及之后的版本中,倾向使用OOM Killer而不是swap空间

设置为1的话,在Linux3.5以及后续版本中,内存不够用的时候,倾向于使用swap空间,而不是OOM Killer

多说一句:OOM kill是指Linux发现操作系统不可用的时候,也就是Out Of Memory的时候,强制杀死一些非内核进程,来保证有足够的可用内存进行分配。一般OOM的日志记录在系统日志/var/log/message中

以上就是Redis swap空间的使用示例的详细内容,更多关于Redis swap空间的资料请关注脚本之家其它相关文章!

相关文章

  • Redisson分布式限流器RRateLimiter的使用及原理小结

    Redisson分布式限流器RRateLimiter的使用及原理小结

    本文主要介绍了Redisson分布式限流器RRateLimiter的使用及原理小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • Redis list 类型学习笔记与总结

    Redis list 类型学习笔记与总结

    这篇文章主要介绍了Redis list 类型学习笔记与总结,本文着重讲解了关于List的一些常用方法,比如lpush 方法、lrange 方法、rpush 方法、linsert 方法、 lset 方法等,需要的朋友可以参考下
    2015-06-06
  • Redis分布式锁升级版RedLock及SpringBoot实现方法

    Redis分布式锁升级版RedLock及SpringBoot实现方法

    这篇文章主要介绍了Redis分布式锁升级版RedLock及SpringBoot实现,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Redis和Lua实现分布式限流器的方法详解

    Redis和Lua实现分布式限流器的方法详解

    这篇文章主要给大家介绍了关于Redis和Lua实现分布式限流器的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis和Lua具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • Redis三种集群搭建配置(主从集群、哨兵集群、分片集群)

    Redis三种集群搭建配置(主从集群、哨兵集群、分片集群)

    本文主要介绍了Redis三种集群搭建配置,包括主从集群、哨兵集群、分片集群,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • Redis 的过期策略与键的过期时间设置方法

    Redis 的过期策略与键的过期时间设置方法

    Redis通过惰性删除和定期删除策略管理内存,提供多种命令设置键的过期时间,并通过过期字典高效处理过期键,合理设置过期时间、监控过期键数量和避免大量键同时过期是最佳实践,本文介绍Redis 的过期策略与键的过期时间设置,感兴趣的朋友一起看看吧
    2025-03-03
  • 浅析Redis 切片集群的数据倾斜问题

    浅析Redis 切片集群的数据倾斜问题

    如果 Redis 中的部署,采用的是切片集群,数据是会按照一定的规则分散到不同的实例中保存,比如,使用 Redis Cluster 或 Codis,这篇文章主要介绍了Redis 切片集群的数据倾斜分析,需要的朋友可以参考下
    2022-06-06
  • 分布式架构Redis中有哪些数据结构及底层实现原理

    分布式架构Redis中有哪些数据结构及底层实现原理

    这篇文章主要为大家介绍了分布式架构Redis中有哪些数据结构及底层的实现原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03
  • Redis对象与redisObject超详细分析源码层

    Redis对象与redisObject超详细分析源码层

    这篇文章主要介绍了Redis对象与redisObject源码层的分析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-11-11
  • redis调用二维码时的不断刷新排查分析

    redis调用二维码时的不断刷新排查分析

    这篇文章主要为大家介绍了redis调用二维码时不断刷新排查分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-04-04

最新评论