溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Beanstalkd有什么特性

發(fā)布時(shí)間:2021-12-02 14:42:34 來源:億速云 閱讀:121 作者:iii 欄目:web開發(fā)

本篇內(nèi)容介紹了“Beanstalkd有什么特性”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

設(shè)計(jì)思想

高性能離不開異步,異步離不開隊(duì)列,而其內(nèi)部都是Producer-Comsumer模式的原理。

Beanstalkd有什么特性

圖1 Producer-Comsumer模式

應(yīng)用

Beanstalkd,一個(gè)高性能、輕量級(jí)的分布式內(nèi)存隊(duì)列系統(tǒng),最初設(shè)計(jì)的目的是想通過后臺(tái)異步執(zhí)行耗時(shí)的任務(wù)來降低高容量Web應(yīng)用系統(tǒng)的頁面訪問延遲,支持過有9.5 million用戶的Facebook Causes應(yīng)用。后來開源,現(xiàn)在有PostRank大規(guī)模部署和使用,每天處理***任務(wù)。Beanstalkd是典型的類Memcached設(shè)計(jì),協(xié)議和使用方式都是同樣的風(fēng)格,所以使用過memcached的用戶會(huì)覺得Beanstalkd似曾相識(shí)。

核心概念

Beanstalkd設(shè)計(jì)里面的核心概念:

◆ job

一個(gè)需要異步處理的任務(wù),是Beanstalkd中的基本單元,需要放在一個(gè)tube中。

◆ tube

一個(gè)有名的任務(wù)隊(duì)列,用來存儲(chǔ)統(tǒng)一類型的job,是producer和consumer操作的對(duì)象。

◆ producer

Job的生產(chǎn)者,通過put命令來將一個(gè)job放到一個(gè)tube中。

◆ consumer

Job的消費(fèi)者,通過reserve/release/bury/delete命令來獲取job或改變job的狀態(tài)。

Beanstalkd中一個(gè)job的生命周期如圖2所示。一個(gè)job有READY, RESERVED, DELAYED, BURIED四種狀態(tài)。當(dāng)producer直接put一個(gè)job時(shí),job就處于READY狀態(tài),等待consumer來處理,如果選擇延遲put,job就先到DELAYED狀態(tài),等待時(shí)間過后才遷移到READY狀態(tài)。consumer獲取了當(dāng)前READY的job后,該job的狀態(tài)就遷移到RESERVED,這樣其他的consumer就不能再操作該job。當(dāng)consumer完成該job后,可以選擇delete, release或者bury操作;delete之后,job從系統(tǒng)消亡,之后不能再獲取;release操作可以重新把該job狀態(tài)遷移回READY(也可以延遲該狀態(tài)遷移操作),使其他的consumer可以繼續(xù)獲取和執(zhí)行該job;有意思的是bury操作,可以把該job休眠,等到需要的時(shí)候,再將休眠的job kick回READY狀態(tài),也可以delete BURIED狀態(tài)的job。正是有這些有趣的操作和狀態(tài),才可以基于此做出很多意思的應(yīng)用,比如要實(shí)現(xiàn)一個(gè)循環(huán)隊(duì)列,就可以將RESERVED狀態(tài)的job休眠掉,等沒有READY狀態(tài)的job時(shí)再將BURIED狀態(tài)的job一次性kick回READY狀態(tài)。

Beanstalkd有什么特性

圖2 Beanstalkd中job的生命周期

特性

Beanstalkd基于的源碼安裝和使用很簡單,在此略過。這里重點(diǎn)介紹一下其幾個(gè)很nice的特性。

◆ 優(yōu)先級(jí)

支持0到2**32的優(yōu)先級(jí),值越小,優(yōu)先級(jí)越高,默認(rèn)優(yōu)先級(jí)為1024。

◆ 持久化

可以通過binlog將job及其狀態(tài)記錄到文件里面,在Beanstalkd下次啟動(dòng)時(shí)可以通過讀取binlog來恢復(fù)之前的job及狀態(tài)。

◆ 分布式容錯(cuò)

分布式設(shè)計(jì)和Memcached類似,beanstalkd各個(gè)server之間并不知道彼此的存在,都是通過client來實(shí)現(xiàn)分布式以及根據(jù)tube名稱去特定server獲取job。

◆ 超時(shí)控制

為了防止某個(gè)consumer長時(shí)間占用任務(wù)但不能處理的情況,Beanstalkd為reserve操作設(shè)置了timeout時(shí)間,如果該consumer不能在指定時(shí)間內(nèi)完成job,job將被遷移回READY狀態(tài),供其他consumer執(zhí)行。

不足

在使用中發(fā)現(xiàn)一個(gè)Beanstalkd尚無提供刪除一個(gè)tube的操作,只能將tube的job依次刪除,并讓Beanstalkd來自動(dòng)刪除空tube。還有就是Beanstalkd不支持客戶端認(rèn)證機(jī)制(開發(fā)者將應(yīng)用場(chǎng)景定位在局域網(wǎng))。

“Beanstalkd有什么特性”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI