`
Jony.Hwong
  • 浏览: 116691 次
  • 来自: ...
社区版块
存档分类
最新评论

memcache及其telnet命令使用详解

阅读更多


1、启动Memcache 常用参数
memcached 1.4.3
-p <num>      设置端口号(默认不设置为: 11211)
-U <num>      UDP监听端口 (默认: 11211, 0 时关闭)  
-l <ip_addr>  绑定地址 (默认:所有都允许,无论内外网或者本机更换IP,有安全隐患,若设置为127.0.0.1就只能本机访问)
-d            独立进程运行
-u <username> 绑定使用指定用于运行进程 <username>
-m <num>      允许最大内存用量,单位M (默认: 64 MB)
-P <file>     将PID写入文件<file>,这样可以使得后边进行快速进程终止, 需要与 -d 一起使用
如:
在linux下:./usr/local/bin/memcached -d -u jb-mc -l 192.168.1.197 -m 2048 -p 12121
在window下:d:\App_Serv\memcached\memcached.exe -d RunService -l 127.0.0.1 -p 11211 -m 500
在windows下注册为服务后运行:
sc.exe create jb-Memcached binpath= “d:\App_Serv\memcached\memcached.exe -d RunService -p 11211 -m 500″ start= auto
net start jb-Memcached

2、telnet连接

telnet 127.0.0.1 11211

3、写入memcache

3.1 memcached Telnet Interface

Command Description Example
get Reads a value get mykey
set Set a key unconditionally set mykey 0 60 5
add Add a new key add newkey 0 60 5
replace Overwrite existing key replace key 0 60 5
append Append data to existing key append key 0 60 15
prepend Prepend data to existing key prepend key 0 60 15
incr Increments numerical key value by given number incr mykey 2
decr Decrements numerical key value by given number decr mykey 5
delete Deletes an existing key delete mykey
flush_all Invalidate specific items immediately flush_all
Invalidate all items in n seconds flush_all 900
stats Prints general statistics stats
Prints memory statistics stats slabs
Prints memory statistics stats malloc
Print higher level allocation statistics stats items
  stats detail
  stats sizes
Resets statistics stats reset
version Prints server version. version
verbosity Increases log level verbosity
quit Terminate telnet session quit


3.2 telnet请求命令格式

<command name> <key> <flags> <exptime> <bytes>\r\n <data block>\r\n
a) <command name> 可以是”set”, “add”, “replace”
“set”表示按照相应的<key>存储该数据,没有的时候增加,有的覆盖。
“add”表示按照相应的<key>添加该数据,但是如果该<key>已经存在则会操作失败。
“replace”表示按照相应的<key>替换数据,但是如果该<key>不存在则操作失败

b) <key> 客户端需要保存数据的key。

c) <flags> 是一个16位的无符号的整数(以十进制的方式表示)。
该标志将和需要存储的数据一起存储,并在客户端get数据时返回。
客户可以将此标志用做特殊用途,此标志对服务器来说是不透明的。

d) <exptime> 过期的时间。
若为0表示存储的数据永远不过时(但可被服务器算法:LRU 等替换)。
如果非0(unix时间或者距离此时的秒数),当过期后,服务器可以保证用户得不到该数据(以服务器时间为标准)。

e) <bytes> 需要存储的字节数(不包含最后的”\r\n”),当用户希望存储空数据时,<bytes>可以为0

f) 最后客户端需要加上”\r\n”作为”命令头”的结束标志。
<data block>\r\n

紧接着”命令头”结束之后就要发送数据块(即希望存储的数据内容),最后加上”\r\n”作为此次通讯的结束。

3.3 telnet响应命令

结果响应:reply
当以上数据发送结束之后,服务器将返回一个应答。可能有如下的情况:

a) “STORED\r\n”:表示存储成功
b) “NOT_STORED\r\n” : 表示存储失败,但是该失败不是由于错误。
通常这是由于”add”或者”replace”命令本身的要求所引起的,或者该项在删除队列之中。

如: set key 33 0 4\r\n
ffff\r\n

4、获取/检查KeyValue
get <key>*\r\n
a) <key>* 表示一个或者多个key(以空格分开)
b) “\r\n” 命令头的结束

结果响应:reply
服务器端将返回0个或者多个的数据项。每个数据项都是由一个文本行和一个数据块组成。当所有的数据项都接收完毕将收到”END\r\n”
每一项的数据结构:
VALUE <key> <flags> <bytes>\r\n
<data block>\r\n

a) <key> 希望得到存储数据的key
b) <falg> 发送set命令时设置的标志项
c) <bytes> 发送数据块的长度(不包含”\r\n”)
d) “\r\n” 文本行的结束标志
e) <data block> 希望接收的数据项。
f) “\r\n” 接收一个数据项的结束标志。

如果有些key出现在get命令行中但是没有返回相应的数据,这意味着服务器中不存在这些项,这些项过时了,或者被删除了
如:get aa
VALUE aa 33 4
ffff
END

5、删除KeyValue:
delete <key> <time>\r\n

a) <key> 需要被删除数据的key
b) <time> 客户端希望服务器将该数据删除的时间(unix时间或者从现在开始的秒数)
c) “\r\n” 命令头的结束

6、检查Memcache服务器状态:
stats\r\n
在这里可以看到memcache的获取次数,当前连接数,写入次数,已经命中率等;

pid : 进程id
uptime :总的运行时间,秒数
time : 当前时间
version : 版本号
……
curr_items : 当前缓存中的KeyValue数量
total_items : 曾经总共经过缓存的KeyValue数量
bytes : 所有的缓存使用的内存量
curr_connections 当前连接数
….
cmd_get : 总获取次数
cmd_set : 总的写入次数
get_hits : 总的命中次数
miss_hits :  获取失败次数
…..
bytes_read : 总共读取的流量字节数
bytes_written : 总的写入流量字节
limit_maxbytes : 最大允许使用的内存量,字节

7、高级缓存细节查看方法:
stats reset
清空统计数据

stats malloc
显示内存分配数据

stats cachedump slab_id limit_num
显示某个slab中的前limit_num个key列表,显示格式如下
ITEM key_name [ value_length b; expire_time|access_time s]
其中,memcached 1.2.2及以前版本显示的是  访问时间(timestamp)
1.2.4以上版本,包括1.2.4显示 过期时间(timestamp)
如果是永不过期的key,expire_time会显示为服务器启动的时间

stats cachedump 7 2
ITEM copy_test1 [250 b; 1207795754 s]
ITEM copy_test [248 b; 1207793649 s]

stats slabs
显示各个slab的信息,包括chunk的大小、数目、使用情况等

stats items
显示各个slab中item的数目和最老item的年龄(最后一次访问距离现在的秒数)

stats detail [on|off|dump]
设置或者显示详细操作记录

参数为on,打开详细操作记录
参数为off,关闭详细操作记录
参数为dump,显示详细操作记录(每一个键值get、set、hit、del的次数)

8、清空所有键值
flush_all
注:flush并不会将items删除,只是将所有的items标记为expired,因此这时memcache依旧占用所有内存。

8、退出
quit\r\n

 

 

分享到:
评论

相关推荐

    memcache安装与基本操作详解

    ### Memcache安装与基本操作详解 #### 一、前言 Memcache是一种高性能的分布式内存对象缓存系统,用于加速动态Web应用,减轻数据库负担。本文将详细介绍如何安装配置Memcache,并提供基本的操作示例。 #### 二、...

    在telnet下操作memcache详解(操作命令详解)

    首先,要连接到Memcache服务器,可以使用telnet命令。例如,如果你的Memcache服务运行在本地主机的11211端口,可以输入以下命令: ```bash telnet 127.0.0.1 11211 ``` 一旦连接成功,你可以开始执行各种操作。 *...

    Memcache常用命令.docx

    ### Memcached 常用命令详解 #### 一、Memcached 安装与管理命令 在部署和管理 Memcached 服务时,以下是一些常用的命令选项: - **-p 监听的端口**:指定 Memcached 服务监听的端口。例如,`-p 11211` 表示 ...

    telnet连接操作memcache服务器详解

    要获取memcache服务器的状态信息,使用 `stats` 命令,这将返回包括进程ID、运行时间、当前时间、版本、指针大小、资源使用情况等统计信息: ```text stats ``` 以上就是通过telnet工具连接和管理memcache服务器的...

    MemCache服务器端和使用说明

    1. **命令行测试**:使用telnet命令行工具连接到MemCache服务器,进行简单的键值对操作。 2. **性能监控**:通过MemCache的统计接口,可以获取内存使用情况、命中率等性能指标。 3. **第三方工具**:使用像`mcstat`...

    memcache使用

    【Memcache使用详解】 Memcache是一款高性能的分布式内存对象缓存系统,主要用于减轻数据库的负载,通过将数据存储在内存中来快速响应读取请求。本文主要针对Windows环境下的Memcache安装与配置进行详述。 **一、...

    Memcache常用命令.pdf

    ### Memcached常用命令详解 #### 一、Memcached概述与基本命令 Memcached是一款高性能的分布式内存对象缓存系统,用于加速动态Web应用程序并减轻数据库负载。它通过在内存中缓存数据和对象来减少数据库访问频率,...

    详解memcache

    ### 详解memcache #### memcache概述 memcached是一个高性能的分布式的内存对象缓存系统,主要用于加速动态网页应用的响应速度。它通过在内存中维护一个巨大的hash表来存储各种格式的数据,如图像、视频、文件以及...

    memcache的安装步骤

    **Memcache 安装步骤详解** Memcache 是一个高性能的分布式内存对象缓存系统,它最初由 danga.com 开发,主要用于减轻数据库的负载压力,尤其是对于那些访问量巨大的网站。Memcache 可以在内存中创建哈希表,自管理...

    linux下的memcache-2.2.4

    5. **验证运行**:通过命令`ps aux | grep memcached`检查进程是否正常运行,或者使用`telnet`测试连接,例如`telnet localhost 11211`(默认端口)。 **三、使用Memcached** 1. **客户端接口**:Memcached提供了...

    memcache+tomcat集群说明手册

    5. **验证安装**:使用`telnet *.*.*.* 11211`验证memcache是否启动成功。 ##### 3.4 安装Tomcat 1. **登录系统**:使用`appuser`登录系统。 2. **解压安装包**:使用命令`tar –zxvf /app/soft/tomcat.tar.gz`解压...

    memcache安装文档

    **Memcached 安装详解** Memcached 是一款高性能、分布式内存对象缓存系统,用于临时存储数据,以减轻数据库的负担。它适用于多种环境,尤其是处理高并发读写操作的应用。在 Linux 系统中安装 Memcached 可以显著...

    memcache配置文档

    ### Memcache配置与部署详解 #### 一、引言 Memcache是一种高性能的分布式内存对象缓存系统,用于加速动态Web应用,减轻数据库负担。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高网站速度。本...

    memadmin--memcache客户端可视化管理软件

    与telnet和putty的对比,表明memadmin可能提供了更为直观和便捷的交互方式,适合那些不熟悉或者不喜欢使用命令行工具的用户。 **标签解析:** “memadmin”标签直接指出了软件的名字,“windows”标签则意味着该...

    memcache 笔记

    检查Memcached是否启动成功,可以使用`netstat -an`命令查看11211端口是否在监听。 4. **操作Memcached**:通过telnet工具可以进行CRUD(Create, Read, Update, Delete)操作: - **增加(Add)**:`add key 名 0 ...

    linux下安装配置Memcache和PHP环境的实现

    可以使用telnet或nc命令进行简单测试。 ```bash telnet localhost 11211 ``` #### 七、总结 通过以上步骤,我们已经成功在Linux环境下安装配置了Memcache和PHP环境。这不仅有助于提升Web应用的性能,还能优化...

Global site tag (gtag.js) - Google Analytics