PHP MEMCACHE 詳解(經典php緩衝)

來源:互聯網
上載者:User
Memcache函數庫是在PECL(PHPExtensionCommunityLibrary)中,主要作
用是搭建大容量的記憶體資料的 臨時存放地區,在分布式的時候作用體現的非常明顯,否則不建議使用。 本人在ubuntu上安裝 完啟動並執行時候報錯:
/usr/local/memcached/bin/memcached:errorwhilelo 

   

Memcache函數庫是在PECL(PHP Extension Community Library)中,主要作用是搭建大容量的記憶體資料的

臨時存放地區,在分布式的時候作用體現的非常明顯,否則不建議使用。 本人在ubuntu上安裝

完啟動並執行時候報錯:
/usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2: 

cannot open shared object file: No such file or directory

按照:《libeven、memcached、libmemcache安裝》中的方法,使用:

sudo ln -s /usr/local/lib/libevent-1.4.so.2 /usr/lib/libevent-1.4.so.2
可以修正這個BUG

通過新得立安裝php的memcached模組,登出/etc/php5/conf.d/memcached.ini裡面的“;”,重啟apache

,調用phpinfo()出現memcached的資訊

執行:
<?php
$memcache = new Memcache;
$memcache->connect('localhost', 11211) or die ("Could not connect");
$version = $memcache->getVersion();
echo "Server's version: ".$version."
\n";
?>
<?php
$memcache = new Memcache;
$memcache->connect('localhost', 11211) or die ("Could not connect");
print_r($memcache->getStats());
/**
* Array
* (
*     [pid] => 8052
*     [uptime] => 9205
*     [time] => 1205898428
*     [version] => 1.2.5
*     [pointer_size] => 32
*     [rusage_user] => 0.008000
*     [rusage_system] => 0.000000
*     [curr_items] => 1
*     [total_items] => 17
*     [bytes] => 57
*     [curr_connections] => 2
*     [total_connections] => 15
*     [connection_structures] => 3
*     [cmd_get] => 9
*     [cmd_set] => 23
*     [get_hits] => 5
*     [get_misses] => 4
*     [evictions] => 0
*     [bytes_read] => 671
*     [bytes_written] => 850
*     [limit_maxbytes] => 10485760
*     [threads] => 1
* )
*/
?>
<?php
$memcache = new Memcache;
$memcache->connect('localhost', 11211) or die ("Could not connect");
$memcache->set( 'name', 'leo', 0, 30);
if(!$memcache->add( 'name', 'susan', 0, 30))
{
    echo 'susan is exist';
};
$memcache->replace( 'name', 'lion', 0, 300);
echo $memcache->get( 'name');
$memcache->delete( 'name', 5);
?> 
<?php
function _callback_memcache_failure($host, $port) {
    print "memcache '$host:$port' failed";
}
$memcache = new Memcache;
$memcache->addServer('192.168.1.116', 11211);
$memcache->setServerParams('192.168.1.116', 11211, 1, 15, true, 

'_callback_memcache_failure');
echo $memcache->getServerStatus('192.168.1.116', 11211);
?>
<?php
$memcache = new Memcache;
$memcache->connect('localhost', 11211);
$memcache->set('test_item', 8);
$memcache->increment('test_item', 4);
echo $memcache->decrement('test_item', 7);
// 顯示 5
?>

 

/usr/local/bin/memcached -d -m 10 -u root -l 127.0.0.1 -p 11211 -c 256 -P 
                /tmp/memcached.pid
memcached的服務正式啟動

Memcache::add — 添加一個值,如果已經存在,則返回false
Memcache::addServer — 添加一個可供使用的伺服器位址
Memcache::close — 關閉一個Memcache對象
Memcache::connect — 建立一個Memcache對象
memcache_debug — 控制調試功能
Memcache::decrement — 對儲存的某個key中的值進行減法操作
Memcache::delete — 刪除一個key值
Memcache::flush — 清除所有緩衝的資料
Memcache::get — 擷取一個key值
Memcache::getExtendedStats — 擷取進程池中所有進程的運行系統統計
Memcache::getServerStatus — 擷取運行伺服器的參數
Memcache::getStats — 返回伺服器的一些運行統計資訊
Memcache::getVersion — 返回啟動並執行Memcache的版本資訊
Memcache::increment — 對儲存的某個key中的值進行加法操作
Memcache::pconnect — 建立一個Memcache的持久連線物件
Memcache::replace — R對一個已有的key進行覆寫操作
Memcache::set — 添加一個值,如果已經存在,則覆寫
Memcache::setCompressThreshold — 對大於某一大小的資料進行壓縮
Memcache::setServerParams — 在運行時修改伺服器的參數

建議用物件導向的方式來測試這個庫: 

Memcache::getVersion方法的作用是返回啟動並執行Memcache的版本資訊。

Memcache::getStats 方法的作用是返回伺服器的一些運行統計資訊。Memcache::getStats方法有三個參

數,第一個參數表示要求返回的類型:reset, malloc, maps, cachedump, slabs, items, sizes;第二個

參數和第三個參數是在第一個參數設定為“cachedump”時使用的。Memcache::getExtendedStats方法的

作用是擷取進程池中所有進程的運行系統統計。

Memcache::connect方法的作用是建立一個Memcache對象。Memcache::pconnect方法的作用是建立一個

Memcache的持久連線物件。Memcache::close方法的作用是關閉一個Memcache對象。

Memcache::set 方法的作用是添加一個值,Memcache::set方法有四個參數,第一個參數是key,第二個參

數是value,第三個參數可選,表示是否壓縮儲存,第四個參數可選,用來設定一個到期自動銷毀的時間

。Memcache::add方法的作用和Memcache::set方法類似,區別是如果 Memcache::add方法的傳回值為

false,表示這個key已經存在,而Memcache::set方法則會直接覆寫。 Memcache::get方法的作用是擷取

一個key值,Memcache::get方法有一個參數,表示key。Memcache::replace 方法的作用是對一個已有的

key進行覆寫操作,Memcache::replace方法有四個參數,作用和Memcache::set方法的相同。 

Memcache::delete方法的作用是刪除一個key值,Memcache::delete方法有兩個參數,第一個參數表示key

,第二個參數可選,表示刪除延遲的時間。

memcache_debug()函數的作用是控制調試功能,前提是php在編譯的時候使用了–enable-debug選項,否

則這個函數不會有作用。

Memcache::addServer 方法的作用是添加一個可供使用的伺服器位址,Memcache::addServer方法有8個參

數,除了第一個參數意外,其他都是可選的,第一個參數表示伺服器的地址,第二個參數表示連接埠,第三

個參數表示是否是一個持久串連,第四個參數表示這台伺服器在所有伺服器中所佔的權重,第五個參數表

示串連的期間,第六個參數表示串連重試的間隔時間,預設為15,設定為-1表示不進行重試,第七個

參數用來控制伺服器的線上狀態,第8個參數允許設定一個回掉函數來處理錯誤資訊。
Memcache::setServerParams方法的作用是在運行時修改伺服器的參數,Memcache::setServerParams方法

有六個參數,Memcache::addServer方法少了第三和第四個參數。 Memcache::getServerStatus方法的作

用是擷取運行伺服器的參數,兩個參數分別表示的地址和連接埠。

Memcache::flush方法的作用是清除所有緩衝的資料,但是不會削去使用的記憶體空間。

Memcache::increment方法的作用是對儲存的某個key中的值進行加法操作,Memcache::decremen方法的作

用是對儲存的某個key中的值進行減法操作。

詳見:http://www.php100.com/html/webkaifa/PHP/PHPyingyong/2010/0126/3868.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.