摘要:背景最近公司許多團隊進行升級,目前支持讀取的擴展只有。驗證驗證擴展和擴展讀寫數(shù)組數(shù)據(jù)是否不相兼容測試腳本執(zhí)行結(jié)果從結(jié)果來看,印證了我們之前的說法。為了保證擴展和擴展直接寫的數(shù)據(jù)可以相互讀取,只能用的格式寫入。
背景
最近公司許多團隊進行升級php7,目前支持php7讀取mc的擴展只有memcached。
但是公司許多項目都會共用一個mc集群來存取用戶session數(shù)據(jù),存的時候是登陸時用memcache擴展以array的形式寫進去,讀的時候自然是用memcache擴展以array的形式讀出來。 但是現(xiàn)在只能使用memcached進行讀取。但是據(jù)我所知兩者讀取array形式的數(shù)據(jù)是互不兼容的,因此想探究一下究竟是為什么。
驗證memcache擴展和memcached擴展讀寫數(shù)組數(shù)據(jù)是否不相兼容
測試腳本:
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 ============ "; $key2 = "testArray"; $mc->set($key2, [1,2,3]); var_dump($mc->get($key2)); var_dump($mc2->get($key2));
執(zhí)行結(jié)果:
? ~ 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)
從結(jié)果來看,印證了我們之前的說法。
猜測原因由于string沒有問題,出問題是在array格式里面。所以懷疑是array存進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));
執(zhí)行結(jié)果:
? ~ 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 10.199.189.129 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
從結(jié)果來看,我們可以發(fā)現(xiàn),memcache和memcached寫到mc里面的結(jié)果是一樣的,也就是說我們的猜測是錯誤的。兩個值的序列化處理一模一樣,區(qū)別在于值的flag不同。 memcache存儲array數(shù)據(jù)的時候,falg為1,而memcached為4. 我們知道,mc中值的flag是提供給使用者自定義,方便再讀取的時候做不同的處理。但是為什么兩者的flag定義會不相同呢。 抱著這個疑問,試著通過閱讀兩個擴展的源碼查找原因。
閱讀兩個擴展的源碼 memcachephp_memcache.h:
#define MMC_SERIALIZED 1 #define MMC_COMPRESSED 2memcached
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
經(jīng)閱讀源碼,發(fā)現(xiàn)memcache將array的數(shù)組格式的flag定義為1,而memcached為了將php存進mc中的值進行詳細的類型區(qū)分,將數(shù)據(jù)類型定義了string,long,double等等的數(shù)據(jù)類型。
也就是說,當(dāng)你使用memcache的時候,運行
addServer("10.199.189.129", 11511); $mc->set("123",1); var_dump($mc->get("123"));
執(zhí)行結(jié)果是:
string(1) "1"
你明明存了一個值為數(shù)字1的key,但是讀取的時候卻為字符串。 而當(dāng)你使用memcached的時候,運行
addServer("10.199.189.129", 11511); $mc->set("123",1); var_dump($mc->get("123"));
執(zhí)行結(jié)果是:
int(1)結(jié)論
memcache擴展和memcached擴展讀寫數(shù)組數(shù)據(jù)不相兼容的原因是,memcached為了詳細地區(qū)分數(shù)據(jù)類型,定義了各種數(shù)據(jù)類型的標(biāo)識,而其中數(shù)組的標(biāo)識與memcache定義的數(shù)組標(biāo)識不一致導(dǎo)致。
為了保證memcache擴展和memcached擴展直接寫的數(shù)據(jù)可以相互讀取,只能用string的格式寫入mc。
經(jīng)過這次探究,也讓我認識到許多memcached比memcache更優(yōu)秀的地方,相信隨著php7的普及,memcache會加速地被歷史所淘汰。
轉(zhuǎn)載注明來源:
作者: Akay
本文地址: [http://www.akayzhang.com/arti...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/21937.html
摘要:背景最近公司許多團隊進行升級,目前支持讀取的擴展只有。驗證驗證擴展和擴展讀寫數(shù)組數(shù)據(jù)是否不相兼容測試腳本執(zhí)行結(jié)果從結(jié)果來看,印證了我們之前的說法。為了保證擴展和擴展直接寫的數(shù)據(jù)可以相互讀取,只能用的格式寫入。 背景 最近公司許多團隊進行升級php7,目前支持php7讀取mc的擴展只有memcached。但是公司許多項目都會共用一個mc集群來存取用戶session數(shù)據(jù),存的時候是登陸時用...
摘要:以下正文的部分內(nèi)容來自程序員面試筆試寶典書籍,如果轉(zhuǎn)載請保留出處一什么是是一個開源免費高性能的分布式對象緩存系統(tǒng),它基于一個存儲鍵值對的來存儲數(shù)據(jù)到內(nèi)存中。預(yù)告面試常考內(nèi)容之和將于本周三更新。 你好,是我琉憶。繼上周(2019.2-11至2-15)發(fā)布的PHP面試常考內(nèi)容之面向?qū)ο髮n}后,發(fā)布的第二個專題,感謝你的閱讀。本周(2019.2-18至2-22)的文章內(nèi)容點為以下幾點,更新時...
摘要:以下正文的部分內(nèi)容來自程序員面試筆試寶典書籍,如果轉(zhuǎn)載請保留出處一什么是是一個開源免費高性能的分布式對象緩存系統(tǒng),它基于一個存儲鍵值對的來存儲數(shù)據(jù)到內(nèi)存中。預(yù)告面試常考內(nèi)容之和將于本周三更新。 你好,是我琉憶。繼上周(2019.2-11至2-15)發(fā)布的PHP面試常考內(nèi)容之面向?qū)ο髮n}后,發(fā)布的第二個專題,感謝你的閱讀。本周(2019.2-18至2-22)的文章內(nèi)容點為以下幾點,更新時...
摘要:安裝擴展支持在服務(wù)以及擴展中,默認都是不支持用戶名和密碼,但是如果需要可以通過打開來提供用戶名和密碼服務(wù)。最后在修改對應(yīng)的文件增加擴展重啟,大功告成以上內(nèi)容僅供參考 Mac安裝memcached擴展支持sasl Memcached在服務(wù)以及擴展中,默認都是不支持用戶名和密碼,但是如果需要可以通過打開sasl來提供用戶名和密碼服務(wù)。所以在memcached的擴展與服務(wù)器安裝時都需要啟用s...
摘要:安裝擴展支持在服務(wù)以及擴展中,默認都是不支持用戶名和密碼,但是如果需要可以通過打開來提供用戶名和密碼服務(wù)。最后在修改對應(yīng)的文件增加擴展重啟,大功告成以上內(nèi)容僅供參考 Mac安裝memcached擴展支持sasl Memcached在服務(wù)以及擴展中,默認都是不支持用戶名和密碼,但是如果需要可以通過打開sasl來提供用戶名和密碼服務(wù)。所以在memcached的擴展與服務(wù)器安裝時都需要啟用s...
閱讀 703·2021-11-18 10:02
閱讀 3579·2021-09-02 10:21
閱讀 1725·2021-08-27 16:16
閱讀 2058·2019-08-30 15:56
閱讀 2386·2019-08-29 16:53
閱讀 1373·2019-08-29 11:18
閱讀 2953·2019-08-26 10:33
閱讀 2642·2019-08-23 18:34