Tokyo Tyrant(TTServer)系列-memcache协议
Tokyo Tyrant(TTServer)系列-memcache协议
[文章作者:孙立 链接:http://www.cnblogs.com/sunli/ 更新时间:2009-03-18]
上篇【Tokyo Tyrant(TTServer)系列-启动参数和配置 】
通过memcache协议使用ttserver
通过telnet 127.0.0.1 1978 telnet连接到到我们第一节的启动实例。
以下我们通过add增加key为key1和value为value1的数据。
通过get key1获取数据,如果你看不明白,可以搜索下memcache协议的东西看下。
add key1 1 0 6
value1
STORED
get key1
VALUE key1 0 6
value1
END
|
通过php使用
$mem=new Memcache(); $mem->connect("192.168.15.178",1978); $mem->add("key2","value2"); print_r( $mem->get("key2")); echo "<hr>"; $mem->add("key3",array("value3"=>"this is value3")); print_r($mem->get("key3")); ?> |
运行后输出:
value2
a:1:{s:6:"value3";s:14:"this is value3";} |
需要注意的问题
序列化问题
如果你熟悉memcache协议,或者你曾经用php的memcache来使用ttserver,你可能马上就发现了上面的问题。
比如我们key3是一个数组,但是我们取回来的是一个序列化的字符串,没有自动反序列化,在memcached服务器上是会
自动反序列化的。
通过上面的telnet示例我们可以看到,我们add key1的时候设置flag参数为1,但是我们get回来的时候,返回的flag参数是0,实际上,ttserver是没有存储flag参数的,统一的都使用0,这就造成了php使用时不会自动反序列化,当然,如果你使用压缩参数,一样会有这样的问题。
怎么样解决这个问题,如果要修改ttserver的代码实为不方便。我们完全可以在php,或者我们的客户端来控制。
比如value我们统一的都序列化后存储,取出来的时候我们再反序列化。
自增问题
//使用ttserver自增 $mem=new Memcache(); $mem->connect("192.168.15.178",1978); var_dump($mem->increment("incr")); //结果为int(1) ?> |
//使用memcache自增 $mem=new Memcache(); $mem->connect("192.168.15.178",11211); var_dump($mem->increment("incr")); //结果为bool(false) ?> |
我们看到同样的代码用在memcache返回了失败(false).我们可以在php手册上看到这样一句话“Memcache::increment() does not create an item if
it didn't exist.”但是同样的,用在ttserver上就是成功的。这一点要特别注意。
新浪微博:http://t.sina.com.cn/sunli1223
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述