Memcache集羣環境下緩存解決方案
前端
Memcache是一個高性能的分佈式的內存對象緩存系統,經過在內存裏維護一個統一的巨大的hash表,它可以用來存儲各類格式的數據,包括圖像、視頻、文件以及數據庫檢索的結果等。簡單的說就是將數據調用到內存中,而後從內存中讀取,從而大大提升讀取速度。 java
Memcache是danga的一個項目,最先是LiveJournal 服務的,最初爲了加速 LiveJournal 訪問速度而開發的,後來被不少大型的網站採用。 git
Memcached是以守護程序方式運行於一個或多個服務器中,隨時會接收客戶端的鏈接和操做 github
Memcached是高性能的,分佈式的內存對象緩存系統,用於在動態應用中減小數據庫負載,提高訪問速度。Memcached由Danga Interactive開發,用於提高LiveJournal.com訪問速度的。LJ每秒動態頁面訪問量幾千次,用戶700萬。Memcached將數據庫負載大幅度下降,更好的分配資源,更快速訪問。 web
上網baidu了不少東西,幾乎都差很少,並且基於java的說的不多,全部只有在研究了各個其餘語言類的應用後再來嘗試在java上進行簡單的操做應用。先從memcached上進行說明,memcached的最新版是採用c語言進行開發和設計的,聽說舊版的是採用perl語言開發的,並且它是一個應用軟件來的,是做爲緩存服務器的服務器端運行在服務器上的,須要使用特定的語言編寫客戶端與其進行通訊來進行數據的緩存和獲取。一般咱們是把memcached安裝運行在web服務器上,而後經過對須要的數據進行緩存,據我目前所知,全部數據的緩存設置和存取操做,以及數據的更新後替換操做所有須要程序來進行,而不是自動進行的(自動不知道能不能成功,呵呵)。下面從一個實際的例子來應用memcached。 算法
如何要下載的話,到http://danga.com/memcached/下載memcached。 數據庫
安裝Libevent apache
Libevent是一個異步事件處理軟件函式庫,以BSD許可證釋出。Memcached依賴Libevent,所以必須先編譯安裝Libevent。 ubuntu
檢測libevent 安裝是否成功,輸入:# ls -al /usr/lib | grep libevent 會出現以下結果(不一樣的機器可能有不一樣的輸出):
yangfei@yangfei-laptop:~$ ls -al /usr/lib |grep libevent
lrwxrwxrwx 1 root root 21 2009-07-19 08:45 libevent-1.4.so.2 -> libevent-1.4.so.2.1.3
-rwxr-xr-x 1 root root 301588 2009-07-19 08:45 libevent-1.4.so.2.1.3
-rw-r--r-- 1 root root 386638 2009-07-19 08:45 libevent.a
lrwxrwxrwx 1 root root 26 2009-07-19 08:45 libevent_core-1.4.so.2 -> libevent_core-1.4.so.2.1.3
-rwxr-xr-x 1 root root 115721 2009-07-19 08:45 libevent_core-1.4.so.2.1.3
-rw-r--r-- 1 root root 151618 2009-07-19 08:45 libevent_core.a
-rwxr-xr-x 1 root root 860 2009-07-19 08:45 libevent_core.la
lrwxrwxrwx 1 root root 26 2009-07-19 08:45 libevent_core.so -> libevent_core-1.4.so.2.1.3
lrwxrwxrwx 1 root root 27 2009-07-19 08:45 libevent_extra-1.4.so.2 -> libevent_extra-1.4.so.2.1.3
-rwxr-xr-x 1 root root 239933 2009-07-19 08:45 libevent_extra-1.4.so.2.1.3
-rw-r--r-- 1 root root 298406 2009-07-19 08:45 libevent_extra.a
-rwxr-xr-x 1 root root 867 2009-07-19 08:45 libevent_extra.la
lrwxrwxrwx 1 root root 27 2009-07-19 08:45 libevent_extra.so -> libevent_extra-1.4.so.2.1.3
-rwxr-xr-x 1 root root 825 2009-07-19 08:45 libevent.la
lrwxrwxrwx 1 root root 21 2009-07-19 08:45 libevent.so -> libevent-1.4.so.2.1.3
1 2 3 4 5 |
wget http://www.monkey.org/~provos/libevent-2.0.13-stable.tar.gz tar xzvf libevent-2.0.13-stable.tar.gz ./configure make make install |
1)安裝Memcache服務端
sudo apt-get install memcached
安裝完Memcache服務端之後,咱們須要啓動該服務:
memcached -d -m 128 -p 11111 -u root
這裏須要說明一下memcached服務的啓動參數:
-p 監聽的端口
-l 鏈接的IP地址, 默認是本機
-d start 啓動memcached服務
-d restart 重起memcached服務
-d stop|shutdown 關閉正在運行的memcached服務
-d install 安裝memcached服務
-d uninstall 卸載memcached服務
-u 以的身份運行 (僅在以root運行的時候有效)
-m 最大內存使用,單位MB。默認64MB
-M 內存耗盡時返回錯誤,而不是刪除項
-c 最大同時鏈接數,默認是1024
-f 塊大小增加因子,默認是1.25-n 最小分配空間,key+value+flags默認是48
-h 顯示幫助
查看是否創建成功
telnet測試memcached
telnet 192.168.1.2 11211
Trying 192.168.1.2...
Connected to 192.168.1.2.
Escape character is '^]'
查看版本
version
…
對Memcached緩存服務的狀態查詢,能夠先telnet鏈接上服務:telnet 127.0.0.1 11211 ,而後使用 stats命令查看緩存服務的狀態,會返回以下的數據:
time: 1255537291 服務器當前的unix時間戳
total_items: 54 從服務器啓動之後存儲的items總數量
connection_structures: 19 服務器分配的鏈接構造數
version: 1.2.6 memcache版本
limit_maxbytes: 67108864 分配給memcache的內存大小(字節)
cmd_get: 1645 get命令(獲取)總請求次數
evictions: 0 爲獲取空閒內存而刪除的items數(分配給memcache的空間用滿後需
要刪除舊的items來獲得空間分配給新的items)
total_connections: 19 從服務器啓動之後曾經打開過的鏈接數
bytes: 248723 當前服務器存儲items佔用的字節數
threads: 1 當前線程數
get_misses: 82 總未命中次數
pointer_size: 32 當前操做系統的指針大小(32位系統通常是32bit)
bytes_read: 490982 總讀取字節數(請求字節數)
uptime: 161 服務器已經運行的秒數
curr_connections: 18 當前打開着的鏈接數
pid: 2816 memcache服務器的進程ID
bytes_written: 16517259 總髮送字節數(結果字節數)
get_hits: 1563 總命中次數
cmd_set: 54 set命令(保存)總請求次數
curr_items: 28 服務器當前存儲的items數量
Ok,安裝memcached1.4.5成功。
初始化:memcache
能夠從這裏下載:http://jehiah.cz/projects/memcached-win32/。
4、 原理與部署
1. magent的hash算法
magent採用的是:Consistent Hashing原理,Consistent Hashing以下所示:首先求出memcached服務器(節點)的哈希值, 並將其配置到0~232的圓(continuum)上。 而後用一樣的方法求出存儲數據的鍵的哈希值,並映射到圓上。而後從數據映射到的位置開始順時針查找,將數據保存到找到的第一個服務器上。 若是超過232仍然找不到服務器,就會保存到第一臺memcached服務器上。
從上圖的狀態中添加一臺memcached服務器。餘數分佈式算法因爲保存鍵的服務器會發生巨大變化 而影響緩存的命中率,但Consistent Hashing中,只有在continuum上增長服務器的地點逆時針方向的第一臺服務器上的鍵會受到影響。
2. 部署示意圖
Java開發中的Memcache原理及實現(四)原理與部署
5、 測試Memcached流程
此處以二機集羣爲例。
1. 啓動Memcached及代理
啓動兩個memcached進程,端口分別爲11211和11212:
memcached -m 1 -u root -d -l 127.0.0.1 -p 11211
memcached -m 1 -u root -d -l 127.0.0.1 -p 11212
再啓動兩個magent進程,端口分別爲10000和11000:
magent -u root -n 51200 -l 127.0.0.1 -p 10000 -s 127.0.0.1:11211 -b 127.0.0.1:11212
magent -u root -n 51200 -l 127.0.0.1 -p 11000 -s 127.0.0.1:11212 -b 127.0.0.1:11211
-s 爲要寫入的memcached, -b 爲備份用的memcached。
說明:測試環境用magent和memached的不一樣端口來實現,在生產環境中能夠將magent和memached做爲一組放到兩臺服務器上。也就是說經過magent可以寫入兩個memcached。
2. 數據讀寫測試
[root@odb ~]# telnet 127.0.0.1 10000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
set key 0 0 8 <—在10000端口設置key的值
88888888
STORED
quit
Connection closed by foreign host.
[root@odb ~]# telnet 127.0.0.1 11211
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
get key <—在11211端口獲取key的值成功
VALUE key 0 8
88888888
END
quit
Connection closed by foreign host.
[root@odb ~]# telnet 127.0.0.1 11212
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
get key <—在11212端口獲取key的值成功
VALUE key 0 8
88888888
END
quit
Connection closed by foreign host.
3. 高可靠性測試
[root@odb ~]# ps aux |grep -v grep |grep memcached
root 23455 0.0 0.0 5012 1796 ? Ss 09:22 0:00 memcached -m 1 -u root -d -l 127.0.0.1 -p 11212
root 24950 0.0 0.0 4120 1800 ? Ss 10:58 0:00 memcached -m 1 -u root -d -l 127.0.0.1 -p 11211
[root@odb ~]# ps aux |grep -v grep |grep ‘magent -u’
root 25919 0.0 0.0 2176 484 ? Ss 12:00 0:00 magent -u root -n 51200 -l 127.0.0.1 -p 10000 -s 127.0.0.1:11211 -b 127.0.0.1:11212
root 25925 0.0 0.0 3004 484 ? Ss 12:00 0:00 magent -u root -n 51200 -l 127.0.0.1 -p 11000 -s 127.0.0.1:11212 -b 127.0.0.1:11211
[root@odb ~]# telnet 127.0.0.1 10000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
set stone 0 0 6 <—在10000端口設置stone的值
123456
STORED
quit
Connection closed by foreign host.
[root@odb ~]# telnet 127.0.0.1 11000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
set shidl 0 0 6 <—在11000端口設置shidl的值
666666
STORED
get stone <—在11000端口獲取stone的值成功
VALUE stone 0 6
123456
END
incr stone 2 <—在11000端口修改stone的值成功
123458
get stone
VALUE stone 0 6 <—在11000端口驗證stone的值,證實上面的修改爲功
123458
END
get shidl <—在11000端口獲取shidl的值成功
VALUE shidl 0 6
666666
END
quit <—退出11000端口
Connection closed by foreign host.
[root@odb ~]# telnet 127.0.0.1 10000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
get stone <—在10000端口獲取stone的值,已被修改
VALUE stone 0 6
123458
END
get shidl <—在10000端口獲取shidl的值成功
VALUE shidl 0 6
666666
END
delete shidl <—在10000端口刪除shidl
DELETED
get shidl <—在10000端口刪除shidl生效
END
quit
Connection closed by foreign host.
[root@odb ~]# telnet 127.0.0.1 11000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
get shidl <—在11000端口驗證刪除shidl生效
END
get stone <—在11000端口獲取stone的值成功
VALUE stone 0 6
123458
END
quit
Connection closed by foreign host.
4. Down機模擬測試1
1) Down掉11211端口的memcached
[root@odb ~]# kill -9 24950
[root@odb ~]# telnet 127.0.0.1 10000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
get stone <—在10000依然能夠獲取stone的值
VALUE stone 0 6
123458
END
quit
Connection closed by foreign host.
[root@odb ~]# telnet 127.0.0.1 11000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
get stone <—在11000依然能夠獲取stone的值
VALUE stone 0 6
123458
END
quit
Connection closed by foreign host.
5. Down機模擬測試2
1) Down掉11000端口的magent
[root@odb ~]# kill -9 25925
[root@odb ~]# telnet 127.0.0.1 10000
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
get stone <—在10000依然能夠獲取stone的值
VALUE stone 0 6
123458
END
quit
Connection closed by foreign host.
2) 重啓11000端口的magent
[root@lh-web-test memcached-1.4.5]# magent -u root -n 51200 -l 127.0.0.1 -p 11000 -s 127.0.0.1:11212 -b 127.0.0.1:11211
[root@lh-web-test memcached-1.4.5]# telnet 127.0.0.1 11000
Trying 127.0.0.1...
Connected to localhost.localdomain (127.0.0.1).
Escape character is '^]'.
get stone <—在11000依然能夠獲取stone的值
VALUE stone 0 6
123458
END
quit
Connection closed by foreign host.
Memcached的java客戶端已經存在三種了:
? 官方提供的基於傳統阻塞io由Greg Whalin維護的客戶端
? Dustin Sallings實現的基於java nio的Spymemcached
? XMemcached
較早推出的memcached JAVA客戶端API,應用普遍,運行比較穩定。
A simple, asynchronous, single-threaded memcached client written in java. 支持異步,單線程的memcached客戶端,用到了java1.5版本的concurrent和nio,存取速度會高於前者,可是穩定性很差,測試中常報timeOut等相關異常。
XMemcached一樣是基於java nio的客戶端,java nio相比於傳統阻塞io模型來講,有效率高(特別在高併發下)和資源耗費相對較少的優勢。傳統阻塞IO爲了提升效率,須要建立必定數量的鏈接造成鏈接池,而nio僅須要一個鏈接便可(固然,nio也是能夠作池化處理),相對來講減小了線程建立和切換的開銷,這一點在高併發下特別明顯。所以XMemcached與Spymemcached在性能都很是優秀,在某些方面(存儲的數據比較小的狀況下)Xmemcached比Spymemcached的表現更爲優秀,具體能夠看這個Java Memcached Clients Benchmark。
因爲memcached client for java發佈了新版本,性能上有所提升,而且運行穩定,因此建議使用memcached client for java。
XMemcached也使用得比較普遍,並且有較詳細的中文API文檔,具備以下特色:高性能、支持完整的協議、支持客戶端分佈、容許設置節點權重、動態增刪節點、支持JMX、與Spring框架和Hibernate-memcached的集成、客戶端鏈接池、可擴展性好等。
下面給出這三種客戶端的示例程序。
從前面介紹的Java環境的Memcached客戶端程序項目網址裏,下載最新版的客戶端程序包:java_memcached-release_2.5.1.zip,解壓後,文件夾裏找到java_memcached-release_2.5.1.jar,這個就是客戶端的JAR包。將此JAR包添加到項目的構建路徑裏,則項目中,就可使用Memcached了。
示例代碼以下:
package temp;
import com.danga.MemCached.*;
import org.apache.log4j.*;
public class CacheTest {
public static void main(String[] args) {
/**
* 初始化SockIOPool,管理memcached的鏈接池
* */
String[] servers = { "10.11.15.222:10000" };
SockIOPool pool = SockIOPool.getInstance();
pool.setServers(servers);
pool.setFailover(true);
pool.setInitConn(10);
pool.setMinConn(5);
pool.setMaxConn(250);
pool.setMaintSleep(30);
pool.setNagle(false);
pool.setSocketTO(3000);
pool.setAliveCheck(true);
pool.initialize();
/**
* 創建MemcachedClient實例
* */
MemCachedClient memCachedClient = new MemCachedClient();
for (int i = 0; i < 1000; i++) {
/**
* 將對象加入到memcached緩存
* */
boolean success = memCachedClient.set("" + i, "Hello!");
/**
* 從memcached緩存中按key值取對象
* */
String result = (String) memCachedClient.get("" + i);
System.out.println(String.format("set( %d ): %s", i, success));
System.out.println(String.format("get( %d ): %s", i, result));
}
}
}
spymemcached當前版本是2.5版本,官方網址是:http://code.google.com/p/spymemcached/。能夠從地址:http://spymemcached.googlecode.com/files/memcached-2.5.jar下載最新版原本使用。
示例代碼以下:
package temp;
import java.net.InetSocketAddress;
import java.util.concurrent.Future;
import net.spy.memcached.MemcachedClient;
public class TestSpyMemcache {
public static void main(String[] args) {
// 保存對象
try {
/* 創建MemcachedClient 實例,並指定memcached服務的IP地址和端口號 */
MemcachedClient mc = new MemcachedClient(new InetSocketAddress("10.11.15.222", 10000));
Future<Boolean> b = null;
/* 將key值,過時時間(秒)和要緩存的對象set到memcached中 */
b = mc.set("neea:testDaF:ksIdno", 900, "someObject");
if (b.get().booleanValue() == true) {
mc.shutdown();
}
} catch (Exception ex) {
ex.printStackTrace();
}
// 取得對象
try {
/* 創建MemcachedClient 實例,並指定memcached服務的IP地址和端口號 */
MemcachedClient mc = new MemcachedClient(new InetSocketAddress("10.11.15.222", 10000));
/* 按照key值從memcached中查找緩存,不存在則返回null */
Object b = mc.get("neea:testDaF:ksIdno");
System.out.println(b.toString());
mc.shutdown();
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
Xmemcached的官方網址是:http://code.google.com/p/xmemcached/,能夠從其官網上下載最新版本的1.2.4來使用。地址是:http://xmemcached.googlecode.com/files/xmemcached-1.2.4-src.tar.gz。
示例代碼以下:
package temp;
import java.io.IOException;
import java.util.concurrent.TimeoutException;
import net.rubyeye.xmemcached.utils.AddrUtil;
import net.rubyeye.xmemcached.MemcachedClient;
import net.rubyeye.xmemcached.MemcachedClientBuilder;
import net.rubyeye.xmemcached.XMemcachedClientBuilder;
import net.rubyeye.xmemcached.exception.MemcachedException;
public class TestXMemcache {
public static void main(String[] args) {
MemcachedClientBuilder builder = new XMemcachedClientBuilder(AddrUtil
.getAddresses("10.11.15.222:10000"));
MemcachedClient memcachedClient;
try {
memcachedClient = builder.build();
memcachedClient.set("hello", 0, "Hello,xmemcached");
String value = memcachedClient.get("hello");
System.out.println("hello=" + value);
memcachedClient.delete("hello");
value = memcachedClient.get("hello");
System.out.println("hello=" + value);
// close memcached client
memcachedClient.shutdown();
} catch (MemcachedException e) {
System.err.println("MemcachedClient operation fail");
e.printStackTrace();
} catch (TimeoutException e) {
System.err.println("MemcachedClient operation timeout");
e.printStackTrace();
} catch (InterruptedException e) {
// ignore
}catch (IOException e) {
System.err.println("Shutdown MemcachedClient fail");
e.printStackTrace();
}
}
}
(八) 64位機器安裝Memcache
1. 安裝
在64位的機器上安裝Memcache和在32位的機器上安裝的操做是同樣的。在安裝的過程當中,可使用以下的命令來查看安裝是否成功,以進行確認。
1) 確認libevent安裝
查看libevent是否安裝成功:
# ls -al /usr/lib | grep libevent
在命令行出現以下信息,代表安裝成功:
lrwxrwxrwx 1 root root 21 Mar 22 18:41 libevent-1.2.so.1 -> libevent-1.2.so.1.0.3
-rwxr-xr-x 1 root root 262475 Mar 22 18:41 libevent-1.2.so.1.0.3
-rw-r--r-- 1 root root 430228 Mar 22 18:41 libevent.a
-rwxr-xr-x 1 root root 811 Mar 22 18:41 libevent.la
lrwxrwxrwx 1 root root 21 Mar 22 18:41 libevent.so -> libevent-1.2.so.1.0.3
2) 確認memcache安裝
查看memcache是否安裝成功:
# ls -al /usr /bin/mem*
在命令行出現以下信息,代表安裝成功:
-rwxr-xr-x 1 root root 114673 Mar 22 18:52 /usr/local/src/memcached
-rwxr-xr-x 1 root root 120092 Mar 22 18:52 /usr/local/src/memcached-debug
2. 64位的問題及修復
1) 問題
安裝完成了,如今咱們看一下memcache的幫助:
#/usr/local/src/memecached -h
這時候出現了以下錯誤:
memcached: error while loading shared libraries: libevent-1.2.so.1: cannot open shared object file: No such file or directory
2) 修復
下面說下修復過程:
#LD_DEBUG=libs memcached -v #查看memcached的libs的路徑
在命令上出現了以下信息:
5427: find library=libevent-1.2.so.1 [0]; searching
5427: search cache=/etc/ld.so.cache
5427: search path=/lib64/tls/x86_64:/lib64/tls:/lib64/x86_64:/lib64:/usr/lib64/tls/x86_64:/usr/lib64/tls:/usr/lib64/x86_64:
/usr/lib64 (system search path)
5427: trying file=/lib64/tls/x86_64/libevent-1.2.so.1
5427: trying file=/lib64/tls/libevent-1.2.so.1
5427: trying file=/lib64/x86_64/libevent-1.2.so.1
5427: trying file=/lib64/libevent-1.2.so.1
5427: trying file=/usr/lib64/tls/x86_64/libevent-1.2.so.1
5427: trying file=/usr/lib64/tls/libevent-1.2.so.1
5427: trying file=/usr/lib64/x86_64/libevent-1.2.so.1
5427: trying file=/usr/lib64/libevent-1.2.so.1
5427: memcached: error while loading shared libraries: libevent-1.2.so.1: cannot open shared object file: No such file or directory
如今應該記錄下來libs的位置,我選擇的是trying file=/usr/lib64/libevent-1.2.so.1,如今咱們利用這個來作個符號連接:
# ln -s /usr/lib/libevent-1.4.so.2 /usr/lib64/libevent-1.4.so.2
下面咱們繼續使用memcached -h作下測試,終於出現了以下信息:
memcached 1.2.0
-p <num> port number to listen on
-s <file> unix socket path to listen on (disables network support)
-l <ip_addr> interface to listen on, default is INDRR_ANY
-d run as a daemon
-r maximize core file limit
-u <username> assume identity of <username> (only when run as root)
-m <num> max memory to use for items in megabytes, default is 64 MB
-M return error on memory exhausted (rather than removing items)
-c <num> max simultaneous connections, default is 1024
-k lock down all paged memory
-v verbose (print errors/warnings while in event loop)
-vv very verbose (also print client commands/reponses)
-h print this help and exit
-i print memcached and libevent license
-b run a managed instanced (mnemonic: buckets)
-P <file> save PID in <file>, only used with -d option
-f <factor> chunk size growth factor, default 1.25
-n <bytes> minimum space allocated for key+value+flags, default 48
說明memcached安裝成功。(應該是機器是64位的緣由,因此將so文件放到了lib64下面,而不是lib下面,使得memcached找不到了so文件)。
下面,咱們來啓動一個Memcached的服務器端:
# /usr/local/src/memcached -d -m 10 -u root -l 192.168.0.200 -p 12000 -c 256 -P /tmp/memcached.pid
在這裏簡單介紹一下Windows下的Memcache的安裝:
1. 下載memcache的windows穩定版,解壓放某個盤下面,好比在c:\memcached
2. 在終端(也即cmd命令界面)下輸入‘c:\memcached\memcached.exe -d install’安裝
3. 再輸入:‘c:\memcached\memcached.exe -d start’啓動。NOTE: 之後memcached將做爲windows的一個服務每次開機時自動啓動。這樣服務器端已經安裝完畢了。
? -p 監聽的端口
? -l 鏈接的IP地址, 默認是本機
? -d start 啓動memcached服務
? -d restart 重起memcached服務
? -d stop|shutdown 關閉正在運行的memcached服務
? -d install 安裝memcached服務
? -d uninstall 卸載memcached服務
? -u 以的身份運行 (僅在以root運行的時候有效)
? -m 最大內存使用,單位MB。默認64MB
? -M 內存耗盡時返回錯誤,而不是刪除項
? -c 最大同時鏈接數,默認是1024
? -f 塊大小增加因子,默認是1.25
? -n 最小分配空間,key+value+flags默認是48
? -h 顯示幫助
Memcache的默認啓動時的參數可能不知足實際生產環境的須要,因而就想到直接修改windows服務的啓動參數,操做以下:
打開註冊表,找到:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server
其中的ImagePath項的值爲: c:\memcached\memcached.exe" -d runservice
改爲:c:\memcached\memcached.exe" -p 12345 -m 128 -d runservice
其中,-p就是端口,-m就是緩存大小,以M爲單位。
一、因爲memcached是基於libevent的,所以須要安裝libevent,libevent-devel
- # yum install libevent libevent-devel -y
二、下載並解壓memcached-1.4.5
memcached官方網站是:http://memcached.org/
- # cd /root
- # wget http://memcached.googlecode.com/files/memcached-1.4.5.tar.gz
- # tar -xvzf memcached-1.4.5.tar.gz
三、編譯安裝memcached-1.4.5
- # cd memcached-1.4.5
- # ./configure --prefix=/etc/memcached
- # make
- # make install
四、配置環境變量
進入用戶宿主目錄,編輯.bash_profile,爲系統環境變量LD_LIBRARY_PATH增長新的目錄,須要增長的內容以下:
# vi .bash_profile
- MEMCACHED_HOME=/etc/memcached
- export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$MEMCACHED_HOME/lib
刷新用戶環境變量:# source .bash_profile
五、編寫memcached服務啓停腳本
# cd /etc/init.d
vi memcached,腳本內容以下:
- #!/bin/sh
- #
- # Startup script for the server of memcached
- #
- # processname: memcached
- # pidfile: /etc/memcached/memcached.pid
- # logfile: /etc/memcached/memcached_log.txt
- # memcached_home: /etc/memcached
- # chkconfig: 35 21 79
- # description: Start and stop memcached Service
- # Source function library
- . /etc/rc.d/init.d/functions
- RETVAL=0
- prog="memcached"
- basedir=/etc/memcached
- cmd=${basedir}/bin/memcached
- pidfile="$basedir/${prog}.pid"
- #logfile="$basedir/memcached_log.txt"
- # 設置memcached啓動參數
- ipaddr="192.168.1.201" # 綁定偵聽的IP地址
- port="11211" # 服務端口
- username="root" # 運行程序的用戶身份
- max_memory=64 # default: 64M | 最大使用內存
- max_simul_conn=1024 # default: 1024 | 最大同時鏈接數
- #maxcon=51200
- #growth_factor=1.3 # default: 1.25 | 塊大小增加因子
- #thread_num=6 # default: 4
- #verbose="-vv" # 查看詳細啓動信息
- #bind_protocol=binary # ascii, binary, or auto (default)
- start() {
- echo -n $"Starting service: $prog"
- $cmd -d -m $max_memory -u $username -l $ipaddr -p $port -c $max_simul_conn -P $pidfile
- RETVAL=$?
- echo
- [ $RETVAL -eq 0 ] && touch /var/lock/subsys/$prog
- }
- stop() {
- echo -n $"Stopping service: $prog "
- run_user=`whoami`
- pidlist=`ps -ef | grep $run_user | grep memcached | grep -v grep | awk '{print($2)}'`
- for pid in $pidlist
- do
- # echo "pid=$pid"
- kill -9 $pid
- if [ $? -ne 0 ]; then
- return 1
- fi
- done
- RETVAL=$?
- echo
- [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/$prog
- }
- # See how we were called.
- case "$1" in
- start)
- start
- ;;
- stop)
- stop
- ;;
- #reload)
- # reload
- # ;;
- restart)
- stop
- start
- ;;
- #condrestart)
- # if [ -f /var/lock/subsys/$prog ]; then
- # stop
- # start
- # fi
- # ;;
- status)
- status memcached
- ;;
- *)
- echo "Usage: $0 {start|stop|restart|status}"
- exit 1
- esac
- exit $RETVAL
設置腳本可被執行:# chmod +x memcached
六、設置memcached隨系統啓動
- # chkconfig --add memcached
- # chkconfig --level 35 memcached on
- # service memcached start
- //啓動的時候其實是調用了下面的這個命令,以守護進程的方式來啓動memcached
- /etc/memcached/bin/memcached -d -m 64 -u root -l 192.168.1.201
- \-p 11211 -c 1024 -P /etc/memcached/memcached.pid
查看memcached是否啓動:
# ps -ef | grep memcached
參數 | 參數解釋及說明 |
-p <num> | 監聽的端口 |
-l <ip_addr> | 鏈接的IP地址,,默認是本機。-l選項能夠不使用,此時表示在全部網絡接口地址上監聽。建議是-l <ip_addr>指定一個內部網絡IP地址,以免成爲外部網絡攻擊的對象 |
-d start | 啓動memcached 服務 |
-d restart | 重起memcached 服務 |
-d stop|shutdown | 關閉正在運行的memcached 服務 |
-d install | 安裝memcached 服務 |
-d uninstall | 卸載memcached 服務 |
-u <username> | 以<username>的身份運行 (僅在以root運行的時候有效) |
-m <num> | 最大內存使用,單位MB。默認64MB |
-M | 內存耗盡時返回錯誤,而不是刪除項 |
-c <num> | 最大同時鏈接數,默認是1024 |
-f <factor> | 塊大小增加因子,默認是1.25 |
-n <bytes> | 最小分配空間,key+value+flags默認是48 |
-h | 顯示幫助 |