一:安裝libevent
由於memcached安裝時,需要使用libevent類庫,所以先安裝libevent
1.下載
#wget http://www.monkey.org/~provos/libevent-2.0.12-stable.tar.gz
2.解壓縮
#tar xzfv libevent-2.0.12-stable.tar.gz
3.進入目錄
#cd libevent-2.0.12-stable
4. 編譯,安裝
# ./configure
# make
# make install
注:默認安裝到/usr/local/lib/目錄
二:安裝Memcached
http://memcached.org/ 是Memcached的官方網站
1.下載
# wget http://memcached.googlecode.com/files/memcached-1.4.5.tar.gz
2.解壓縮
#tar xzfv memcached-1.4.5.tar.gz
3.進入目錄
#cd memcached-1.4.5
4. 編譯,安裝
./configure --prefix=/local/memcached
make
make install
安裝完成後,會在 /local/memcached 出現 bin和share目錄
進行 bin目錄,啓動 memcache
方法如下:
./memcached -d -u nobody -m 512 127.0.0.1 -p 11211
此時,會報一個異常
error while loading shared libraries: libevent-2.0.so.5: cannot open shared object file: No such file or directory
原因是找不到libevent-2.0.so.5類庫,解決辦法如下:
使用LD_DEBUG=help ./memcached -v來確定 加載的類庫路徑,方法如下:
LD_DEBUG=libs ./memcached -v 2>&1 > /dev/null | less
出現(END)可以直接輸入p退出
#ln -s /usr/local/lib/libevent-2.0.so.5 /lib/libevent-2.0.so.5
現在可以正常啓動memcached了
./memcached -d -u nobody -m 512 127.0.0.1 -p 11211
到這裏,看到memcached已經啓動,說明安裝成功。
三:安裝memcache PHP模塊
#wget http://pecl.php.net/get/memcache-2.2.4.tgz
# tar zxvf memcache-2.2.4.tgz
# cd memcache-2.2.4
找phpize
#whereis phpize
本機是/usr/bin/phpize
# /usr/bin/phpize
# ./configure --with-php-config=/usr/bin/php-config
# make
# make install
php.ini在/etc下
extension=memcache.so
重啓httpd
#service httpd restart
php裏使用phpinfo()看到如下信息說明memcached擴展才算安裝好!
四:PHP調用memcached
- <?php
- $memcache = new Memcache; //創建一個memcache對象
- $memcache->connect('localhost', 11211) or die ("Could not connect"); //連接Memcached服務器
- $memcache->set('key', 'test'); //設置一個變量到內存中,名稱是key 值是test
- $get_value = $memcache->get('key'); //從內存中取出key的值
- echo $get_value;
- ?>
- <?php
- //連接Memcache
- $mem = new Memcache;
- $mem->connect("localhost", 11211);
- //保存數據
- $mem->set('key1', 'This is first value', 0, 60);
- $val = $mem->get('key1');
- echo "Get key1 value: " . $val ."<br>";
- //替換數據
- $mem->replace('key1', 'This is replace value', 0, 60);
- $val = $mem->get('key1');
- echo "Get key1 value: " . $val . "<br>";
- //保存數組數據
- $arr = array('aaa', 'bbb', 'ccc', 'ddd');
- $mem->set('key2', $arr, 0, 60);
- $val2 = $mem->get('key2');
- echo "Get key2 value: ";
- print_r($val2);
- echo "<br>";
- //刪除數據
- $mem->delete('key1');
- $val = $mem->get('key1');
- echo "Get key1 value: " . $val . "<br>";
- //清除所有數據
- $mem->flush();
- $val2 = $mem->get('key2');
- echo "Get key2 value: ";
- print_r($val2);
- echo "<br>";
- //關閉連接
- $mem->close();
- ?>
在一臺或者多臺機器啓用一個或者多個進程,這裏是在一臺機器啓
用兩個進程,使用兩個端口:
#./memcached -d -u nobody -m 512 127.0.0.1 -p 11211
#./memcached -d -u nobody -m 512 127.0.0.1 -p 11212
- <?php
- //連接Memcache
- $mem = new Memcache;
- $mem->addServer("localhost", 11211);
- $mem->addServer("localhost", 11212);
- //保存數據
- $mem->set('key1', 'This is first value', 0, 60);
- $val = $mem->get('key1');
- echo "Get key1 value: " . $val ."<br>";
- //保存數組數據
- $arr = array('aaa', 'bbb', 'ccc', 'ddd');
- $mem->set('key2', $arr, 0, 60);
- $val2 = $mem->get('key2');
- echo "Get key2 value: ";
- print_r($val2);
- echo "<br>";
- //刪除數據
- $mem->delete('key1');
- $val = $mem->get('key1');
- echo "Get key1 value: " . $val . "<br>";
- //關閉連接
- $mem->close();
- ?>
五:Memcached一些特性和限制
• Memcached單進程最大使用內存爲2G,要使用更多內存,可以分多個端口開啓多個Memcached進程
• 最大30天的數據過期時間, 設置爲永久的也會在這個時間過期,常量REALTIME_MAXDELTA
60*60*24*30 控制
• 最大鍵長爲250字節,大於該長度無法存儲,常量KEY_MAX_LENGTH 250 控制
• 單個item最大數據是1MB,超過1MB數據不予存儲,常量POWER_BLOCK 1048576 進行控制,
它是默認的slab大小
• 最大同時連接數是200,通過 conn_init()中的freetotal 進行控制,最大軟連接數是1024,通過
settings.maxconns=1024 進行控制
• 跟空間佔用相關的參數:settings.factor=1.25, settings.chunk_size=48, 影響slab的數據佔用和步進方式
訪問Memcached:telnet 主機名 端口號
查看總狀態:stats
查看某項狀態:stats curr_connections
禁止LRU
有些情況下LRU機制反倒會造成麻煩。memcached啓動時通過“-M”參數可以禁止LRU,
如下所示:
$ memcached -M -m 1024
啓動時必須注意的是,小寫的“-m”選項是用來指定最大內存大小的。不指定具體數值則
使用默認值64MB。
指定“-M”參數啓動後,內存用盡時memcached會返回錯誤。話說回來,memcached畢
竟不是存儲器,而是緩存,所以推薦使用LRU。
在安裝的時候必須打開:./configure --enable-threads
安裝完之後,啓動的時候看看幫助信息有沒有這條:
-t <num> number of threads to use, default 4
如果存在該選項,說明已經支持了線程,就可以在啓動的時候使用 -t 選項來啓動多線程
然後啓動的時候必須加上你需要支持的線程數量:
/usr/local/memcache/bin/memcached -t 1024