成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Beanstalkd一個高性能分布式內存隊列系統

開發 前端 分布式
Beanstalkd之于RabbitMQ,就好比Nginx之于Apache,Varnish之于Squid。后面在項目中使用Beanstalkd的過程中,更發現其簡單、輕量級、高性能、易使用等特點,以及優先級、多隊列、持久化、分布式容錯、超時控制等特性。下面就簡單介紹一下Beanstalkd。

之前在微博上調查過大家正在使用的分布式內存隊列系統,反饋有Memcacheq,Fqueue, RabbitMQ, Beanstalkd以及linkedin的kafka。RabbitMQ使用比較廣泛,Beanstalkd是后起之秀。Beanstalkd之于RabbitMQ,就好比Nginx之于Apache,Varnish之于Squid。后面在項目中使用Beanstalkd的過程中,更發現其簡單、輕量級、高性能、易使用等特點,以及優先級、多隊列、持久化、分布式容錯、超時控制等特性。下面就簡單介紹一下Beanstalkd,不足之處請大家指正。

設計思想

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

 

 

圖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狀態。

 

 

圖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不支持客戶端認證機制(開發者將應用場景定位在局域網)。

后續工作

1.介紹Beanstalkd的命令和使用

2. 翻譯Beanstalkd協議

3. 分析Beanstalkd源碼

原文:http://rdc.taobao.com/blog/cs/?p=1201

【編輯推薦】

  1. LAMP網站架構方案深入分析
  2. 9月編程語言排行榜:專為機器人玩具設計的語言NXT-G
  3. 從新浪微博的改版談網頁重構
  4. 9月10款非常有用的jQuery工具提示插件推薦
  5. Google強推Dart語言替代JavaScript 意欲何為?
責任編輯:陳貽新 來源: 淘寶核心系統團隊博客
相關推薦

2017-10-11 16:12:19

內存

2021-06-24 10:27:48

分布式架構系統

2021-06-25 10:45:43

Netty 分布式框架 IO 框架

2021-07-06 10:35:46

分布式KafkaLinux

2018-07-02 08:25:14

2013-09-11 16:02:00

Spark分布式計算系統

2022-06-30 08:04:16

Redis分布式鎖Redisson

2012-12-28 17:31:06

2020-07-30 09:35:09

Redis分布式鎖數據庫

2025-06-27 10:41:04

Redis數據庫集群

2022-06-27 08:36:27

分布式事務XA規范

2016-09-30 10:13:07

分布式爬蟲系統

2020-07-08 11:59:52

分布式系統緩存

2014-03-12 10:42:10

equeue分布式消息隊列

2022-12-09 08:40:56

高性能內存隊列

2024-02-19 00:00:00

Redis分布式

2023-09-04 08:45:07

分布式配置中心Zookeeper

2015-08-03 09:15:00

300行代碼分布式系統

2022-12-08 08:13:11

分布式數據庫CAP

2023-04-27 09:00:35

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久久久国产精品一区二区 | 日本a v在线播放 | 久久免费精品视频 | 一区在线视频 | 国产成人久久精品 | 国内精品视频免费观看 | 亚洲成a | 国产免费国产 | 亚洲精品一区二区三区蜜桃久 | 在线播放中文字幕 | 国产一区三区在线 | 理论片午午伦夜理片影院 | 国产一区三区在线 | 日韩精品久久一区 | 毛片在线看片 | 国产免费又色又爽又黄在线观看 | 成年人视频在线免费观看 | 超碰在线免费av | 精品国产欧美一区二区 | 日本不卡高字幕在线2019 | 精品久久久久久久久久久久 | 欧美精品久久久久久久久老牛影院 | 久久午夜精品 | 91精品国产91久久综合桃花 | 久久久久久国产 | 天天射天天操天天干 | 伊人久久综合 | 久久青草av | 伊人在线| 日日日干干干 | 妞干网av | 久久免费观看视频 | 欧美国产日韩在线观看 | 久草成人| 久久国产传媒 | 亚洲巨乳自拍在线视频 | 久久91av | 国产成人精品视频在线观看 | 欧美激情精品久久久久久 | 国产成人精品一区二区三区 | 91久久精品一区二区二区 |