Memcached作為一個(gè)高并發(fā)內(nèi)存Cached系統(tǒng)被很多大公司使用,最近也一直在用Memcached做項(xiàng)目也積累了一些相關(guān)經(jīng)驗(yàn)。
Install
Memcached的安裝很簡(jiǎn)單,在Ubuntu下面一行命令搞定。
Start
實(shí)際使用的時(shí)候,memcached需要調(diào)整內(nèi)存大小和端口號(hào)等命令,則啟動(dòng)的使用時(shí)用以下的Command就行。
-p 指定端口號(hào)
-m 指定內(nèi)存大小
-d 作為daemon在后臺(tái)啟動(dòng)
如果想trouble shotting 則加 -vv
Test
Test也很簡(jiǎn)單,安裝官網(wǎng)的命令就行
里面就能Get和Set了。
Use in Java
由于項(xiàng)目是java的,所以以java為例子來介紹Java下Memcached的使用。
Java下Memcached的客戶端很多,這里介紹spymemcached
spymemcached的使用很簡(jiǎn)單,在maven項(xiàng)目下面,我們加入如下依賴。
這樣我們就能對(duì)Memcached操作了。
private static MemcachedClient MEMCACHED_CLIENT;
static {
try {
MEMCACHED_CLIENT = new MemcachedClient(
AddrUtil.getAddresses("localhost1:11211 localhost2:11211"));
} catch (Exception e) {
System.err.println("Cannot init MEMCACHED Memcached Client");
}
}
public static void set(String key, String value,Integer expireTime ) throws Exception {
MEMCACHED_CLIENT.set(key, expireTime, value);
}
public static String get(String key) throws Exception {
Object value = MEMCACHED_CLIENT.get(key);
if (null != value)
return value.toString();
return null;
}
}
Monitor
我們可以通過以下簡(jiǎn)單的命令得知Memcached的運(yùn)行狀況,以此為擴(kuò)充可以實(shí)現(xiàn)簡(jiǎn)單的Memcached檢測(cè)shell。
Conclusion
Memcached實(shí)際使用下來簡(jiǎn)單易用,各個(gè)平臺(tái)上面也有相應(yīng)的Client.
但有時(shí)高并發(fā)可能會(huì)出現(xiàn)Timeout的情況,導(dǎo)致緩沖沒辦法命中的情況,具體原因還需要進(jìn)一步調(diào)查。
Memcahed的作者最近用Go語言去寫了groupcache很值得關(guān)注。
新聞熱點(diǎn)
疑難解答
圖片精選