php上的memcache和memcached兩個pecl庫

來源:互聯網
上載者:User

之前嘗試用的是memcache,後來發現memcached支援setMulti方法,準備轉向使用memcached庫了。

(試了下,實際上,memcache從支援多值set,但文檔上還沒有,看changelog好像是3.0開始支援,穩定版可能不帶此功能。)

至於效率,也不清楚會有多大差距。

這裡有一篇文章也說到,memcached是基於libmemcached,可能要好一些。

終於,基於libmemached的php擴充在pecl發布了。

於是,現在pecl上有兩個memcache用戶端了。一個是完全在PHP架構內開發的memcache,一個是使用libmemcached的memecached。

功能嘛,我沒看過libmemcached,但是理論上來說,在其他語言裡已經很流行的libmemcached應該會有更完善的功能。而程式上效能(記憶體和CPU使用率),不好說,雖然pecl::memcache是原生實現的,但是使用libmemcached的pecl::memached只支援OO介面,而pecl::memcache則是OO和非OO兩套介面並存,這點拖累了它。

其實這些都不是最重要的。使用libmemcached有個明顯的優點,就是以後隨著memcached伺服器端的改進,這個lib也必定會馬上跟進的。而pecl::memcache卻不一定能做到按時跟進。

pecl::memcached,還有個非常稱讚的地方,就是flag不是在操作的時候設定了。而是有一個統一的setOption()。衝著這個方法,就非常值得從pecl::memcache轉到pecl::memcached了。具體的介面可以看這裡:http://cvs.php.net/viewvc.cgi/pecl/memcached/memcached-api.php?view=markup

我在pecl-dev@裡提到是否可以做成driver-based的架構。跟現在的MySQL一樣,可以選擇使用mysqlnd或者libmysql作為底層的引擎。但是之後想想,其實我並不是很支援對memcached使用這樣的架構,它和MySQL的情況不一樣。

mysqlnd作為一個引擎而不是一個新的api來開發,可以使得大量的應用程式不需要對資料庫操作做修改即可用上新的引擎。如果mysqlnd作為一個新的extension,那麼如果它想相容以前的程式,就面臨一個很困難的選擇。因為目前為止,存在3個官方的使用libmysql的,並具有不同對外介面的MySQL類集。mysqlnd能相容mysql,就無法相容mysqli或者pdo。當然對於使用自己的抽象資料庫類的程式來說,這個可以通過改寫類或者更換driver(php層面)來實現相容。但是要想想,就算是使用抽象庫,這個世界如此之多的資料庫抽象庫,如果要讓所有人都用得起nd,那得改多少個庫,加多少個driver阿。

memcached的情況就簡單很多了,目前和官方關係比較密切的只有pecl::memcache,而且介面基本上都是根據memcached的協議來的,和libmemcache相差無幾。它們其實都可以被看作是一個抽象類別裡的不同driver。所以雖然是兩套不同的用戶端,但是更換起來,幾乎不需要做什麼改動,只需要在類初始化的地方更改一下,set/get等等這些方法的flag去掉即可,除非你使用了非OO的介面。

另外mysql在通訊和資料擷取上也比memcache複雜,nd可以做到一些libmysql無法做到的事情。例如buffer可以直接用php內部的HashTable和zval儲存;再例如一些作為持久連結的結構可以更多地緩衝起來。(這些例如只是我的猜測,我並沒有去閱讀過mysqlnd的代碼)

Memcached manual:

http://cn.php.net/manual/en/book.memcached.php

Memcache manual:

http://cn.php.net/manual/en/book.memcache.php

Memcached 協議中英文對照

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.