|
memcacheQ是一個單純的分布式消息隊列服務。
一,MEMCACHEQ的應用背景
Web應用中為什
么會需要消息隊列?主要原因是由于在高并發環境下,由于來不及同步處理,請求往往會發生堵塞,比如說,大量的insert,update之類的請求同時到達mysql,直接導致無數的行鎖表鎖,甚至最后請求會堆積過多,從而觸發too manyconnections錯誤。通過使用消息隊列,我們可以異步處理請求,從而緩解系統的壓力。在Web2.0的時代,高并發的情況越來越常見,從而使消息隊列有成為居家必備的趨勢,相應的也涌現出了很多實現方案,像Twitter以前就使用RabbitMQ實現消息隊列服務,現在又轉而使用Kestrel來實現消息隊列服務,此外還有很多其他的選擇,比如說:ActiveMQ,ZeroMQ等。
上述消息隊列的軟件中,大多為了實現AMQP,STOMP,XMPP之類的協議,變得極其重量級,但在很多Web應用中的實際情況是:我們只是想找到一個緩解高并發請求的解決方案,不需要雜七雜八的功能,一個輕量級的消息隊列實現方式才是我們真正需要的。
二,MEMCACHEQ的特性
1 簡單易用
2 處理速度快
3 多條隊列
4 并發性能好
5 與memcache的協議兼容。這就意味著只要裝了memcache的extension就可以了,不需要額外的插件。
三,安裝
MEMCACHEQ依賴于libevent和BerkleyDB。
BerkleyDB用于持久化存儲隊列的數據。 這樣在MEMCACHEQ崩潰或者服務器掛掉的時候,
不至于造成數據的丟失。這一點很重要,很重要。
它的安裝依賴于BerkeleyDB 和 libevent,所以要先安裝這BerkeleyDB和libevent:
其中libevent如果你安裝過memcached就已經安裝了,如果不確定,就檢查一下吧
1. 先檢查libevent, libevent-devel是否已經安裝: rpm -qa|grep libevent 輸出中必須包含libevent, libevent-deve, 如果缺失,使用以下命令安裝:
yum install libevent yum
install libevent-devel
注意事項:libevent, libevent-devel優先使用yum安裝源,光盤鏡像中的rpm包安裝,這樣穩定性和兼容性可得到保證,網上流傳的使用源碼安裝libevent的方法會有問題,因為很可能系統已經安裝libevent, 再使用源碼安裝, 必然導致沖突,造成意外問題,所以一定要使用上述命令檢查系統是否已經安裝相應的庫
2. 安裝BerkleyDB
1.tar zxvf bdb-5.3.3.tar.gz
2.cd db-5.3.3/
#需要進入特定操作系統編譯環境,更常規軟件的編譯有些區別
3.cd build_unix/
4. ../dist/configure --prefix=/usr/local/berkeleydb
#如果沒有指定特殊安裝路徑,編譯完成,需要將Berkeley Db運行庫的路徑添加到系統配置里面
echo "/usr/local/BerkeleyDB.5.3/lib/" >> /etc/ld.so.conf
#重載系統Ld運行庫
ldconfig
5. make & make install
記得改/etc/ld.so.conf文件,添加/usr/local/BerkeleyDB.5.3/lib啊,不然后面的mcq會安裝錯誤。
而BerkeleyDB就要去下載了
點擊下載Berkeley DB 5.3.21.rar
下面安裝memcacheq,
先下載一個memcacheq-0.2.0.rar
解壓,進目錄
./configure
主站蜘蛛池模板:
欧美综合久久
|
亚洲人在线
|
久久电影一区
|
综合二区
|
夜夜撸av
|
久久久久国产精品
|
中文字幕亚洲精品
|
精品99久久久久久
|
国产99精品
|
99久久精品免费看国产四区
|
亚洲一区视频
|
成人 在线|
免费av电影网站
|
一区二区精品在线
|
欧美韩一区二区三区
|
成人不卡
|
亚洲精品一区二区在线
|
91丨国产|
久久99精品久久久久久青青日本
|
国产精品九九
|
欧美日韩国产高清
|
中文日本在线
|
国产精品视频一
|
成人动慢|
欧美激情在线一区二区三区
|
最新国产在线
|
成人伊人|
国产成人免费视频网站高清观看视频
|
完全免费在线视频
|
精品伊人久久
|
国产精品久久久久久久久免费
|
久久久久久久久综合
|
国产精品一区一区
|
国产精品成人一区二区
|
日韩亚洲视频
|
久久一
|
久久精品色欧美aⅴ一区二区
|
chinese中国真实乱对白
|
久久精品国产免费一区二区三区
|
毛片网站在线观看视频
|
日韩免费成人av
|