memcache作为一款优秀的进程外缓存,常常被运用于高并发系统架构中。这里主要谈谈怎么通过telnet工具,查看memcache运行状况并对其key进行管理维护。假设memcache安装目录:/usr/local/memcached
1、启动memcache
[root@localhost ~]# /usr/local/memcached/bin/memcached -d -m -u root -l 192.168.119.70 -p -c -P /usr/local/memcached/memcached.pid
启动参数详解
-d:以守护进程方式启动。如果该参数没有指定,当按ctrl+c命令结束,memcache自动关闭
-m:分配给memcache使用的最大内存数 单位是m,默认是64m
-u: 指定运行memcache的用户
-l: 指定监听的ip地址
-p: 指定监听的tcp端口号,可以通过-u指定udp端口.默认是11211
-c: 最大并发连接数
-P: 报错进程id的文件
memcache 启动之后,我们就可以通过telnet连接memcache,对其进行简单操作管理。
2、telnet连接memcache
[root@localhost ~]# telnet 192.168.119.70
Trying 192.168.119.70...
Connected to 192.168.119.70 (192.168.119.70).
Escape character is '^]'.
连接成功之后,即可对memcache进行操作管理了,常用的命令有:
Ⅰ、添加修改
命令格式:<command> <key> <flags> <exptime> <bytes>\r\n<data block>\r\n
<command>:add, set或 replace
<key> :缓存的名字
<flag>:16位无符号整数,和key要存储的数据一起存储,并在程序get缓存时,返回。
<exptime>:过去时间,0 表示永远不过期,如果非零,表示unix时间或距此秒数
<bytes>:存储数据的字节数
\r\n: 表示换行回车
命令结果:
STORED :表示成功
NOT_STORED : 表示失败
a)、添加缓存
add id STORED
如果key已经存在,则会添加失败。
b)、修改缓存
replace id STORED
key存在时,成功;不存在时,失败。
c)、设置缓存
set id STORED
key不存在时,添加【add】;已存在时,替换【replace】。
Ⅱ、读取
命令格式:get <key>+\r\n
<key>+:表示一个或多个key,多个key时,用空格隔开
a)、读取单个key的缓存
get id
VALUE id END
b)、读取多个key的缓存
Ⅲ、删除
命令格式:delete <key> \r\n
<key>:要删除的key
删除id
delete id
DELETED
Ⅳ、清空所有缓存
命令格式:flush_all
flush_all
OK
Ⅴ、查看缓存服务器状态
命令:stats
stats
STAT pid //进程id
STAT uptime //总的运行时间,单位描述
STAT time //当前时间
STAT version 1.4. //版本
STAT pointer_size //服务器指针位数,一般32位操作系统是32
STAT rusage_user 0.002999 //进程的累计用户时间
STAT rusage_system 1.277805 //进程的累计系统事件
STAT curr_connections //当前连接数
STAT total_connections //服务器启动后,总连接数
STAT connection_structures //连接结构的数量
STAT cmd_get //总获取次数
STAT cmd_set //总写入次数
STAT cmd_flush //总的的清空次数
STAT get_hits //总的命中次数
STAT get_misses //获取没有命中次数
STAT delete_misses //删除没有命中次数
STAT delete_hits //删除命中次数
STAT incr_misses //递增操作没有命中次数
STAT incr_hits //递增操作命中次数
STAT decr_misses //递减操作没有命中的次数
STAT decr_hits //递减操作命中的次数
STAT cas_misses //cas设置没有命中次数
STAT cas_hits //cas命中次数
STAT cas_badval //cas操作找到key,但版本过期,没有设置成功
STAT bytes_read //总共获取数据量
STAT bytes_written //总共写入数据量
STAT limit_maxbytes //最大允许使用内存,单位字节
STAT accepting_conns
STAT listen_disabled_num
STAT threads //当前线程数
STAT conn_yields
STAT bytes //已用缓存空间
STAT curr_items //当前缓存的keyvalue数
STAT total_items //总共缓存的keyvalue数,包括过期删除的
STAT evictions //通过删除keyvalue,释放内存次数
END
Ⅵ、打印版本
命令:version
version
VERSION 1.4.
Ⅶ、打印内存信息
命令:stats slabs
stats slabs
STAT :chunk_size
STAT :chunks_per_page
STAT :total_pages
STAT :total_chunks
STAT :used_chunks
STAT :free_chunks
STAT :free_chunks_end
STAT :get_hits
STAT :cmd_set
STAT :delete_hits
STAT :incr_hits
STAT :decr_hits
STAT :cas_hits
STAT :cas_badval
STAT active_slabs
STAT total_malloced
END
3、退出telnet
quit