Perl Memcached的客户端序列化对象采用的是Storable模块的nfreeze方法,而这个方法又调用了c扩展的do_store方法;反序列化使用的是Storable模块的thaw方法,而这个方法又是调用的c扩展的do_retrieve方法。
而在PHP中,进行的却是serialize和unserialize操作。造成了无法正常读取的结果。
Perl存储一个('a', 'c')数组的引用,
命令行获取的结果如下:

用二进制编辑器查看存储的结果如下:

在PHP中memcache客户端gzuncompress和unserialize函数处理前可以得到存储的数据,打印出来如下图所示:

和上面二进制编辑器查看的结果是一致的。
memcached的官方文档:http://code.google.com/p/memcached/wiki/FAQ
里也提到

由此可以看到,在不同语言的客户端访问memcached,由于对象序列化算法不一致,造成无法直接的进行读取和解析。
比较好的办法是通过通用的格式例如JSON、YAML进行存储和读取,或者调用服务,或者采用Thrift、Gearman这样的跨语言平台来解决。
但是对于已有的数据,有没有可以直接访问的办法呢?
Perl可以可以安装PHP serialize and unserialize in Perl模块实现和php一样的序列化,具体解决办法参加惊峰的博客:http://www.jeftom.com/?p=212#respond。
本文探讨了PerlMemcached客户端与PHP客户端在memcached交互时遇到的序列化问题,由于Perl使用Storable模块而PHP使用serialize和unserialize方法,导致两者间的数据无法直接互读。文章还提供了解决方案。
878

被折叠的 条评论
为什么被折叠?



