python获取redis memory使用情况场景分析

 更新时间:2022年12月21日 15:39:14   作者:kngines  
这篇文章主要介绍了python获取redis memory使用情况,项目研发过程中,用到Python操作Redis场景,记录学习过程中的心得体会,需要的朋友可以参考下

项目研发过程中,用到Python操作Redis场景,记录学习过程中的心得体会。

一、环境搭建

  • Windows + Anaconda3
  • 安装redis第3方包,pip install -u redis
    • pip install -u # 升级安装
  • linux下查看redis配置信息
bind 127.0.0.1	# 表示只允许本地访问,无法远程连接
bind 0.0.0.0    # 表示任何ip都可以访问

protected-mode yes # 保护模式,只允许本地链接
protected-mode no  # 保护模式关闭  

daemonize yes # 开启守护进程模式。单进程多线程模式,redis在后台运行。
daemonize no  # redis命令行界面,exit强制退出或关闭连接都会导致redis进程退出

配置示例

  • 查找redis.conf文件路径位置,find / -name 'redis.conf'
  • 查看redis.conf文件,vim redis.conf

在这里插入图片描述

二、代码实现

1、StrictRedis vs Redis

  • StrictRedis用于实现大部分官方的命令,并使用官方语法和命令;
  • Redis是StrictRedis的子类,用于向后兼容旧版本的redis-py;
  • 官方推荐使用StrictRedis方法。

2、 实验代码

import redis

r = redis.Redis(host='10.xx.xx.201', port=7019,decode_responses=True, password='********')
mmj = r.info('Memory')
# result / r.execute_command('info Memory')

used_memory = mmj.get('used_memory')
maxmemory = mmj.get('maxmemory')

used_memory_human = mmj.get('used_memory_human')
maxmemory_human = mmj.get('maxmemory_human')
left_mem_ratio = (maxmemory - used_memory)*1.0/maxmemory

在这里插入图片描述

三、redis info

Redis commands info 官方指南

1、memory

信息项解释
used_memory由Redis分配器分配的内存总量,包含redis进程内部的开销和数据占用的内存,以字节为单位
used_memory_human更直观展示分配的内存总量
used_memory_rss向os申请的内存大小。与 top 、 ps等命令的输出一致。
used_memory_rss_human更直观展示向os申请的内存大小。
used_memory_peakredis的内存消耗峰值(以字节为单位)
used_memory_peak_human更直观返回redis的内存消耗峰值
used_memory_peak_perc使用内存达到峰值内存的百分比,即(used_memory/ used_memory_peak) *100%
used_memory_overheadRedis为了维护数据集的内部机制所需的内存开销,包括所有客户端输出缓冲区、查询缓冲区、AOF重写缓冲区和主从复制的backlog。
used_memory_startupRedis服务器启动时消耗的内存
used_memory_dataset数据占用的内存大小,即used_memory-sed_memory_overhead
used_memory_dataset_perc数据占用的内存大小的百分比,100%*(used_memory_dataset/(used_memory-used_memory_startup))
total_system_memory整个系统内存
total_system_memory_human以更直观的格式显示整个系统内存
used_memory_luaLua脚本存储占用的内存
used_memory_lua_human以更直观的格式显示Lua脚本存储占用的内存
maxmemoryRedis实例的最大内存配置
maxmemory_human以更直观的格式显示Redis实例的最大内存配置
maxmemory_policy当达到maxmemory时的淘汰策略
mem_fragmentation_ratio碎片率,used_memory_rss/ used_memory
mem_allocator内存分配器
active_defrag_running表示没有活动的defrag任务正在运行,1表示有活动的defrag任务正在运行(defrag:表示内存碎片整理)
lazyfree_pending_objects0表示不存在延迟释放的挂起对象

到此这篇关于python获取redis memory使用情况的文章就介绍到这了,更多相关python redis memory使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python库sklearn常用操作

    python库sklearn常用操作

    sklearn是一个无论对于机器学习还是深度学习都必不可少的重要的库,里面包含了关于机器学习的几乎所有需要的功能,本文不会先整体介绍sklearn库,而是先从sklearn库中的一些具体实例入手,感兴趣的朋友一起看看吧
    2021-08-08
  • python检测服务器是否正常

    python检测服务器是否正常

    本文介绍使用python检测服务器是否正常,程序的端口是否正常,需要的朋友可以参考下
    2014-02-02
  • Python使用conda如何安装requirement.txt的扩展包

    Python使用conda如何安装requirement.txt的扩展包

    这篇文章主要介绍了Python使用conda如何安装requirement.txt的扩展包问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • 利用Python实现Json序列化库的方法步骤

    利用Python实现Json序列化库的方法步骤

    这篇文章主要给大家介绍了关于利用Python实现Json序列化库的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Python读取excel文件中带公式的值的实现

    Python读取excel文件中带公式的值的实现

    这篇文章主要介绍了Python读取excel文件中带公式的值的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Keras loss函数剖析

    Keras loss函数剖析

    这篇文章主要介绍了Keras loss函数剖析,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • python 多线程应用介绍

    python 多线程应用介绍

    python可以方便地支持多线程。可以快速创建线程、互斥锁、信号量等等元素,支持线程读写同步互斥
    2012-12-12
  • python递归法解决棋盘分割问题

    python递归法解决棋盘分割问题

    这篇文章主要为大家详细介绍了python递归法解决棋盘分割问题,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • 请不要重复犯我在学习Python和Linux系统上的错误

    请不要重复犯我在学习Python和Linux系统上的错误

    本人已经在运维行业工作了将近十年,我最早接触Linux是在大二的样子,那时候只追求易懂,所以就选择了Ubuntu作为学习、使用的对象,它简单、易用、好操作、界面绚丽,对于想接触Linux的新手来说是非常不错的
    2016-12-12
  • Python多进程机制实例详解

    Python多进程机制实例详解

    这篇文章主要介绍了Python多进程机制,以实例形式详细分析了Python多进程机制的原理与实现技巧,需要的朋友可以参考下
    2015-07-07

最新评论