久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長(zhǎng)資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      Memcached詳解

      Memcached是一款開源、高性能、分布式內(nèi)存對(duì)象緩存系統(tǒng),可應(yīng)用各種需要緩存的場(chǎng)景,其主要目的是通過降低對(duì)Database的訪問來加速web應(yīng)用程序。它是一個(gè)基于內(nèi)存的“鍵值對(duì)”存儲(chǔ),用于存儲(chǔ)數(shù)據(jù)庫調(diào)用、API調(diào)用或頁面引用結(jié)果的直接數(shù)據(jù),如字符串、對(duì)象等。

      memcached是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 為首開發(fā)的一款軟件?,F(xiàn)在

      已成為mixi、hatena、Facebook、Vox、LiveJournal等眾多服務(wù)中提高Web應(yīng)用擴(kuò)展性的重要因素。

      Memcached是一款開發(fā)工具,它既不是一個(gè)代碼加速器,也不是數(shù)據(jù)庫中間件。其設(shè)計(jì)哲學(xué)思想主要反映在如下方面:

      1. 簡(jiǎn)單key/value存儲(chǔ):服務(wù)器不關(guān)心數(shù)據(jù)本身的意義及結(jié)構(gòu),只要是可序列化數(shù)據(jù)即可。存儲(chǔ)項(xiàng)由“鍵、過期時(shí)間、可選的標(biāo)志及數(shù)據(jù)”四個(gè)部分組成;

      2. 功能的實(shí)現(xiàn)一半依賴于客戶端,一半基于服務(wù)器端:客戶負(fù)責(zé)發(fā)送存儲(chǔ)項(xiàng)至服務(wù)器端、從服務(wù)端獲取數(shù)據(jù)以及無法連接至服務(wù)器時(shí)采用相應(yīng)的動(dòng)作;服務(wù)端負(fù)責(zé)接收、存儲(chǔ)數(shù)據(jù),并負(fù)責(zé)數(shù)據(jù)項(xiàng)的超時(shí)過期;

      3. 各服務(wù)器間彼此無視:不在服務(wù)器間進(jìn)行數(shù)據(jù)同步;

      4. O(1)的執(zhí)行效率

      5. 清理超期數(shù)據(jù):默認(rèn)情況下,Memcached是一個(gè)LRU緩存,同時(shí),它按事先預(yù)訂的時(shí)長(zhǎng)清理超期數(shù)據(jù);但事實(shí)上,memcached不會(huì)刪除任何已緩存數(shù)據(jù),只是在其過期之后不再為客戶所見;而且,memcached也不會(huì)真正按期限清理緩存,而僅是當(dāng)get命令到達(dá)時(shí)檢查其時(shí)長(zhǎng);

      Memcached提供了為數(shù)不多的幾個(gè)命令來完成與服務(wù)器端的交互,這些命令基于memcached的協(xié)議實(shí)現(xiàn)。

      存儲(chǔ)類命令:set, add, replace, append, prepend

      獲取數(shù)據(jù)類命令:get, delete, incr/decr

      統(tǒng)計(jì)類命令:stats, stats items, stats slabs, stats sizes

      清理命令: flush_all

      一、安裝libevent

      memcached依賴于libevent API,因此要事先安裝之,項(xiàng)目主頁:http://libevent.org/,讀者可自行選擇需要的版本下載。本文采用的是目前最新版本的源碼包libevent-2.0.16-stable.tar.gz。安裝過程:

      # tar xf libevent-2.0.20-stable.tar.gz

      # cd libevent-2.0.20

      # ./configure –prefix=/usr/local/libevent

      # make && make install

      # echo "/usr/local/libevent/lib" > /etc/ld.so.conf.d/libevent.conf

      # ldconfig

      二、安裝配置memcached

      1、安裝memcached

      # tar xf memcached-1.4.15.tar.gz

      # cd memcached-1.4.15

      # ./configure –prefix=/usr/local/memcached –with-libevent=/usr/local/libevent

      # make && make install

      2、memcached SysV的startup腳本代碼如下所示,將其建立為/etc/init.d/memcached文件:

      #!/bin/bash

      #

      # Init file for memcached

      #

      # chkconfig: – 86 14

      # description: Distributed memory caching daemon

      #

      # processname: memcached

      # config: /etc/sysconfig/memcached

      . /etc/rc.d/init.d/functions

      ## Default variables

      PORT="11211"

      USER="nobody"

      MAXCONN="1024"

      CACHESIZE="64"

      OPTIONS=""

      RETVAL=0

      prog="/usr/local/memcached/bin/memcached"

      desc="Distributed memory caching"

      lockfile="/var/lock/subsys/memcached"

      start() {

      echo -n $"Starting $desc (memcached): "

      daemon $prog -d -p $PORT -u $USER -c $MAXCONN -m $CACHESIZE -o "$OPTIONS"

      RETVAL=$

      echo

      [ $RETVAL -eq 0 ] && touch $lockfile

      return $RETVAL

      }

      stop() {

      echo -n $"Shutting down $desc (memcached): "

      killproc $prog

      RETVAL=$

      echo

      [ $RETVAL -eq 0 ] && rm -f $lockfile

      return $RETVAL

      }

      restart() {

      stop

      start

      }

      reload() {

      echo -n $"Reloading $desc ($prog): "

      killproc $prog -HUP

      RETVAL=$

      echo

      return $RETVAL

      }

      case "$1" in

      start)

      start

      ;;

      stop)

      stop

      ;;

      restart)

      restart

      ;;

      condrestart)

      [ -e $lockfile ] && restart

      RETVAL=$

      ;;

      reload)

      reload

      ;;

      status)

      status $prog

      RETVAL=$

      ;;

      *)

      echo $"Usage: $0 {start|stop|restart|condrestart|status}"

      RETVAL=1

      esac

      exit $RETVAL

      使用如下命令配置memcached成為系統(tǒng)服務(wù):

      # chmod +x /etc/init.d/memcached

      # chkconfig –add memcached

      # service memcached start

      3、使用telnet命令測(cè)試memcached的使用

      Memcached提供一組基本命令用于基于命令行調(diào)用其服務(wù)或查看服務(wù)器狀態(tài)等。

      # telnet 127.0.0.1 11211

      add命令:

      add keyname flag timeout datasize

      如:

      add mykey 0 10 12

      Hello world!

      get命令:

      get keyname

      如:get mykey

      VALUE mykey 0 12

      Hello world!

      END

      4、memcached的常用選項(xiàng)說明

      -l :指定進(jìn)程監(jiān)聽的地址;

      -d: 以服務(wù)模式運(yùn)行;

      -u :以指定的用戶身份運(yùn)行memcached進(jìn)程;

      -m :用于緩存數(shù)據(jù)的最大內(nèi)存空間,單位為MB,默認(rèn)為64MB;

      -c :最大支持的并發(fā)連接數(shù),默認(rèn)為1024;

      -p : 指定監(jiān)聽的TCP端口,默認(rèn)為11211;

      -U :指定監(jiān)聽的UDP端口,默認(rèn)為11211,0表示關(guān)閉UDP端口;

      -t :用于處理入站請(qǐng)求的最大線程數(shù),僅在memcached編譯時(shí)開啟了支持線程才有效;

      -f :設(shè)定Slab Allocator定義預(yù)先分配內(nèi)存空間大小固定的塊時(shí)使用的增長(zhǎng)因子;

      -M:當(dāng)內(nèi)存空間不夠使用時(shí)返回錯(cuò)誤信息,而不是按LRU算法利用空間;

      -n: 指定最小的slab chunk大小;單位是字節(jié);

      -S: 啟用sasl進(jìn)行用戶認(rèn)證;

      三、安裝Memcache的PHP擴(kuò)展

      ①安裝PHP的memcache擴(kuò)展

      # tar xf memcache-2.2.5.tgz

      # cd memcache-2.2.5

      /usr/local/php/bin/phpize

      # ./configure –with-php-config=/usr/local/php/bin/php-config –enable-memcache

      # make && make install

      上述安裝完后會(huì)有類似以下的提示:

      Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/

      ②編輯/usr/local/php/lib/php.ini,在“動(dòng)態(tài)模塊”相關(guān)的位置添加如下一行來載入memcache擴(kuò)展:

      extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

      而后對(duì)memcached功能進(jìn)行測(cè)試,在網(wǎng)站目錄中建立測(cè)試頁面test.php,添加如下內(nèi)容:

      $mem = new Memcache;

      $mem->connect("127.0.0.1", 11211) or die("Could not connect");

      $version = $mem->getVersion();

      echo "Server's version: ".$version."

      n";

      $mem->set('testkey', 'Hello World', 0, 600) or die("Failed to save data at the memcached server");

      echo "Store data in the cache (data will expire in 600 seconds)

      n";

      $get_result = $mem->get('testkey');

      echo "$get_result is from memcached server.";

      >

      如果有輸出“Hello World is from memcached.”等信息,則表明memcache已經(jīng)能夠正常工作。

      四、使用libmemcached的客戶端工具:

      訪問memcached的傳統(tǒng)方法是使用基于perl語言開發(fā)的Cache::memcached模塊,這個(gè)模塊在大多數(shù)perl代碼中都能良好的工作,但也有著眾所周知的性能方面的問題。libMemcached則是基于C語言開發(fā)的開源的C/C++代碼訪問memcached的庫文件,同時(shí),它還提供了數(shù)個(gè)可以遠(yuǎn)程使用的memcached管理工具,如memcat, memping,memstat,memslap等。

      1) 編譯安裝libmemcached

      # tar xf libmemcached-1.0.2.tar.gz

      # cd libmemcached-1.0.2

      # ./configure

      # make && make install

      # ldconfig

      2) 客戶端工具

      # memcat –servers=127.0.0.1:11211 mykey

      # memping

      # memslap

      # memstat

      五、Nginx整合memcached:

      server {

      listen 80;

      server_name www.magedu.com;

      #charset koi8-r;

      #access_log logs/host.access.log main;

      location / {

      set $memcached_key $uri;

      memcached_pass 127.0.0.1:11211;

      default_type text/html;

      error_page 404 @fallback;

      }

      location @fallback {

      proxy_pass http://172.16.0.1;

      }

      }

      前提:

      1、配置各php支持使用memcache;

      2、安裝配置好memcached服務(wù)器,這里假設(shè)其地址為172.16.200.11,端口為11211;

      一、配置php將會(huì)話保存至memcached中

      編輯php.ini文件,確保如下兩個(gè)參數(shù)的值分別如下所示:

      session.save_handler = memcache

      session.save_path = "tcp://172.16.200.11:11211persistent=1&weight=1&timeout=1&retry_interval=15"

      二、測(cè)試

      新建php頁面setsess.php,為客戶端設(shè)置啟用session:

      session_start();

      if (!isset($_SESSION['www.MageEdu.com'])) {

      $_SESSION['www.MageEdu.com'] = time();

      }

      print $_SESSION['www.MageEdu.com'];

      print "

      ";

      print "Session ID: " . session_id();

      >

      新建php頁面showsess.php,獲取當(dāng)前用戶的會(huì)話ID:

      session_start();

      $memcache_obj = new Memcache;

      $memcache_obj->connect('172.16.200.11', 11211);

      $mysess=session_id();

      var_dump($memcache_obj->get($mysess));

      $memcache_obj->close();

      >

      // Generating cookies must take place before any HTML.

      // Check for existing "SessionId" cookie

      $session = $HTTP_COOKIE_VARS["SessionId"];

      if ( $session == "" ) {

      // Generate time-based unique id.

      // Use user's IP address to make more unique.

      $session = uniqid ( getenv ( "REMOTE_ADDR" ) );

      // Send session id – expires when browser exits

      SetCookie ( "SessionId", $session );

      }

      >

      16 Current session id:

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)