- 浏览: 86996 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
骑猴上树:
报错啊SyntaxError (C:/home/blog/ap ...
Rails的validate验证的本地化 -
benlhp:
通许一天是什么意思啊??
有.没,有.人要买railscasts pro,想找一个人一起合买 -
Hooopo:
我想知道pro的内容有什么特别吗
有.没,有.人要买railscasts pro,想找一个人一起合买 -
cxh116:
en 看不懂
有.没,有.人要买railscasts pro,想找一个人一起合买 -
夜鸣猪:
多么,我怎么只看到2个pro两个revised,就四个怎么值得 ...
有.没,有.人要买railscasts pro,想找一个人一起合买
-
http://blog.chinaunix.net/u1/45336/showart_2227790.html
- 标准协议
- No Reply
- 存储命令
- set命令
- add命令
- replace命令
- append命令
- prepend命令
- cas命令
- 读取命令
- get命令
- gets命令
- 删除命令
- incr/decr命令
- 查看memcached使用状态
- stats命令
- stats items命令
- stats slabs命令
- stats sizes命令
- flush_all命令
- 标准协议
标准协议
memcached所有的标准协议包含在对item执行命令过程中,一个item包含:
- 一个key
- 一个32位的标志值
- 以秒为单位的失效时间
- 一个64为的CAS值,这个是唯一的
- 数据
”禁止CAS。
No Reply
大多数ascii命令允许“noreply”。建议大家在ascii协议下别用“noreply”,因为那样不会报请求错误。“noreply”的目的是在执行交互命令(如:set、add)后,避免等待返回的包。
二进制协议将“noreply”定义为声明。如果你的客户端支持或者使用二进制协议,那么你将会用到它。
存储命令
首先客户端向服务器按照如下格式发送命令行:
<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命令)。
set
set是保存数据命令。会覆盖已存在的数据,而新数据将在LRU顶端
add
只有在该数据不存在时才保存该数据。如果是新加入的item,那么将其直接放在LRU顶端;如果item已经存在导致add失败,那么将这个item从LRU链表上摘下再放到LRU顶端。
replace
替换已经存在的数据。 这个操作几乎用不到。
append
紧接着已经存在的item增加item。这个操作不允许增加原来的item限制,对管理链表很有用。
prepend
与append命令类似,这个命令是在已存在的数据前加入新数据。
cas
检查并存储(
Check And Set)或者比较并更新(Compare And Swap)。如果从上次读取到现在没有更新,那么存入数据,处理更新竞争很有用。
读取命令
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
读取命令, 更具一个或多个key查找数据,并返回所找到的数据。
gets
使用CAS的get命令,返回的item带有一个CAS标识符 (一个唯一的64位数)。使用cas命令返回数据。如果得到的item的cas值被更改了,这个数据将不会被保存。
删除命令
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不存在
Increment and Decrement. 如果item是以64为整型存储的,那么可以使用incr和decr命令修改那个数。
如果数据不存在,那么将返回失败。
命令格式:
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命令越界后会自动的增加数据的位数。
查看memcached使用状态
通过这些命令可以查看memcached服务器的使用状态。
stats
查看memcached状态的基本命令,通过这个命令可以看到如下信息:
|
stats items
输出各个slab中的item信息。s
stats slabs
输出slab中更详细的item信息
stats sizes
输出所有item的大小和个数
stats cachedump <slab_id> <limit_num>
flush_all
使在内存中所有的item失效。加入参数则表示在N秒后失效所有item。这项操作会立即返回,不会暂停服务器。这个操作并不会真的释放内存空间,而是标志所有的item为失效
发表评论
-
蜗牛同学新做的小站,大家轻拍
2011-03-16 17:32 2066是一个常见的旅游网站,目前来说业务只在南京地区 网址是 悠 ... -
mongoid没有的set_defaults rake
2011-02-07 23:23 1036#https://github.com/iamnade ... -
转//mongoDB安装
2011-01-06 23:06 835http://shiftcommathree.com/arti ... -
linux文件权限
2010-11-02 20:47 1238sudo chmod -R 777 /home/www/ ... -
同一个控制器,公用子菜单的方法
2010-10-20 12:08 920在做管理后台的时候经常会遇到同一个控制器的 :index ,: ... -
_form 中常用的 form_for ,这样就不用写两次 url 啦!
2010-09-19 23:41 1008额,这个是 /admin/xxx 下的情况,备份一下免得忘记了 ... -
task调用
2010-09-19 16:30 966task :yyy do Task[:xxx].i ... -
比较好的用户多角色控制,适用于用户角色不多的情况,最好5个以内
2010-09-19 16:18 937named_scope :email_is, lambda ... -
truncate_u
2010-09-17 15:31 1161def truncate_u(text, length = ... -
will_paginate 中文
2010-09-16 10:33 1566在 /config/initialize下放一个 will_p ... -
Nginx防盗链的几种方法
2010-09-12 10:45 1564转载: http://www.31sky.net/node/3 ... -
VPS安装记录
2010-09-12 10:43 1255操作系统 Linux ubuntu 2.6.32-21-se ... -
rails的301重定向
2010-09-09 10:54 971def redirect_301_to url ... -
zhuan//為Ruby on Rails程式加入拖曳排序功能~
2010-07-25 11:56 943来源: http://www.simplexteam.org/ ... -
转 Installing Nginx with Passenger on Linux (from source)
2010-07-24 02:05 911http://www.openmymind.net/2010/ ... -
复制一下,免得下次翻越围墙
2010-07-15 15:32 395分享: <!-- MURMUR --&g ... -
抄写一下
2010-07-15 15:29 764Deploying a Ruby on Rails appli ... -
周末在家两天利用Nokogiri 和 Mechanize 写了个团购导航小网站。。。轻拍砖。。。
2010-07-14 02:24 2328module Goods module MeiTuan ... -
[转载]rails Helper 解析
2010-04-16 01:26 3735http://blog.csdn.net/e_online/a ... -
Conexant Systems HD SmartAudio 221 @ 英特尔 82801I(ICH9) 高保真音频
2010-03-20 19:15 14616Conexant Systems HD SmartAudio ...
相关推荐
### Memcached 命令详解 #### 一、Memcached简介 Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少从复杂数据库中检索数据所需的次数,从而...
### Memcached 命令汇总:Stats 系列详解 #### 概述 Memcached 是一种高性能、分布式内存对象缓存系统,用于减轻数据库负载、加快动态 Web 应用的速度并提升网站性能。通过 stats 命令,我们可以获取 Memcached ...
标题中的“memcached几个命令”指的是在使用memcached这一分布式内存对象缓存系统时,经常用到的一些核心命令。memcached被广泛应用于大型网站设计,尤其是对于PHP程序员来说,掌握这些命令是至关重要的。 首先,...
本文将详细介绍Memcached的一些常用命令及其使用说明。 一、存储命令 1. `set key flags exptime bytes` `set`命令是最常用的,用于存储或更新键值对。如果键已经存在,它会更新该键的值。`flags`允许客户端附加...
memcached-win64安装包 内含详细安装命令说明文件:说明.txt windows上保证安装成功。
对于那些想要深入了解Memcached的用户,可以查看`man memcached`获取命令行工具的完整文档,或者阅读源代码来理解其工作原理。源代码分析可以帮助你定制服务,添加新功能,或解决特定问题。 标签提到的“源码”意味...
计算机后端-PHP视频教程. Memcached04 memcached基本命令.wmv
2. **Memcached命令** - `Memcached`命令行工具提供了多个选项用于管理服务。例如: - `-p`设置监听的端口,默认是11211。 - `-l`设置监听的IP地址,默认为本机。 - `-d start/restart/stop/shutdown/install/...
本文档主要讲解了在 Linux(Cent OS7.2) 环境下安装、启动和停止 Memcached 服务的方法,并对 ps 命令的使用进行了详细讲解。 一、Memcached 服务安装 在 Linux(Cent OS7.2) 环境下,可以使用 yum 源安装 Memcached...
在终端(也即cmd命令界面)下输入 ‘c:\memcached\memcached.exe -d install’ 安装 3. 再输入: ‘c:\memcached\memcached.exe -d start’ 启动。NOTE: 以后memcached将作为windows的一个服务每次开机时自动启动...
1. 启动命令:`memcached -d -p 11211 -u root -m 64`,这里 `-p` 指定端口号,`-u` 指定运行用户,`-m` 设置内存大小。 2. 要检查服务是否运行,可以使用`ps aux | grep memcached`。 为了更方便地控制memcached,...
标题"memcached 64位 window"指的是在Windows操作系统上运行的64位版本的Memcached缓存系统。Memcached是一种分布式内存对象缓存系统,广泛用于减轻数据库负载,提高Web应用的性能。由于是64位版本,这意味着它可以...
如果 Memcached 成功安装,您应该能在 `/usr/local/bin` 目录下看到 `memcached` 命令。 #### 四、安装 Memcache PHP 扩展 为了使 PHP 能够与 Memcached 进行交互,还需要安装 Memcache 的 PHP 扩展。 1. **安装...
3. **配置Memcached**: 在Windows环境下,不像Linux那样使用服务管理命令,你需要手动创建一个批处理文件或使用第三方工具(如`nssm - the Non-Sucking Service Manager`)将`memcached.exe`作为Windows服务运行。...
首先,解压安装包至指定目录,然后以管理员身份运行以下命令将Memcached添加到任务计划程序中: ```cmd schtasks /create /sc onstart /tn memcached /tr "'C:\memcached\memcached.exe' -m 512" ``` 其中,`-m ...
`stats` 命令可以用来查看Memcached的整体统计信息,包括版本号、当前时间戳、启动时间、连接数、命令执行次数等。具体命令如下: ```sh stats ``` 示例输出: ``` STAT pid 27835 STAT uptime 297 STAT time ...
例如,命令`./memcached -m 512 -p 11211 -vv`表示Memcached将以512MB的内存限制在11211端口上运行,并输出详细信息。 #### 四、Memcached使用 Memcached提供了丰富的API支持,适用于多种编程语言。测试时,可通过...
**Memcached 安装与使用详解** Memcached 是一款高性能的分布式内存缓存系统,用于在Web应用中减轻数据库负载。它将数据存储在内存中,以键值对的形式提供快速访问,尤其适用于高并发场景。Memcached 使用简单,可...
本文将介绍如何使用 Telnet 命令来查看 Memcached 的运行状态。 一、Telnet 命令 Telnet 是一个基本的网络协议,用于远程登录和查看服务器的状态。我们可以使用 Telnet 命令来连接 Memcached 服务器,并查看其运行...
可以使用 `memcached –m 200` 命令来调整最大内存占用,但是这个命令可能不生效。解决方法是修改注册表中的ImagePath项。在 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server 中添加 `-l ...