`

【转】memcached命令行操作

阅读更多

 

最近都木有使用memcached的telnet操作,一些基本的用法都忘记了,本打算写出来做个备注,在google时发现已经有写的关于memcached的基本操作,就转过来了

 

memcached命令


comments 类型


1. storage commands: set add replace

2. retrieval commands: get

3. other commands: incr delete


error strings

1. "ERROR\r\n"

客户端发送了一个不存在的command


2. "CLIENT_ERROR <error>\r\n"

客户端的错误:客户端发送的数据或者格式方面有问题。 <error>表示具体错误的原因。


3. "SERVER_ERROR <error>\r\n"

服务器端的错误:服务器一系列的错误阻止了命令的执行。<error>表示具体错误的原因。当发生此错误时。服务器发送完了"SERVER_ERROR <error>\r\n"之后将会关闭connection。(这是唯一的关闭connection的情况)


descriptions of individual commands


1. storage commands

首先客户端向服务器按照如下格式发送命令行:

<command name> <key> <flags> <exptime> <bytes>\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"作为此次通讯的结束。


reply

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


a) "STORED\r\n"

表示存储成功


b) "NOT_STORED\r\n"

表示存储失败,但是该失败不是由于错误。通常这是由于"add"或者"replace"命令本身的要求所引起的,或者该项在删除队列之中(见delete命令)。


2 retrieval command

获取数据的格式:


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命令行中但是没有返回相应的数据,这意味着服务器中不存在这些项,这些项过时了,或者被删除了。


3. delete

delete 命令格式:

delete <key> <time>\r\n


a) <key> 需要被删除数据的key


b) <time> 客户端希望服务器将该数据删除的时间(unix时间或者从现在开始的秒数)


c) "\r\n" 命令头的结束


reply


a) "DELETED\r\n" 删除成功


b) "NOT_FOUND\r\n" 需要删除的key不存在


ps:"flush_all" command 可以所有项都无效。


4. increment/decrement


command "incr" "decr" 是用来改变数据项数值的命令。设置数据项的数据被认为是一个10进制的无符号的整数。如果当前设置的值不能够被转换则认为是0.如果该数据项的key不存在,则执行命令失败!


命令格式:


incr <key> <value>\r\n

or

decr <key> <value>\r\n


a) <key> 数据项的key


b) <value> 用户希望增加/减少的数据的数值.该数值是一个32位十进制的无符号整形变量。


c) "\r\n" 命令行结束标志


reply


a) "NOT_FOUND\r\n" 没有找到需要操作的项。


b) "<value>\r\n" <value>数据项有效期的最新剩余时间。


注意: 

a) 如果一个数据项的有效期被设置为0,这时使用decr命令是无法减少数据。


b) 如果要执行 incr key -1 的操作不会有什么问题,结果和你希望的一样。但是,执行decr -1时的结果一定会让你觉得很意外,因为它的结果无论key的数据是什么结果的都是0.原因是:在这两个命令的执行过程中都是吧-1当做一个无符号的整形处理的。


c) 执行decr命令时数据的长度不会随之而减小,而是在返回数据的后面填补空格。但是执行incr命令越界后会自动的增加数据的位数。



5. 其他命令


"stats": 用来查询服务器提供的内部数据。


stats <args>\r\n

查询特定的数据


reply


STAT <name> <value>\r\n

...

END\r\n


"quit"

"quit\r\n": 退出程序

 

link:

http://andylin02.iteye.com/blog/443744

http://www.cnblogs.com/eoiioe/archive/2009/06/03/1495338.html

 

关于stats及settings的介绍:

http://www.haogongju.net/art/583134

分享到:
评论

相关推荐

    nginx memcached tomcat8负载均衡配置文件

    2 解压附件里的压缩包里的memcached-win64-1.4.4-14.zip 命令行cd 到根目录然后执行 (1)memcached.exe -d install (2)memcached.exe -d start 2 解压附件里的压缩包里的nginx-1.10.1.zip 将附件压缩包的nginx-...

    memcached缓存,亲测可用

    windows上的安装 ... ·在命令行下操作:cd D:\memcached 转到安装目录下 ·执行memcached.exe -d install 把memcached加入到服务中 ·执行memcached.exe -d start 启动memcached服务 默认端口号是:11211。

    转载+整合 64位系统+ php 5.5 memcache 安装教程 及下载

    如果安装了memcached不安装扩展,那么php无法操控memcached,但是命令行使用起来没有问题 如果安装了memcache扩展但是没有安装memcached服务,那么这个就无法使用 只有同时安装了memcached服务和memcache扩展...

    高洛峰 memcache for window 和linux版软件及教程

    六、操作Memcached (命令行方式telnet作为客户端) telnet 192.168.1.128 80 --- apache telnet 192.168.1.129 21 --- ftpd telnet 192.168.1.111 22 ---ssh telnet localhost 11211 ---memcached 七、...

    redis windows(含32/64位 )v2.4.5官方版.zip

    redis windows支持32bit和64bit,自己实际情况选择,都是windows环境的,Redis是一个key-value存储系统。Redis的出现,很大程度补偿了memcached这类key...另外开启一个命令行窗口 进入redis目录下 (注意修改自己的ip)

    DebianLNMP加强版一键安装包Debian6配置Nginx PHP5.3 MySQL最快最新

    同时支持命令行方式的图片转换操作. 图像处理例如“验证码”“图片水印”.imagick module version 3.1.0RC2;ImageMagick version ImageMagick 6.6.0-4; +php缓存器.缓存加速;XCache v3.0.1;XCache Cacher v...

    java开源包1

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包11

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包2

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包3

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包6

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包5

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包10

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包4

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包8

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包7

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包9

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    java开源包101

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    Java资源包01

    可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...

    JAVA上百实例源码以及开源项目源代码

    6个目标文件,EJB来模拟银行ATM机的流程及操作:获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,并将当前的计数器初始化,调用每一个EJB对象的count()方法,保证Bean正常被激活和钝化,EJB对象是用...

Global site tag (gtag.js) - Google Analytics