PHP結合memcacheq消息隊列解決併發問題

在處理業務邏輯時有可能遇到高併發問題,例如商城秒殺、微博評論等。若是不作任何措施可能在高瞬間形成服務器癱瘓,如何解決這個問題呢?隊列是個不錯的選擇。隊列(Queue)又稱先進先出(First In First Out)利用消息隊列能夠很好地異步處理數據傳送和存儲,當你向數據庫中寫入數據就可採起消息隊列來異步插入。只要有併發限制的地方基本均可以使用隊列來解決。這裏先重點介紹一下memcacheq。數據庫

    持久化消息隊列memcacheq是一個輕量級的消息隊列。依附於Berkeley DB和libevent。Berkeley DB用於持久化存儲隊列的數據,避免在memcacheq出問題時形成數據喪失。接下來看一下安裝過程,首先下載libevent-1.4X***、BerkeleyDB5.0、memcacheq-0.2.0,下載地址:服務器

    http://monkey.org/~provos/libevent/併發

    http://download.oracle.com/berkeley-db/db-5.0.21.tar.gzoracle

    http://code.google.com/p/memcacheq/downloads/list異步

安裝步驟:高併發

    tar zxvf libevent-1.4.14b-stable.tar.gz
cd libevent-1.4.14b-stable
./configure
make
make install
ln -s /usr/local/lib/libevent-1.4.so.2 /usr/lib/libevent-1.4.so.2
cd ..
tar zxvf db-5.0.21.tar.gz
 cd db-5.0.21/build_unix/
../dist/configure
make
make install
vi /etc/ld.so.conf
加入如下兩行
/usr/local/lib
/usr/local/BerkeleyDB.5.0/lib
執行
ldconfig
cd ../../
 tar zxvf memcacheq-0.2.0.tar.gz
cd memcacheq-0.2.0
./configure --with-bdb=/usr/local/BerkeleyDB.5.0 --with-libevent=/usr/local/lib --enable-threads
make
make install
啓動前肯定一下 日誌目錄是否存在  若是不存在須要手動建立
memcacheq -d -r -uroot -p22201 -H /data0/memcacheq -N -v -L 1024 -B 1024 > /data0/mq_error.log 2>&1
  參數說明:
-d : 之後臺服務方式運行
-l :  設置監聽地址及端口(默認端口是22201)
-A : 數據頁大小
-H : 數據保存目錄 必定要存在
-B : 隊列中每條數據的最大長度(字節)
-N : 使用內存緩衝方式保存數據至磁盤,從而得到極高性能。若無此參數,性能會不好
-R : 自動清理過時的日誌 -u : 設置memcacheq進程帳號性能

    PHP代碼示例:ui

 

    1. $memcache_obj = new Memcache;
    2. $memcache_obj->connect('192.168.1.106', 22201);

    3. $memcache_obj->set('a',time(),0,0);//入棧
    4. echo $memcache_obj->get('a');      //出棧
相關文章
相關標籤/搜索