php的memcache扩展和memcached扩展读写数组数据不相兼容原因探究

出处:http://www.akayzhang.com/article/6

背景

最近公司许多团队进行升级php7,目前支持php7读取mc的扩展只有memcached。

但是公司许多项目都会共用一个mc集群来存取用户session数据,存的时候是登陆时用memcache扩展以array的形式写进去,读的时候自然是用memcache扩展以array的形式读出来。 但是现在只能使用memcached进行读取。但是据我所知两者读取array形式的数据是互不兼容的,因此想探究一下究竟是为什么。

验证

验证memcache扩展和memcached扩展读写数组数据是否不相兼容

测试脚本:

echo "========== test  string  ============\n";

$mc = new Memcache;

$mc->addServer('10.199.189.129', 11511);

$key = 'testString';

$mc->set($key, 'test success');

var_dump($mc->get($key));

$mc2 = new memcached;

$mc2->addServer('10.199.189.129', 11511);

var_dump($mc2->get($key));

echo "========== test  array  ============\n";

$key2 = 'testArray';

$mc->set($key2, [1,2,3]);

var_dump($mc->get($key2));

var_dump($mc2->get($key2));

执行结果:

➜  ~ php /apps/dat/test.php

========== test  string  ============

string(12) "test success"

string(12) "test success"

========== test  array  ============

array(3) {

    [0]=> int(1)

    [1]=> int(2)

    [2]=> int(3)

}

int(0)

从结果来看,印证了我们之前的说法。以字符串类型的数据

猜测原因

由于string没有问题,出问题是在array格式里面。所以怀疑是array存进mc时的序列化方法不同。于是乎进行进一步的测试:

编写测试脚本

echo "========== test  array  ============\n";

$mc = new Memcache;

$mc->addServer('10.199.189.129', 11511);

$mc2 = new memcached;

$mc2->addServer('10.199.189.129', 11511);

$key2 = 'testArray1';

$key3 = 'testArray2';

$mc->set($key2, [1,2,3]);

$mc2->set($key3, [1,2,3]);

var_dump($mc->get($key2));

var_dump($mc2->get($key3));

执行结果:

➜  ~ php /apps/dat/test.php

========== test  array  ============

array(3) {

    [0]=> int(1)

    [1]=> int(2)

    [2]=> int(3)

}

array(3) {

    [0]=> int(1)

    [1]=> int(2)

    [2]=> int(3)

}

接下来直接连接mc进行查看

➜  ~ telnet 10.199.189.129 11511

Trying 10.199.189.129...

Connected to msession.vip.vip.co.

Escape character is '^]'.

get testArray1

VALUE testArray1 1 30

a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}

END

get testArray2

VALUE testArray2 4 30

a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}

END

从结果来看,我们可以发现,memcache和memcached写到mc里面的结果是一样的,也就是说我们的猜测是错误的。两个值的序列化处理一模一样,区别在于值的flag不同。 memcache存储array数据的时候,falg为1,而memcached为4. 我们知道,mc中值的flag是提供给使用者自定义,方便再读取的时候做不同的处理。但是为什么两者的flag定义会不相同呢。 抱着这个疑问,试着通过阅读两个扩展的源码查找原因。

阅读源码

memcache

php_memcache.h:

#define MMC_SERIALIZED 1

#define MMC_COMPRESSED 2

memcached

php_memcached.c

#define MEMC_VAL_IS_STRING    0

#define MEMC_VAL_IS_LONG      1

#define MEMC_VAL_IS_DOUBLE    2

#define MEMC_VAL_IS_BOOL      3

#define MEMC_VAL_IS_SERIALIZED 4

#define MEMC_VAL_IS_IGBINARY  5

#define MEMC_VAL_IS_JSON      6

#define MEMC_VAL_IS_MSGPACK    7

经阅读源码,发现memcache将array的数组格式的flag定义为1,而memcached为了将php存进mc中的值进行详细的类型区分,将数据类型定义了string,long,double等等的数据类型。

也就是说,当你使用memcache的时候,运行

$mc = new memcache;

$mc->addServer('10.199.189.129', 11511);

$mc->set('123',1);

var_dump($mc->get('123'));

执行结果是:

string(1) "1"

你明明存了一个值为数字1的key,但是读取的时候却为字符串。 而当你使用memcached的时候,运行

$mc = new memcached;

$mc->addServer('10.199.189.129', 11511);

$mc->set('123',1);

var_dump($mc->get('123'));

执行结果是:

int(1)

结论

memcache扩展和memcached扩展读写数组数据不相兼容的原因是,memcached为了详细地区分数据类型,定义了各种数据类型的标示,而导致其中数组的标识与memcache定义的数组标识不一致导致。 经过这次探究,也让我认识到许多memcached比memcache更优秀的地方,相信随着php7的普及,memcache会加速地被历史所淘汰。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

  • 1、memcache的概念? Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨...
    桖辶殇阅读 2,218评论 2 12
  • redis这个新产品在sns时很火,而memcache早就存在, 但redis提供出来的功能,好多网站均把它当me...
    常晓晓阅读 945评论 1 8
  • PHP7 已经出来1年了,PHP7.1也即将和大家见面,这么多好的特性,好的方法,为什么不使用呢,也希望PHP越来...
    梦幻_78af阅读 2,069评论 1 10
  • 1.为什么要使用memcache 由于网站的高并发读写需求,传统的关系型数据库开始出现瓶颈,例如: 1)对数据库的...
    苏文星阅读 1,777评论 0 5
  • 资讯类:人人 :http://www.woshipm.com/36氪:http://36kr.com/,看Next...
    斯瓦西里阅读 1,588评论 2 11