分別把memcached和libevent下載回來,放到 /tmp 目錄下:java
cd /tmpjquery
wget http://www.danga.com/memcached/dist/memcached-1.2.0.tar.gz算法
wget http://www.monkey.org/~provos/libevent-1.2.tar.gzspring
先安裝libevent:apache
tar zxvf libevent-1.2.tar.gz服務器
cd libevent-1.2併發
./configure –prefix=/usrmemcached
make測試
make install優化
測試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
還不錯,都安裝上了。
安裝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
,
測試是否成功安裝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
啓動Memcached服務:
啓動Memcache的服務器端:
/usr/local/bin/memcached -d -m 10 -u root -l 192.168.141.64 -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是設置保存Memcache的pid文件,我這裏是保存在 /tmp/memcached.pid,
若是要結束Memcache進程,執行:
kill cat /tmp/memcached.pid
也能夠啓動多個守護進程,不過端口不能重複。
測試
Memcached: [root@localhost /]# telnet 192.168.141.64 12000 Trying 192.168.141.64... Connected to 192.168.141.64 (192.168.141.64). Escape character is '^]'. set key1 0 60 4 zhou STORED get key1 VALUE key1 0 4 zhou END
至此Memcached安裝成功!
常見問題:
若是啓動Memcached服務的時候遇到了
/usr/local/bin/memcached: error while loading shared libraries: libevent-1.2.so.1: cannot open shared object file: No such file or directory; 解決方案: [root@localhost bin]# LD_DEBUG=libs memcached -v [root@localhost bin]# ln -s /usr/lib/libevent-1.2.so.1 /usr/lib64/libevent-1.2.so.1 [root@localhost bin]# /usr/local/bin/memcached -d -m 100 -u root -p 12000 -c 1000 -P /tmp/memcached.pid [root@localhost bin]# ps -aux 能夠看到啓動的Memcached服務了.
把Memcached服務加載到Linux的啓動項中.萬一機器斷電系統重啓.那麼Memcached就會自動啓動了.
假如啓動Memcache的服務器端的命令爲:
/usr/local/bin/memcached -d -m 10 -u root -l 192.168.141.64 -p 12000 -c 256 -P /tmp/memcached.pid容來自17jquery
想開機自動啓動的話,只需在/etc/rc.d/rc.local中加入一行,下面命令
/usr/local/memcached/bin/memcached -d -m 10 -p 12000 -u apache -c 256
上面有些東西能夠參考一下:即,ip不指定時,默認是本機,用戶:最好選擇是:apache 或 deamon
這樣,也就是屬於哪一個用戶的服務,由哪一個用戶啓動。
net.spy.memcached.spring.MemcachedClientFactoryBean在net.spy.memcached.MemcachedClient每次使用的時候建立MemcachedClient的新實例。 <bean id="memcachedClient" class="net.spy.memcached.spring.MemcachedClientFactoryBean"> <property name="servers" value="host1:11211,host2:11211,host3:11211"/> <property name="protocol" value="BINARY"/> <property name="transcoder"> <bean class="net.spy.memcached.transcoders.SerializingTranscoder"> <property name="compressionThreshold" value="1024"/> </bean> </property> <property name="opTimeout" value="1000"/> <property name="timeoutExceptionThreshold" value="1998"/> <property name="hashAlg" value="KETAMA_HASH"/> <property name="locatorType" value="CONSISTENT"/> <property name="failureMode" value="Redistribute"/> <property name="useNagleAlgorithm" value="false"/> </bean>
屬性說明:
Servers 一個字符串,包括由空格或逗號分隔的主機或IP地址與端口號 Daemon 設置IO線程的守護進程(默認爲true)狀態 FailureMode 設置故障模式(取消,從新分配,重試),默認是從新分配 HashAlg 設置哈希算法(見net.spy.memcached.HashAlgorithm的值) InitialObservers 設置初始鏈接的觀察者(觀察初始鏈接) LocatorType 設置定位器類型(ARRAY_MOD,CONSISTENT),默認是ARRAY_MOD MaxReconnectDelay 設置最大的鏈接延遲 OpFact 設置操做工廠 OpQueueFactory 設置操做隊列工廠 OpTimeout 以毫秒爲單位設置默認的操做超時時間 Protocol 指定要使用的協議(BINARY,TEXT),默認是TEXT ReadBufferSize 設置讀取的緩衝區大小 ReadOpQueueFactory 設置讀隊列工廠 ShouldOptimize 若是默認操做優化是不可取的,設置爲false(默認爲true) Transcoder 設置默認的轉碼器(默認以net.spy.memcached.transcoders.SerializingTranscoder) UseNagleAlgorithm 若是你想使用Nagle算法,設置爲true WriteOpQueueFactory 設置寫隊列工廠 AuthDescriptor 設置authDescriptor,在新的鏈接上使用身份驗證