1. 程式人生 > >JAVA MemCache 史無前例的詳細講解!看完包精通MEMCACHE!

JAVA MemCache 史無前例的詳細講解!看完包精通MEMCACHE!

分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow

也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!

                 

JAVA MemCache 史無前例的詳細講解!看完包精通MEMCACHE!

分類: 高併發_效能
  5051人閱讀  評論(0)  收藏  舉報 java string object 快取伺服器 快取系統 windows

目錄(?)[+]

 Memcach什麼是Memcache

Memcache叢集環境下快取解決方案

Memcache是一個高效能的分散式的記憶體物件快取系統,通過在記憶體裡維護一個統一的巨大的hash表,它能夠用來儲存各種格式的資料,包括影象、視訊、檔案以及資料庫檢索的結果等。簡單的說就是將資料呼叫到記憶體中,然後從記憶體中讀取,從而大大提高讀取速度。  

Memcache是danga的一個專案,最早是LiveJournal 服務的,最初為了加速 LiveJournal 訪問速度而開發的,後來被很多大型的網站採用。  

Memcached是以守護程式方式運行於一個或多個伺服器中,隨時會接收客戶端的連線和操作


為什麼會有Memcache和memcached兩種名稱

其實Memcache是這個專案的名稱,而memcached是它伺服器端的主程式檔名,知道我的意思了吧。一個是專案名稱,一個是主程式檔名,在網上看到了很多人不明白,於是混用了。



Memcached是高效能的,分散式的記憶體物件快取系統,用於在動態應用中減少資料庫負載,提升訪問速度。Memcached由Danga Interactive開發,用於提升LiveJournal.com訪問速度的。LJ每秒動態頁面訪問量幾千次,使用者700萬。Memcached將資料庫負載大幅度降低,更好的分配資源,更快速訪問。


    上網baidu了很多東西,幾乎都差不多,而且基於java的說的很少,所有隻有在研究了各個其他語言類的應用後再來嘗試在java上進行簡單的操作應用。先從memcached上進行說明,memcached的最新版是採用c語言進行開發和設計的,據說舊版的是採用perl語言開發的,而且它是一個應用軟體來的,是作為快取伺服器的伺服器端執行在伺服器上的,需要使用特定的語言編寫客戶端與其進行通訊來進行資料的快取和獲取。通常我們是把memcached安裝執行在web伺服器上,然後通過對需要的資料進行快取,據我目前所知,所有資料的快取設定和存取操作,以及資料的更新後替換操作全部需要程式來進行,而不是自動進行的(自動不知道能不能成功,呵呵)。下面從一個實際的例子來應用memcached。

    如何要下載的話,到http://danga.com/memcached/下載memcached。


Ubuntu下安裝Memcached

編譯前,請先確認gcc、make、patch等編譯工具是否已安裝,並可正常使用。

  安裝Libevent

  Libevent是一個非同步事件處理軟體函式庫,以BSD許可證釋出。Memcached依賴Libevent,因此必須先編譯安裝Libevent。


檢測libevent 安裝是否成功,輸入:# ls -al /usr/lib | grep libevent  會出現如下結果(不同的機器可能有不同的輸出):

   [email protected]:~$ 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



? View Code BASH
12345
wget http://www.monkey.org/~provos/libevent-2.0.13-stable.tar.gztar xzvf  libevent-2.0.13-stable.tar.gz./configuremakemake 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 

Java程式碼   收藏程式碼
  1. static {  
  2.         String[] serverlist = { "server1.com:port""server2.com:port" };  
  3.    
  4.         SockIOPool pool = SockIOPool.getInstance();  
  5.         pool.setServers(serverlist);  
  6.         pool.initialize();  
  7.  }  
  8.    

建立一個client物件: 
Java程式碼   收藏程式碼
  1. MemCachedClient mc = new MemCachedClient();  

建立一個快取: 
Java程式碼   收藏程式碼
  1. MemCachedClient mc = new MemCachedClient();  
  2.  String key = "cacheKey1";  
  3.  Object value = SomeClass.getObject();  
  4.  mc.set(key, value);  

通過key刪除一個快取: 
Java程式碼   收藏程式碼
  1. MemCachedClient mc = new MemCachedClient();  
  2.  String key = "cacheKey1";  
  3.  mc.delete(key);  

通過key獲取快取物件: 
Java程式碼   收藏程式碼
  1. MemCachedClient mc = new MemCachedClient();  
  2.  String key = "key";  
  3.  Object value = mc.get(key);  

獲取多個快取物件: 
Java程式碼   收藏程式碼
  1. MemCachedClient mc = new MemCachedClient();  
  2.  String[] keys = { "key""key1""key2" };  
  3.  Map<Object> values = mc.getMulti(keys);  

重新整理全部快取: 
Java程式碼   收藏程式碼
  1. MemCachedClient mc = new MemCachedClient();  
  2.  mc.flushAll(); 


3. 如何在Java開發中使用Memcache

在Java開發中使用Memcache,一般要用到以下幾個程式:

1)      Memcached

該程式用來在Linux或Windows伺服器上建立和管理快取。

其專案網址為:http://danga.com/memcached/。

2)      Magent

Magent是一款開源的Memcached代理伺服器軟體,使用它可以搭建高可用性的叢集應用的Memcached服務,其專案網址為:http://code.google.com/p/memagent/。

3)      Memcached客戶端程式

至於Memcached的客戶端程式,一般推薦用memcached client for java,為什麼推薦用這種客戶端,後面會講到具體的原因,其專案的網址為:http://github.com/gwhalin/Memcached-Java-Client/。

4)      其它程式
i.              Libevent

在Linux環境下應用Memcache時,Memcache用到了libevent這個庫,用於Socket的處理,所以還需要安裝libevent。libevent的最新版本是libevent-1.4.13。(如果你的系統已經安裝了libevent,可以不用安裝)。

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

下載:http://www.monkey.org/~provos/libevent-1.4.13-stable.tar.gz

ii.              Windows下的安裝程式

Memcache也可以安裝在Windows伺服器下,安裝程式:memcached-1.2.1-win32.zip

可以從這裡下載:http://jehiah.cz/projects/memcached-win32/。



四、            原理與部署
1. magent的hash演算法

magent採用的是:Consistent Hashing原理,Consistent Hashing如下所示:首先求出memcached伺服器(節點)的雜湊值, 並將其配置到0~232的圓(continuum)上。 然後用同樣的方法求出儲存資料的鍵的雜湊值,並對映到圓上。然後從資料對映到的位置開始順時針查詢,將資料儲存到找到的第一個伺服器上。 如果超過232仍然找不到伺服器,就會儲存到第一臺memcached伺服器上。

從上圖的狀態中新增一臺memcached伺服器。餘數分散式演算法由於儲存鍵的伺服器會發生巨大變化 而影響快取的命中率,但Consistent Hashing中,只有在continuum上增加伺服器的地點逆時針方向的第一臺伺服器上的鍵會受到影響。

2. 部署示意圖

Java開發中的Memcache原理及實現(四)原理與部署 


Java開發中的Memcache原理及實現(四)原理與部署 - jiaxiaoyuan1204 - 關注程式碼、關注生活--小元



3. 搭建memcache叢集服務

利用magent實現對memecache的分散式管理,搭建一套memcache叢集服務:

?  前端java對magent的訪問跟對memcache訪問相同,不需要做任何更改,對於插入的key,magent會把值雜湊到各個memcache服務上,只操作magent,不用關心後端處理;

?  專案應用:以深圳電信為例,其商呼系統如圖部署三臺機器做為叢集,假設IP分別是:10.11.15.31, 10.11.15.32, 10.11.15.33;

?  每個前端安裝memcached服務(大記憶體機器可以啟動多個服務),如埠都為12001,每個前端都安裝magent服務,埠都為12000,後端掛載全部機器的memcached服務,

?  啟動引數示例:magent -p 12000 -s 10.11.15.31:12001 -s 10.11.15.32:12001 -s 10.11.15.33:12001,這裡將三臺機器都配置進來,如集叢集增加了機器,只需要在啟動引數裡新增進來即可。所有前端配置都是相同的,任何一個前端只需訪問本地埠的magent,這樣的memcache叢集對應用帶來很大便利。

?  這種部署可以解決session共享的應用

專案中多處已經實際應用,magent對memcache的均衡和穩定性都非常不錯,推薦使用。


五、            測試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. 資料讀寫測試

[[email protected] ~]# 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.

 

[[email protected] ~]# 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.

 

[[email protected] ~]# 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. 高可靠性測試

[[email protected] ~]# 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

[[email protected] ~]# 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

 

[[email protected] ~]# 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.

 

[[email protected] ~]# 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.

 

[[email protected] ~]# 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.

 

[[email protected] ~]# 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

[[email protected] ~]# kill -9 24950

[[email protected] ~]# 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.

 

[[email protected] ~]# 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

[[email protected] ~]# kill -9 25925

[[email protected] ~]# 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

[[email protected] 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

[[email protected] 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客戶端程式

Memcached的java客戶端已經存在三種了:

?  官方提供的基於傳統阻塞io由Greg Whalin維護的客戶端

?  Dustin Sallings實現的基於java nio的Spymemcached

?  XMemcached


1. 三種API比較 
1)      memcached client for java

較早推出的memcached JAVA客戶端API,應用廣泛,執行比較穩定。


2)      spymemcached

A simple, asynchronous, single-threaded memcached client written in java. 支援非同步,單執行緒的memcached客戶端,用到了java1.5版本的concurrent和nio,存取速度會高於前者,但是穩定性不好,測試中常報timeOut等相關異常。


3)      xmemcached

XMemcached同樣是基於java nio的客戶端,java nio相比於傳統阻塞io模型來說,有效率高(特別在高併發下)和資源耗費相對較少的優點。傳統阻塞IO為了提高效率,需要建立一定數量的連線形成連線池,而nio僅需要一個連線即可(當然,nio也是可以做池化處理),相對來說減少了執行緒建立和切換的開銷,這一點在高併發下特別明顯。因此XMemcached與Spymemcached在效能都非常優秀,在某些方面(儲存的資料比較小的情況下)Xmemcached比Spymemcached的表現更為優秀,具體可以看這個Java Memcached Clients Benchmark。


2.  建議

由於memcached client for java釋出了新版本,效能上有所提高,並且執行穩定,所以建議使用memcached client for java。

XMemcached也使用得比較廣泛,而且有較詳細的中文API文件,具有如下特點:高效能、支援完整的協議、支援客戶端分佈、允許設定節點權重、動態增刪節點、支援JMX、與Spring框架和Hibernate-memcached的整合、客戶端連線池、可擴充套件性好等。

下面給出這三種客戶端的示例程式。


3.  示例程式
1)      memcached client for java

從前面介紹的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));

       }

    }

}


2)      spymemcached

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();

       }

    }

}


3)      xmemcached

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.  安裝

在這裡簡單介紹一下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的一個服務每次開機時自動啟動。這樣伺服器端已經安裝完畢了。


2.  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 顯示幫助


3.  設定Memcache快取大小和埠

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為單位。

在CentOS 5.6上編譯安裝Memcached

1、由於memcached是基於libevent的,因此需要安裝libevent,libevent-devel


   
    view plain   
    copy
   
   
  1. # yum install libevent libevent-devel -y 

2、下載並解壓memcached-1.4.5

memcached官方網站是:http://memcached.org/


   
    view plain   
    copy
   
   
  1. # cd /root 
  2. # wget http://memcached.googlecode.com/files/memcached-1.4.5.tar.gz 
  3. # tar -xvzf  memcached-1.4.5.tar.gz 

3、編譯安裝memcached-1.4.5


   
    view plain   
    copy
   
   
  1. # cd memcached-1.4.5 
  2. # ./configure --prefix=/etc/memcached 
  3. # make 
  4. # make install 

4、配置環境變數

進入使用者宿主目錄,編輯.bash_profile,為系統環境變數LD_LIBRARY_PATH增加新的目錄,需要增加的內容如下:

# vi .bash_profile


   
    view plain   
    copy
   
   
  1. MEMCACHED_HOME=/etc/memcached 
  2. export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$MEMCACHED_HOME/lib 

重新整理使用者環境變數:# source .bash_profile

5、編寫memcached服務啟停指令碼

# cd /etc/init.d

vi memcached,指令碼內容如下:


   
    view plain   
    copy
   
   
  1. #!/bin/sh 
  2. # 
  3. # Startup script for the server of memcached 
  4. # 
  5. # processname: memcached 
  6. # pidfile: /etc/memcached/memcached.pid 
  7. # logfile: /etc/memcached/memcached_log.txt 
  8. # memcached_home: /etc/memcached 
  9. # chkconfig: 35 21 79 
  10. # description: Start and stop memcached Service 
  11. 相關推薦

    JAVA MemCache 史無前例詳細講解精通MEMCACHE

    分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow 也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!        

    JAVA MemCache 史無前例詳細講解精通MEMCACHE.

     Memcach什麼是Memcache Memcache叢集環境下快取解決方案 Memcache是一個高效能的分散式的記憶體物件快取系統,通過在記憶體裡維護一個統一的巨大的hash表,它能夠用來儲存各種格式的資料,包括影象、視訊、檔案以及資料庫檢索的結果等。簡單的說就是將資

    國服最強JWT生成Token做登錄校驗講解保證你學會

    共享 jwt 存儲 node 基於 clas 成功 講解 算法 轉載於:https://blog.csdn.net/u011277123/article/details/78918390Free碼農 2017-12-28 00:08:02 JWT簡介 JWT(j

    詳細的python 操作 mongodb教程這篇還學不會隨時找我

    條件 cnblogs 江蘇 。。 location flag pre del 修改字段 準備 我的本機環境是: Python3.6 mongodb3.4.3 IDE: PyCharm Professional 因為要使用Python來操作數

    冷暖自知這篇區塊鏈媒體輿情報告,想說點啥?

    前言 進入2018年,伴隨區塊鏈行業的迅速發展,大量人才、資本湧入,促進著行業不斷向前。對於進入區塊鏈行業的人群,區塊鏈資訊的傳播十分重要。正是通過一條條專案資訊、新聞報道讓人們瞭解區塊鏈行業的時間大幅縮短。 鏈塔智庫聯合TokenTM,統計2018年區塊鏈媒體資訊釋出量,分析

    裝修流程你再裝

    1.前期設計 -- 2.主體拆改 -- 3.水電改造 -- 4.木工 -- 5.貼磚 -- 6.刷牆面漆 -- 7.廚衛吊頂 -- 8.櫥櫃安裝 -- 9.木門安裝 -- 10.地板安裝 -- 11.鋪貼桌布 -- 12.散熱器安裝 -- 13.開關插座安裝 -- 14.燈具安裝 -- 15.五金潔

    Java訪問許可權詳細講解

    人在什麼面前最容易失去抵抗力? 美色,算是一個,比如說西施的貢獻薄就是忍辱負重、以身報國、助越滅吳;金錢,算是另外一個,我們古人常說“錢乃身外之物,生不帶來死不帶去”,但我們又都知道“有錢能使鬼推磨”。 除去美色和金錢,我認為還有一個,就是讀者的認可——“二哥,你的文章真的很棒,我特別喜歡

    史上最燒腦物理學科普,瞬間漲姿勢

    導讀:這是一部壯麗的物理史詩,這是一串光耀後世的姓名。他們是:牛頓,高斯,黎曼,麥克斯韋爾,愛因斯坦,楊振寧,拉馬努金,霍金,維藤……那麼,這些智慧的頭腦到底有多智慧? 我們普遍接受這樣一個結論,即我們現存的這個宇宙起源於一次大爆炸,英文叫做Big Bang!但

    Java最經典知識點總結,你都記住的了嗎?

    1實現多執行緒的方式有幾種? 其實這個問題並不難,只是在這裡做一個總結。一共有三種。 實現Runnable介面,並實現該介面的run()方法 繼承Thread類,重寫run()方法 實現Callable介面,實現call()方法。 大家可能對前兩種已經很清楚了,重點

    Kafka史上最詳細原理總結 ----絕對不後悔

    KafkaKafka是最初由Linkedin公司開發,是一個分散式、支援分割槽的(partition)、多副本的(replica),基於zookeeper協調的分散式訊息系統,它的最大的特性就是可以實時的處理大量資料以滿足各種需求場景:比如基於hadoop的批處理系統、低延遲

    Memcache詳細講解

    原文地址:http://blog.csdn.net/hjm4702192/article/details/7894080 什麼是Memcache Memcache叢集環境下快取解決方案 Memcache是一個高效能的分散式的記憶體物件快取系統,通過在記憶體裡維護一個統一的巨

    關於卷積的一個血腥的講解給跪了

    比如說你的老闆命令你幹活,你卻到樓下打檯球去了,後來被老闆發現,他非常氣憤,扇了你一巴掌(注意,這就是輸入訊號,脈衝),於是你的臉上會漸漸地(賤賤地)鼓起來一個包,你的臉就是一個系統,而鼓起來的包就是你的臉對巴掌的響應

    我的助理辭職了——後大家對這篇文章應該很有感觸

          當時公司招了大批應屆本科和研究生畢業的新新人類。平均年齡25歲。那個新的助理,是經過多次面試後,我親自招回來的一個女孩。名牌大學本科畢業,聰明,性格活潑。私下裡我得承認,我招她的一個很重要的原因,除了她在大學裡優秀的表現之外,還因為她寫了一手漂亮的字。女孩能寫一

    月薪30KJava大牛整理了最新Java學習思維導圖,茅塞頓開

    面向 繼承 cached 相對 開發者 規模 所有 git abc 文章最後有面試題福利!記得看一下哦~ 想要成為合格的Java程序員或工程師到底需要具備哪些專業技能,面試者在面試之前到底需要準備哪些東西呢? 本文陳列的這些內容既可以作為個人簡歷中的內容,也可以作為面試的時

    【高併發】高併發環境下如何防止Tomcat記憶體溢位?我懂了

    寫在前面 隨著系統併發量越來越高,Tomcat所佔用的記憶體就會越來越大,如果對Tomcat的記憶體管理不當,則可能會引發Tomcat記憶體溢位的問題,那麼,如何防止Tomcat記憶體溢位呢?我們今天就來一起探討下這個問題。 防止Tomcat記憶體溢位可以總結為兩個方案:一個是設定Tomcat啟動的初始記

    【Nginx】如何使用Nginx實現MySQL資料庫的負載均衡?我懂了

    ## 寫在前面 > Nginx能夠實現HTTP、HTTPS協議的負載均衡,也能夠實現TCP協議的負載均衡。那麼,問題來了,可不可以通過Nginx實現MySQL資料庫的負載均衡呢?答案是:可以。接下來,就讓我們一起探討下如何使用Nginx實現MySQL的負載均衡。 ## 前提條件 **注意:使用Ng

    【高併發】億級流量場景下如何為HTTP介面限流?我懂了

    ## 寫在前面 > 在網際網路應用中,高併發系統會面臨一個重大的挑戰,那就是大量流高併發訪問,比如:天貓的雙十一、京東618、秒殺、搶購促銷等,這些都是典型的大流量高併發場景。關於秒殺,小夥伴們可以參見我的另一篇文章《[【高併發】高併發秒殺系統架構解密,不是所有的秒殺都是秒殺!](https://mp

    【Canal】網際網路背景下有哪些資料同步需求和解決方案?我知道了

    ## 寫在前面 > 在當今網際網路行業,尤其是現在分散式、微服務開發環境下,為了提高搜尋效率,以及搜尋的精準度,會大量使用Redis、Memcached等NoSQL資料庫,也會使用大量的Solr、Elasticsearch等全文檢索服務。那麼,這個時候,就會有一個問題需要我們來思考和解決:那就是資料同

    協程到底是什麼?這個故事明明白白

    神祕使者 “久聞Java語言跨越平臺,框架眾多,不過二十年功夫,就已晉升天下第一程式語言,今日一見,果然名不虛傳吶!” “使者先生您過獎了,咱們快些走,國王陛下已經等候多時了” 今日,Java帝國朝堂之上迎來了一位神祕的來賓。     來

    fish_redux使用詳解---就會用

    **說句心裡話,這篇文章,來來回回修改了很多次,如果認真看完這篇文章,還不會寫fish_redux,請在評論裡噴我。** ## 前言 來學學難搞的fish_redux框架吧,這個框架,官方的文件真是一言難盡,比flutter_bloc官網的文件真是遜色太多了,但是一旦知道怎麼寫,頁面堆起來也是非常爽呀,結