Memcached中Perl序列化存储的对象PHP无法读取的解决

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

posted @ 2010-04-20 20:10  javawebsoa  Views(287)  Comments(0Edit  收藏  举报