中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Beanstalkd有什么特性

發布時間:2021-12-02 14:42:34 來源:億速云 閱讀:129 作者:iii 欄目:web開發

本篇內容介紹了“Beanstalkd有什么特性”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

設計思想

高性能離不開異步,異步離不開隊列,而其內部都是Producer-Comsumer模式的原理。

Beanstalkd有什么特性

圖1 Producer-Comsumer模式

應用

Beanstalkd,一個高性能、輕量級的分布式內存隊列系統,最初設計的目的是想通過后臺異步執行耗時的任務來降低高容量Web應用系統的頁面訪問延遲,支持過有9.5 million用戶的Facebook Causes應用。后來開源,現在有PostRank大規模部署和使用,每天處理***任務。Beanstalkd是典型的類Memcached設計,協議和使用方式都是同樣的風格,所以使用過memcached的用戶會覺得Beanstalkd似曾相識。

核心概念

Beanstalkd設計里面的核心概念:

◆ job

一個需要異步處理的任務,是Beanstalkd中的基本單元,需要放在一個tube中。

◆ tube

一個有名的任務隊列,用來存儲統一類型的job,是producer和consumer操作的對象。

◆ producer

Job的生產者,通過put命令來將一個job放到一個tube中。

◆ consumer

Job的消費者,通過reserve/release/bury/delete命令來獲取job或改變job的狀態。

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

Beanstalkd有什么特性

圖2 Beanstalkd中job的生命周期

特性

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

◆ 優先級

支持0到2**32的優先級,值越小,優先級越高,默認優先級為1024。

◆ 持久化

可以通過binlog將job及其狀態記錄到文件里面,在Beanstalkd下次啟動時可以通過讀取binlog來恢復之前的job及狀態。

◆ 分布式容錯

分布式設計和Memcached類似,beanstalkd各個server之間并不知道彼此的存在,都是通過client來實現分布式以及根據tube名稱去特定server獲取job。

◆ 超時控制

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

不足

在使用中發現一個Beanstalkd尚無提供刪除一個tube的操作,只能將tube的job依次刪除,并讓Beanstalkd來自動刪除空tube。還有就是Beanstalkd不支持客戶端認證機制(開發者將應用場景定位在局域網)。

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

云和县| 晋宁县| 交口县| 江安县| 霸州市| 马公市| 垫江县| 大丰市| 宜春市| 乌兰察布市| 疏附县| 五台县| 忻州市| 阿坝县| 祁门县| 外汇| 广东省| 静海县| 平塘县| 衡阳县| 宁阳县| 林芝县| 友谊县| 双牌县| 平谷区| 扬州市| 巴南区| 务川| 永吉县| 平昌县| 宜兴市| 长沙县| 始兴县| 盐边县| 钦州市| 楚雄市| 山丹县| 沁源县| 昔阳县| 盐津县| 郧西县|