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中的值進行減法操做。