背景:生产上一台redis服务器,物理内存32G,几个项目都在用,经常不足一月内存就会耗尽,然后开始使用swap,当swap也用尽的时候,系统就宕机.redis配置也优化过几次,但未见成效.因此决定看看redis里存放数据占用内存大小,看看有没有异常数据. 一.安装redis-rdb-tools工具 # wget https://github.com/sripathikrishnan/redis-rdb-tools/archive/master.zip# unzip master# cd red
shell-100主要是用于练习! #!/bin/bash # 统计内存的使用量(这里用ps统计) # 第一步:不打印第一行,这里的sed ‘1d’ 去掉 for n in `ps aux |sed '1d'` # 第二步:获取内存那一列的数值 # 第三步:最后用循环相加! sum= for n in `ps aux |sed '1d'|awk '{print $6}'` do sum=$[$sum+$n] done # 知识点:for循环,sum的函数相加!比如1-100的相加 # 简单的
抄自http://www.infoq.com/cn/articles/tq-redis-memory-usage-optimization-storage 本文将对Redis的常见数据类型的使用场景以及在内存优化方面和性能优化方面做一些详细的分析. Redis常用数据类型 Redis最为常用的数据类型主要有以下五种: String Hash List Set Sorted set 在具体描述这几种数据类型之前,我们先通过一张图了解下Redis内部内存管理中是如何描述这些不同数据类型的: 首先Re
Redis常用数据类型 Redis最为常用的数据类型主要有以下五种: String Hash List Set Sorted set 在具体描述这几种数据类型之前,我们先通过一张图了解下Redis内部内存管理中是如何描述这些不同数据类型的: 首先Redis内部使用一个redisObject对象来表示所有的key和value,redisObject最主要的信息如上图所示:type 代表一个value对象具体是何种数据类型,encoding是不同数据类型在redis内部的存储方式,比如:type=s