Redis内存优化
一.Redis 手动清理Key
可以通过手动清理长时间不用的Key来减少Redis内存占用, 通过命令object idletime获取从上一次使用到现在间隔的时间. 但是如果很多Key共用同一个对象(如很多时候为了标识数据是否存在就会把value设置为1,实际上底层都是指向同一个对象),这时候多对key-value就会相互影响导致idletime返回时间不准确.
二.Redis 数据编码格式
为了节省空间,Redis会对Key做特殊编码
1.数据对象定义:
typedef struct redisObject {
unsigned type:4;
unsigned encoding:4;
unsigned lru:REDIS_LRU_BITS; /* lru time (relative to server.lruclock) */
int refcount;
void *ptr;
} robj;
2.基本数据类型:
\#define OBJ_STRING 0
\#define OBJ_LIST 1
\#define OBJ_SET 2
\#define OBJ_ZSET 3
\#define OBJ_HASH 4
3.编码格式:
/* Objects encoding. Some kind of objects like Strings and Hashes can be
* internally represented in multiple ways. The 'encoding' field of the object
* is set to one of this fields for this object. */
\#define OBJ_ENCODING_RAW 0 /* Raw representation */
\#define OBJ_ENCODING_INT 1 /* Encoded as integer */
\#define OBJ_ENCODING_HT 2 /* Encoded as hash table */
\#define OBJ_ENCODING_ZIPMAP 3 /* Encoded as zipmap */ // 已废弃
\#define OBJ_ENCODING_LINKEDLIST 4 /* Encoded as regular linked list */
\#define OBJ_ENCODING_ZIPLIST 5 /* Encoded as ziplist */
\#define OBJ_ENCODING_INTSET 6 /* Encoded as intset */
\#define OBJ_ENCODING_SKIPLIST 7 /* Encoded as skiplist */
\#define OBJ_ENCODING_EMBSTR 8 /* Embedded sds string encoding */
\#define OBJ_ENCODING_QUICKLIST 9 /* Encoded as linked list of ziplists */
4.数据类型和编码格式对照关系:
5.可以通过OBJECT ENCODING Key来看使用的编码格式;
Redis对象回收
1.Redis的内存回收主要是基于引用计数的回收机制.当程序不再使用某个对象的时候,这个对象所占用的内存就会被自动释放.
2.Redis通过共享对象的机制来减少内存的使用.
3.Redis对象带有访问时间记录信息,该信息可以用于计算数据库键的空转时间长,在服务器启用了maxmemory功能的情况下,空转时长较大的那些键可能会优先被数据库删除回收内存.