分布式隊列服務(wù)MemcacheQ在Linux系統(tǒng)下的編譯安裝

MemcacheQ作為簡單的分布式隊列服務(wù),因為對MemcacheQ不了解,不少人在MemcacheQ的安裝上遇到了不少麻煩,小編就為大家詳細介紹下MemcacheQ在Linux系統(tǒng)下的編譯安裝,以便大家有更詳細的了解。
隊列(Queue)是一種常用的數(shù)據(jù)結(jié)構(gòu)。在隊列這種數(shù)據(jù)結(jié)構(gòu)中,最先插入的元素將會最先被取出;反之最后插入的元素將會最后被取出,因此隊列又稱為“先進先出”(FIFO:First In First Out)的線性表。
加入元素的一端叫“隊尾”,取出元素的一端叫“隊頭”。利用消息隊列可以很好地異步處理數(shù)據(jù)的傳送和存儲,當(dāng)遇到頻繁且密集地向后端數(shù)據(jù)庫中插入數(shù)據(jù)時,就可采用消息隊列來異步處理這些數(shù)據(jù)寫入。
MemcacheQ是一款基于Memcache協(xié)議的開源消息隊列服務(wù)軟件,由于其遵循了Memcache協(xié)議,因此開發(fā)成本很低,不需要學(xué)習(xí)額外的知識便可輕松掌握。
在最近的一個項目中也應(yīng)用了MemcacheQ,下面我將分享一下MemcacheQ在Linux中的編譯和安裝過程。
首先,MemcacheQ依賴于BerkeleyDB和Libevent,如果服務(wù)器中曾經(jīng)安裝過Memcached,那么Libevent應(yīng)該已經(jīng)存在了,否則就需要先下載安裝Libevent。
下載鏈接如下:
Libevent:https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz
Berkeley DB:http://download.oracle.com/otn/berkeley-db/db-6.0.30.tar.gz
MemcacheQ:https://github.com/stvchu/memcacheq
安裝Libevent
tar zvxf libevent-2.0.21-stable.tar.gz
cd libevent-2.0.21-stable
。/configure --prefix=/usr/local/libevent
make && make install
echo “/usr/local/libevent/lib” 》》 /etc/ld.so.conf
ldconfig
安裝BerkeleyDB
BerkeleyDB簡介:BerkeleyDB是一個開源的文件數(shù)據(jù)庫,介于關(guān)系數(shù)據(jù)庫與內(nèi)存數(shù)據(jù)庫之間,使用方式與內(nèi)存數(shù)據(jù)庫類似,它提供的是一系列直接訪問數(shù)據(jù)庫的函數(shù),而不是像關(guān)系數(shù)據(jù)庫那樣需要網(wǎng)絡(luò)通訊、SQL解析等步驟。
MemcacheQ依賴BerkleyDB用于隊列數(shù)據(jù)的持久化存儲,以免在MemcacheQ意外崩潰或中斷時,隊列數(shù)據(jù)不會丟失。
tar zxvf db-6.0.30.tar.gz
cd db-6.0.30/build_unix
。。/dist/configure --prefix=/usr/local/berkeleydb
make && make install
ln -s /usr/local/berkeleydb/lib/libdb-6.0.so /usr/lib/
echo “/usr/local/berkeleydb/lib/” 》》 /etc/ld.so.conf
ldconfig
安裝MemcacheQ
tar zxvf memcacheq-0.2.0.tar.gz
cd memcacheq-0.2.0
。/configure --prefix=/usr/local/memcacheq --with-bdb=/usr/local/berkeleydb --with-libevent=/usr/local/libevent --enable-threads
make && make install
啟動MemcacheQ
Shell
/usr/local/memcacheq/bin/memcacheq -d -uroot -r -l 127.0.0.1 -p11210 -H /usr/local/mcq -N -R -v -L 1024 -B 1024 》 /usr/local/mcq/logs/mcq_error.log 2》&1
附:MemcacheQ參數(shù)
-p 《num》 TCP監(jiān)聽端口(default: 22201)
-U 《num》 UDP監(jiān)聽端口(default: 0, off)
-s 《file》 unix socket路徑(不支持網(wǎng)絡(luò))
-a 《mask》 unix socket訪問掩碼(default 0700)
-l 《ip_addr》 監(jiān)聽網(wǎng)卡
-d 守護進程
-r 最大化核心文件限制
-u 《username》 以用戶身份運行(only when run as root)
-c 《num》 最大并發(fā)連接數(shù)(default is 1024)
-v 詳細輸出 (print errors/warnings while in event loop)
-vv 更詳細的輸出 (also print client commands/reponses)
-i 打印許可證信息
-P 《file》 PID文件
-t 《num》 線程數(shù)(default 4)
用PHP測試一下
PHP
《?php
$mcq = new Memcache;
$mcq-》connect(‘127.0.0.1’, 11210) or die (‘Connect Error!’);
for ($i=1; $i《=5; $i++) {
memcache_set($mcq, ‘k’, $i, 0, 0);
}
for ($i=1; $i《=6; $i++) {
$queue = memcache_get($mcq, ‘k’);
if ($queue === false) {
echo “null\n”;
} else {
echo $queue.“\n”;
}
}
memcache_close($mcq);
?。俊?/p>
上面就是Linux編譯安裝MemcacheQ的方法介紹了,在安裝MemcacheQ前,需要先安裝Libevent和BerkeleyDB。
相關(guān)文章
Fedora Linux 42 穩(wěn)定版發(fā)布: 帶來大量新功能和軟件更新
Fedora 42昨日發(fā)布,這是 Red Hat 贊助開發(fā)的杰出前沿 Linux 發(fā)行版的最新版,包含大量新功能和軟件更新,使其成為 2025 年上半年發(fā)布的一款出色的 Linux 操作系統(tǒng)之一,內(nèi)2025-04-16如何在Linux查看硬盤信息? 查看Linux硬盤大小類型和硬件信息的5種方法
使用Linux系統(tǒng)的過程中,查看和了解硬盤信息是非常重要的工作,尤其是對于系統(tǒng)管理員而言,那么在Linux系統(tǒng)中如何查看硬盤信息?以下是具體內(nèi)容介紹2025-03-12如何在 Linux 中查看 CPU 詳細信息? 3招輕松查看CPU型號、核心數(shù)和溫度
在日常運維工作中,獲取 CPU 信息是系統(tǒng)運維管理員常見的工作內(nèi)容,無論是為了性能調(diào)優(yōu)、硬件升級還是僅僅滿足好奇心2025-03-11什么是 Arch Linux? 獨樹一幟的Arch Linux發(fā)行版分析
Arch Linux是為簡化,優(yōu)化,現(xiàn)代化,實用主義,用戶中心和多功能性而創(chuàng)建Linux發(fā)行版,究竟是什么讓 Arch 與眾不同?下面我們就來簡要解讀2025-02-19如何在Linux環(huán)境下制作 Win11裝機U盤?
一直用的linux辦公,想要將筆記本電腦從 Linux 系統(tǒng)切換回 Windows 11,我們可以制作一個win11裝機u盤,詳細如下2025-02-17Rsnapshot怎么用? 基于Rsync的強大Linux備份工具使用指南
Rsnapshot 不僅可以備份本地文件,還能通過 SSH 備份遠程文件,接下來詳細介紹如何安裝、配置和使用 Rsnapshot,包括創(chuàng)建每小時、每天、每周和每月的本地備份,以及如何進2025-02-06Linux Kernel 6.13發(fā)布:附更新內(nèi)容及新特性解讀
Linux 內(nèi)核 6.13 正式發(fā)布,新版本引入了惰性搶占支持,簡化內(nèi)核搶占邏輯,通過減少與調(diào)度器相關(guān)的調(diào)用次數(shù),讓內(nèi)核在運行時表現(xiàn)更優(yōu),從而提高效率2025-01-23五大特性引領(lǐng)創(chuàng)新! 深度操作系統(tǒng) deepin 25 Preview預(yù)覽版發(fā)布
今日,深度操作系統(tǒng)正式推出deepin 25 Preview版本,該版本集成了五大核心特性:磐石系統(tǒng)、全新DDE、Treeland窗口合成器、AI For OS以及Distrobox子系統(tǒng)2025-01-18Linux Mint Xia 22.1重磅發(fā)布: 重要更新一覽
Beta 版 Linux Mint“Xia” 22.1 發(fā)布,新版本基于 Ubuntu 24.04,內(nèi)核版本為 Linux 6.8,這次更新帶來了諸多優(yōu)化和改進,進一步鞏固了 Mint 在 Linux 桌面操作系統(tǒng)領(lǐng)域的2025-01-16LinuxMint怎么安裝? Linux Mint22下載安裝圖文教程
Linux Mint22發(fā)布以后,有很多新功能,很多朋友想要下載并安裝,該怎么操作呢?下面我們就來看看詳細安裝指南2025-01-16