欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

分布式緩存系統Memcached學習心得

系統 1728 0

緣起: 在數據驅動的web開發中,經常要重復從數據庫中取出相同的數據,這種重復極大的增加了數據庫負載。緩存是解決這個問題的好辦法。
Memcached是什么?
Memcached是由Danga Interactive開發的,高性能的,分布式的內存對象緩存系統,用于在動態應用中減少數據庫負載,提升訪問速度。

Memcached能緩存什么?
?????? 通過在內存里維護一個統一的巨大的hash表,Memcached能夠用來存儲各種格式的數據,包括圖像、視頻、文件以及數據庫檢索的結果等。

Memcached快么?
?????? 非常快。Memcached使用了libevent(如果可以的話,在linux下使用epoll)來均衡任何數量的打開鏈接,使用非阻塞的網絡I/O,對內部對象實現引用計數(因此,針對多樣的客戶端,對象可以處在多樣的狀態), 使用自己的頁塊分配器和哈希表, 因此虛擬內存不會產生碎片并且虛擬內存分配的時間復雜度可以保證為O(1).。
?????? Danga Interactive為提升Danga Interactive的速度研發了Memcached。目前,LiveJournal.com每天已經在向一百萬用戶提供多達兩千萬次的頁面訪問。而這些,是由一個由web服務器和數據庫服務器組成的集群完成的。Memcached幾乎完全放棄了任何數據都從數據庫讀取的方式,同時,它還縮短了用戶查看頁面的速度、更好的資源分配方式,以及Memcache失效時對數據庫的訪問速度。

Memcached的特點
?????? Memcached的緩存是一種分布式的,可以讓不同主機上的多個用戶同時訪問, 因此解決了共享內存只能單機應用的局限,更不會出現使用數據庫做類似事情的時候,磁盤開銷和阻塞的發生。

Memcached的使用
一 、Memcached服務器端的安裝 (此處將其作為系統服務安裝)
???? 下載文件:memcached 1.2.1 for Win32 binaries (Dec 23, 2006)
?? 1 解壓縮文件到c:\memcached
?? 2 命令行輸入 'c:\memcached\memcached.exe -d install'
?? 3 命令行輸入 'c:\memcached\memcached.exe -d start' ,該命令啟動 Memcached ,默認監聽端口為 11211
? 通過 memcached.exe -h 可以查看其幫助

二、客戶端使用
????? 下載memcached java client:http://www.whalin.com/memcached/#download
?? 1 解壓后將java_memcached-release_2.0.1.jar jar包添加到工程的classpath中
?????? 2 利用memcached java client 一個簡單的應用

Java代碼 復制代碼
  1. package ?com.danga.MemCached.test;???? ??
  2. ??? ??
  3. import ?java.util.Date;???? ??
  4. ??? ??
  5. import ?com.danga.MemCached.MemCachedClient;???? ??
  6. import ?com.danga.MemCached.SockIOPool;???? ??
  7. ??? ??
  8. ??? ??
  9. public ? class ?Test?{???????? ??
  10. ???? protected ? static ?MemCachedClient?mcc?=? new ?MemCachedClient();??????? ??
  11. ??????? ??
  12. ???? static ?{??????? ??
  13. ????????String[]?servers?={ "192.168.40.4:12000" };??????? ??
  14. ??????? ??
  15. ????????Integer[]?weights?=?{? 3 ?};??????? ??
  16. ??????? ??
  17. ???????? //創建一個實例對象SockIOPool????? ??
  18. ????????SockIOPool?pool?=?SockIOPool.getInstance();??????? ??
  19. ??????? ??
  20. ???????? //?set?the?servers?and?the?weights???? ??
  21. ???????? //設置Memcached?Server???? ??
  22. ????????pool.setServers(?servers?);??????? ??
  23. ????????pool.setWeights(?weights?);??????? ??
  24. ??????? ??
  25. ???????? //?set?some?basic?pool?settings??????? ??
  26. ???????? //?5?initial,?5?min,?and?250?max?conns??????? ??
  27. ???????? //?and?set?the?max?idle?time?for?a?conn??????? ??
  28. ???????? //?to?6?hours??????? ??
  29. ????????pool.setInitConn(? 5 ?);??????? ??
  30. ????????pool.setMinConn(? 5 ?);??????? ??
  31. ????????pool.setMaxConn(? 250 ?);??????? ??
  32. ????????pool.setMaxIdle(? 1000 ?*? 60 ?*? 60 ?*? 6 ?);??????? ??
  33. ??????? ??
  34. ???????? //?set?the?sleep?for?the?maint?thread??????? ??
  35. ???????? //?it?will?wake?up?every?x?seconds?and??????? ??
  36. ???????? //?maintain?the?pool?size??????? ??
  37. ????????pool.setMaintSleep(? 30 ?);??????? ??
  38. ??????? ??
  39. ???????? //?Tcp的規則就是在發送一個包之前,本地機器會等待遠程主機???? ??
  40. ?????????????????? //?對上一次發送的包的確認信息到來;這個方法就可以關閉套接字的緩存,???? ??
  41. ?????????????????? //?以至這個包準備好了就發;???? ??
  42. ??????????????????pool.setNagle(? false ?);??????? ??
  43. ???????? //連接建立后對超時的控制???? ??
  44. ??????????????????pool.setSocketTO(? 3000 ?);???? ??
  45. ???????? //連接建立時對超時的控制???? ??
  46. ??????????????????pool.setSocketConnectTO(? 0 ?);??????? ??
  47. ??????? ??
  48. ???????? //?initialize?the?connection?pool??????? ??
  49. ???????? //初始化一些值并與MemcachedServer段建立連接???? ??
  50. ??????????????????pool.initialize();???? ??
  51. ??????????????? ??
  52. ??????? ??
  53. ???????? //?lets?set?some?compression?on?for?the?client??????? ??
  54. ???????? //?compress?anything?larger?than?64k??????? ??
  55. ????????mcc.setCompressEnable(? true ?);??????? ??
  56. ????????mcc.setCompressThreshold(? 64 ?*? 1024 ?);??????? ??
  57. ????}??????? ??
  58. ??????????? ??
  59. ???? public ? static ? void ?bulidCache(){??????? ??
  60. ???????? //set(key,value,Date)?,Date是一個過期時間,如果想讓這個過期時間生效的話,這里傳遞的new?Date(long?date)?中參數date,需要是個大于或等于1000的值。???? ??
  61. ???????? //因為java?client的實現源碼里是這樣實現的?expiry.getTime()?/?1000?,也就是說,如果?小于1000的值,除以1000以后都是0,即永不過期???? ??
  62. ????????mcc.set(? "test" ,? "This?is?a?test?String" ?, new ?Date( 11211 ));??? ??
  63. ???? //十秒后過期???? ??
  64. ?????????????? ??
  65. ????}??????? ??
  66. ?????? ??
  67. ???? public ? static ? void ?output()?{??????? ??
  68. ???????? //從cache里取值???? ??
  69. ????????String?value?=?(String)?mcc.get(? "test" ?);??????? ??
  70. ????????System.out.println(value);???????? ??
  71. ????}??????? ??
  72. ??????????? ??
  73. ???? public ? static ? void ?main(String[]?args){??????? ??
  74. ????????bulidCache();?????? ??
  75. ????????output();??????????? ??
  76. ????}????? ??
  77. ??????? ??
  78. }?????????
    package com.danga.MemCached.test;    
   
import java.util.Date;    
   
import com.danga.MemCached.MemCachedClient;    
import com.danga.MemCached.SockIOPool;    
   
   
public class Test {        
    protected static MemCachedClient mcc = new MemCachedClient();       
       
    static {       
        String[] servers ={"192.168.40.4:12000"};       
       
        Integer[] weights = { 3 };       
       
        //創建一個實例對象SockIOPool     
        SockIOPool pool = SockIOPool.getInstance();       
       
        // set the servers and the weights    
        //設置Memcached Server    
        pool.setServers( servers );       
        pool.setWeights( weights );       
       
        // set some basic pool settings       
        // 5 initial, 5 min, and 250 max conns       
        // and set the max idle time for a conn       
        // to 6 hours       
        pool.setInitConn( 5 );       
        pool.setMinConn( 5 );       
        pool.setMaxConn( 250 );       
        pool.setMaxIdle( 1000 * 60 * 60 * 6 );       
       
        // set the sleep for the maint thread       
        // it will wake up every x seconds and       
        // maintain the pool size       
        pool.setMaintSleep( 30 );       
       
        // Tcp的規則就是在發送一個包之前,本地機器會等待遠程主機    
                  // 對上一次發送的包的確認信息到來;這個方法就可以關閉套接字的緩存,    
                  // 以至這個包準備好了就發;    
                  pool.setNagle( false );       
        //連接建立后對超時的控制    
                  pool.setSocketTO( 3000 );    
        //連接建立時對超時的控制    
                  pool.setSocketConnectTO( 0 );       
       
        // initialize the connection pool       
        //初始化一些值并與MemcachedServer段建立連接    
                  pool.initialize();    
               
       
        // lets set some compression on for the client       
        // compress anything larger than 64k       
        mcc.setCompressEnable( true );       
        mcc.setCompressThreshold( 64 * 1024 );       
    }       
           
    public static void bulidCache(){       
        //set(key,value,Date) ,Date是一個過期時間,如果想讓這個過期時間生效的話,這里傳遞的new Date(long date) 中參數date,需要是個大于或等于1000的值。    
        //因為java client的實現源碼里是這樣實現的 expiry.getTime() / 1000 ,也就是說,如果 小于1000的值,除以1000以后都是0,即永不過期    
        mcc.set( "test", "This is a test String" ,new Date(11211));   
    //十秒后過期    
              
    }       
      
    public static void output() {       
        //從cache里取值    
        String value = (String) mcc.get( "test" );       
        System.out.println(value);        
    }       
           
    public static void main(String[] args){       
        bulidCache();      
        output();           
    }     
       
}       


  

分布式緩存系統Memcached學習心得


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 日韩综合 | 特黄做愛又硬又大A片视频 小视频在线看 | 亚洲免费人成在线视频观看 | 91精品综合久久久久久五月天 | avtom影院入口永久在线观看 | 在线午夜 | 中文字幕亚洲精品 | japanese末成年free | 亚洲欧美国产日产综合不卡 | 亚洲欧洲精品视频在线观看 | 日韩中文字幕在线看 | 国产香港一级毛片在线看 | 欧美精品人爱a欧美精品 | 久萆app污版下载网站 | 亚洲精品日韩在线 | 亚洲欧美精品综合中文字幕 | 麻豆精品传媒一二三区在线视频 | 日韩一区二区在线观看视频 | 婷婷在线网站 | 国产精品va在线观看无 | 日韩在线操 | 偷拍自拍网址 | 精品国产福利片在线观看 | 久久精品国产一区二区三区不卡 | 欧美日一区二区三区 | 欧美成人精品一区二区三区 | 麻豆一区二区99久久久久 | 成人一级| 在线视频日韩精品 | 狠狠躁夜夜躁人人爽天天段 | 亚洲免费人成在线视频观看 | 亚洲日韩中文字幕一区 | 免费看搡女人无遮挡的视频 | 国产一区二区自拍 | 国产成人精品在线 | 小明永久视频免费播放 | 久久精品免费国产 | 日韩伦理一区 | 狠狠一区 | 久久国产精品久久 | 成年在线视频免费视频观看 |