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.gz

    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代碼示例:

  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');      //出棧
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章