Linux 下memcache安裝及使用

memcache是高性能,分佈式的內存對象緩存系統,用於在動態應用中減小數據庫負載,提高訪問速度。聽說官方所說,其用戶包括twitterdiggflickr等,都是些互聯網大腕呀。目前用memcache解決互聯網上的大用戶讀取是很是流行的一種用法。 javascript

 

LinuxMemcache服務器端的安裝 php

服務器端主要是安裝memcache服務器端,目前的最新版本是 memcached-1.3.0 html

下載:http://www.danga.com/memcached/dist/memcached-1.2.2.tar.gz java

另外,Memcache用到了libevent這個庫用於Socket的處理,因此還須要安裝libeventlibevent的最新版本是libevent-1.3。(若是你的系統已經安裝了libevent,能夠不用安裝) mysql

官網:http://www.monkey.org/~provos/libevent/ linux

下載:http://www.monkey.org/~provos/libevent-1.3.tar.gz sql

 

wget指令直接下載這兩個東西.下載回源文件後。 shell

1.先安裝libevent。這個東西在配置時須要指定一個安裝路徑,即./configure --prefix=/usr;而後make;而後make install 數據庫

2.再安裝memcached,只是須要在配置時須要指定libevent的安裝路徑即./configure --with-libevent=/usr;而後make;而後make install apache

這樣就完成了LinuxMemcache服務器端的安裝。詳細的方法以下:

 

 

1.分別把memcachedlibevent下載回來,放到 /tmp 目錄下:

# cd /tmp

# wget http://www.danga.com/memcached/dist/memcached-1.2.0.tar.gz

# wget http://www.monkey.org/~provos/libevent-1.2.tar.gz

 

2.先安裝libevent

# tar zxvf libevent-1.2.tar.gz

# cd libevent-1.2

# ./configure --prefix=/usr

# make

# make install

 

3.測試libevent是否安裝成功:

# ls -al /usr/lib | grep libevent

lrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent-1.2.so.1 -> libevent-1.2.so.1.0.3

-rwxr-xr-x 1 root root 263546 11?? 12 17:38 libevent-1.2.so.1.0.3

-rw-r--r-- 1 root root 454156 11?? 12 17:38 libevent.a

-rwxr-xr-x 1 root root 811 11?? 12 17:38 libevent.la

lrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent.so -> libevent-1.2.so.1.0.3

還不錯,都安裝上了。

 

4.安裝memcached,同時須要安裝中指定libevent的安裝位置:

# cd /tmp

# tar zxvf memcached-1.2.0.tar.gz

# cd memcached-1.2.0

# ./configure --with-libevent=/usr

# make

# make install

若是中間出現報錯,請仔細檢查錯誤信息,按照錯誤信息來配置或者增長相應的庫或者路徑。

安裝完成後會把memcached放到 /usr/local/bin/memcached

 

5.測試是否成功安裝memcached

# ls -al /usr/local/bin/mem*

-rwxr-xr-x 1 root root 137986 11?? 12 17:39 /usr/local/bin/memcached

-rwxr-xr-x 1 root root 140179 11?? 12 17:39 /usr/local/bin/memcached-debug

 

安裝MemcachePHP擴展

1.http://pecl.php.net/package/memcache 選擇相應想要下載的memcache版本。

2.安裝PHPmemcache擴展

 

tar vxzf memcache-2.2.1.tgz

cd memcache-2.2.1

/usr/local/php/bin/phpize

./configure --enable-memcache --with-php-config=/usr/local/php/bin/php-config --with-zlib-dir

make

make install

 

3.上述安裝完後會有相似這樣的提示:

Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/

 

4.php.ini中的extension_dir = "./"修改成

extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/"

 

5.添加一行來載入memcache擴展:extension=memcache.so

memcached的基本設置:

1.啓動Memcache的服務器端:

# /usr/local/bin/memcached -d -m 10 -u root -l 192.168.0.200 -p 12000 -c 256 -P /tmp/memcached.pid

 

-d選項是啓動一個守護進程,

-m是分配給Memcache使用的內存數量,單位是MB,我這裏是10MB

-u是運行Memcache的用戶,我這裏是root

-l是監聽的服務器IP地址,若是有多個地址的話,我這裏指定了服務器的IP地址192.168.0.200

-p是設置Memcache監聽的端口,我這裏設置了12000,最好是1024以上的端口,

-c選項是最大運行的併發鏈接數,默認是1024,我這裏設置了256,按照你服務器的負載量來設定,

-P是設置保存Memcachepid文件,我這裏是保存在 /tmp/memcached.pid

2.若是要結束Memcache進程,執行:

 

# kill `cat /tmp/memcached.pid`

 

也能夠啓動多個守護進程,不過端口不能重複。

3.重啓apacheservice httpd restart

 

Memcache環境測試:

運行下面的php文件,若是有輸出This is a test!,就表示環境搭建成功。開始領略Memcache的魅力把!

< ?php

$mem = new Memcache;

$mem->connect("127.0.0.1", 11211);

$mem->set('key', 'This is a test!', 0, 60);

$val = $mem->get('key');

echo $val;

?>

 

參考資料:

Memcached有疑問的朋友能夠參考下列文章:

Linux下的Memcache安裝:http://www.ccvita.com/257.html

Windows下的Memcache安裝:http://www.ccvita.com/258.html

Memcache基礎教程:http://www.ccvita.com/259.html

Discuz!Memcache緩存實現:http://www.ccvita.com/261.html

Memcache協議中文版:http://www.ccvita.com/306.html

Memcache分佈式部署方案:http://www.ccvita.com/395.html

 

啓動memcache服務

進入bin目錄,執行:./memcached -d -m 1024 -u blue,可是系統說有一個共享庫沒有加載,共享庫的名稱爲:libevent-1.4.so.2

首先要查看一下memcached 這個命令用到的連接庫地址在哪兒。執行以下命令能夠查看:

LD_DEBUG=libs /usr/local/memcached/bin/memcached -v

   

顯示出memcache從哪些地方找libevent-1.4.so.2這個文件,因此,咱們只有將libevent-1.4.so.2這個文件指定到上面任意一個目錄便可。這裏咱們將其指定到/lib64/下面。作一個軟鏈接便可。命令以下:

ln -s /usr/local/lib/libevent-1.4.so.2 /usr/lib/libevent-1.4.so.2

在啓動一下memcache服務:./memcached -d -m 1024 -u blue就能夠了

下面將memcached命令的參數羅倫以下,

# /usr/local/bin/memcached -d -m 200 -u root -l 192.168.1.91 -p 12301 -c 1000 -P /tmp/memcached.pid

相關解釋以下:

-d選項是啓動一個守護進程,

-m是分配給Memcache使用的內存數量,單位是MB,這裏是200MB

-u是運行Memcache的用戶,若是當前爲 root 的話,須要使用此參數指定用戶。

-l是監聽的服務器IP地址,若是有多個地址的話,我這裏指定了服務器的IP地址192.168.1.91

-p是設置Memcache監聽的端口,我這裏設置了12301,最好是1024以上的端口

-c選項是最大運行的併發鏈接數,默認是1024,這裏設置了256

-P是設置保存Memcache的pid文件,我這裏是保存在 /tmp/memcached.pid

中止Memcache進程:

# kill `cat /tmp/memcached.pid`

也能夠啓動多個守護進程,可是端口不能重複

一開始說的"-d"參數須要進行進一步的解釋

-d install 安裝memcached

-d uninstall 卸載memcached

-d start 啓動memcached服務

-d restart 重啓memcached服務

-d stop 中止memcached服務

-d shutdown 中止memcached服務

檢查服務:

1、查看啓動的memcache服務:

netstat -lp | grep memcached

2、查看memcache的進程號(根據進程號,能夠結束memcache服務:"kill -9 進程號"

ps -ef | grep memcached

   

參照: http://www.myexception.cn/linux-unix/1353940.html

linux上啓動Memcache報錯:error while loading shared libraries: libevent-1.4.so.2

linux上啓動Memcache報錯:

[root@localhost memcached]# ./bin/memcached -d -m 2048 -p 11211 -u root

./bin/memcached: error while loading shared libraries: libevent-1.4.so.2: cannot open shared object file: No such file or directory

緣由通常有兩個, 一個是操做系統裏確實沒有包含該共享庫(lib*.so.*文件)或者共享庫版本不對, 遇到這種狀況那就去網上下載並安裝上便可.

另一個緣由就是已經安裝了該共享庫, 但執行須要調用該共享庫的程序的時候, 程序按照默認共享庫路徑找不到該共享庫文件.

 

由於我已經安裝了libevent,因此應該是程序按照默認共享路徑庫去找,可是沒有找到致使的。

 

首先使用find命令找到libevent-1.4.so.2文件在哪兒

[root@localhost memcached]# find /usr -name libevent-1.4.so.2

/usr/libevent/lib/libevent-1.4.so.2

使用debug信息查看程序去哪裏尋找共享文件庫

LD_DEBUG=libs /usr/local/bin/memcached -v

其中/usr/local/bin/memcached表明我memcached執行程序

控制檯輸出結果以下:

[root@localhost memcached]# LD_DEBUG=libs /usr/local/bin/memcached -v

-bash: /usr/local/bin/memcached: No such file or directory

[root@localhost memcached]# LD_DEBUG=libs /usr/local/memcached/bin/memcached -v

6513: find library=libevent-1.4.so.2 [0]; searching

6513: search cache=/etc/ld.so.cache

6513: search path=/lib/tls/i686/sse2:/lib/tls/i686:/lib/tls/sse2:/lib/tls:/lib/i686/sse2:/lib/i686:/lib/sse2:/lib:/usr/lib/tls/i686/sse2:/usr/lib/tls/i686:/usr/lib/tls/sse2:/usr/lib/tls:/usr/lib/i686/sse2:/usr/lib/i686:/usr/lib/sse2:/usr/lib (system search path)

6513: trying file=/lib/tls/i686/sse2/libevent-1.4.so.2

6513: trying file=/lib/tls/i686/libevent-1.4.so.2

6513: trying file=/lib/tls/sse2/libevent-1.4.so.2

6513: trying file=/lib/tls/libevent-1.4.so.2

6513: trying file=/lib/i686/sse2/libevent-1.4.so.2

6513: trying file=/lib/i686/libevent-1.4.so.2

6513: trying file=/lib/sse2/libevent-1.4.so.2

6513: trying file=/lib/libevent-1.4.so.2

6513: trying file=/usr/lib/tls/i686/sse2/libevent-1.4.so.2

6513: trying file=/usr/lib/tls/i686/libevent-1.4.so.2

6513: trying file=/usr/lib/tls/sse2/libevent-1.4.so.2

6513: trying file=/usr/lib/tls/libevent-1.4.so.2

6513: trying file=/usr/lib/i686/sse2/libevent-1.4.so.2

6513: trying file=/usr/lib/i686/libevent-1.4.so.2

6513: trying file=/usr/lib/sse2/libevent-1.4.so.2

6513: trying file=/usr/lib/libevent-1.4.so.2

6513:

/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

根據debug日誌能夠看到,程序只會去/lib 和/usr/lib下去尋找須要的共享連接庫。

而個人libevent是安裝在/usr/libevent/lib/下,因此memcache啓動的時候並不知道該去這下面找,因此會報錯

 

因此安裝共享庫後要注意共享庫路徑設置問題, 以下:

1) 若是共享庫文件安裝到了/lib或/usr/lib目錄下, 那麼需執行一下ldconfig命令

ldconfig命令的用途, 主要是在默認搜尋目錄(/lib和/usr/lib)以及動態庫配置文件/etc/ld.so.conf內所列的目錄下, 搜索出可共享的動態連接庫(格式如lib*.so*), 進而建立出動態裝入程序(ld.so)所需的鏈接和緩存文件. 緩存文件默認爲/etc/ld.so.cache, 此文件保存已排好序的動態連接庫名字列表.

 

2) 若是共享庫文件安裝到了/usr/local/lib(不少開源的共享庫都會安裝到該目錄下)或其它"非/lib或/usr/lib"目錄下, 那麼在執行ldconfig命令前, 還要把新共享庫目錄加入到共享庫配置文件/etc/ld.so.conf中, 以下:

[root@localhost memcached]# cat /etc/ld.so.conf

include ld.so.conf.d/*.conf

如上所示:/etc/ld.so.conf配置文件中內容只有一行,

ld.so.conf.d/*.conf的意思就是包含ld.so.conf.d/目錄下以.conf爲後綴的文件

因此咱們能夠在/etc/ld.so.conf.d目錄下新建一個libevent.conf的配置文件,而後把libevent安裝路徑配置好

個人libevent內容以下:

[root@localhost ld.so.conf.d]# cat libevent.conf

/usr/libevent/lib

配置完後執行如下ldconfig命令

[root@localhost ~]#ldconfig

3) 若是共享庫文件安裝到了其它"非/lib或/usr/lib" 目錄下, 可是又不想在/etc/ld.so.conf中加路徑(或者是沒有權限加路徑). 那能夠export一個全局變量LD_LIBRARY_PATH, 而後運行程序的時候就會去這個目錄中找共享庫.

LD_LIBRARY_PATH的意思是告訴loader在哪些目錄中能夠找到共享庫. 能夠設置多個搜索目錄, 這些目錄之間用冒號分隔開. 好比安裝了一個mysql到/usr/local/mysql目錄下, 其中有一大堆庫文件在/usr/local/mysql/lib下面, 則能夠在.bashrc或.bash_profile或shell里加入如下語句便可:

export LD_LIBRARY_PATH=/usr/local/mysql/lib:$LD_LIBRARY_PATH

通常來說這只是一種臨時的解決方案, 在沒有權限或臨時須要的時候使用.

相關文章
相關標籤/搜索