darner

simple, lightweight message queue

  • 所有者: wavii/darner
  • 平台:
  • 許可證: Other
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

Darner

Darner is a very simple message queue server. Unlike in-memory servers such as redis, Darner is
designed to handle queues much larger than what can be held in RAM. And unlike enterprise queue servers such as
RabbitMQ, Darner keeps all messages out of process, relying instead on the kernel's
virtual memory manager via log-structured storage.

The result is a durable queue server that uses a small amount of in-resident memory regardless of queue size, while
still achieving remarkable performance.

Darner is based on Robey Pointer's Kestrel simple, distributed message queue. Like Kestrel, Darner
follows the "No talking! Shhh!" approach to distributed queues: A single Darner server has a set of queues identified
by name. Each queue is a strictly-ordered FIFO, and querying from a fleet of Darner servers provides a loosely-ordered
queue. Darner also supports Kestrel's two-phase reliable fetch: if a client disconnects before confirming it handled
a message, the message will be handed to the next client.

Compared to Kestrel, Darner boasts much higher throughput, better concurrency, an order of magnitude better tp99, and
uses an order of magnitude less memory. But Darner has less configuration, and far fewer features than Kestrel. Check
out the benchmarks!

Darner is used at Wavii, and is written and maintained by Erik Frey.

Installing

OSX

Darner installs on a Mac via Homebrew:

brew install darner

Remember to update your Homebrew install if the formula is not available.

Ubuntu

You'll need build tools, CMake, Boost, and
LevelDB/snappy to build Darner. The
following works on Ubuntu 12.04:

sudo apt-get install -y build-essential cmake libboost-all-dev libsnappy-dev libleveldb-dev

Then fetch and install Darner:

git clone git://github.com/wavii/darner.git
cd darner
cmake . && make && sudo make install

Running

Make a directory for Darner to store its queues, say /var/spool/darner/, then run Darner like so.

user@home:~$ darner -d /var/spool/darner/
[INFO] 2012-Aug-13 03:59:41.047739: darner: queue server
[INFO] 2012-Aug-13 03:59:41.048051: build: Aug 26 2012 (15:47:48) v0.1.2 (c) Wavii, Inc.
[INFO] 2012-Aug-13 03:59:41.048132: listening on port: 22133
[INFO] 2012-Aug-13 03:59:41.048507: data dir: /var/spool/darner/
[INFO] 2012-Aug-13 03:59:41.048798: starting up

Voila! By default, Darner listens on port 22133.

Protocol

Darner follows the same protocol as Kestrel, which is the memcache
protocol.

Currently missing from the Darner implementation but TODO: some stats.

主要指標

概覽
名稱與所有者wavii/darner
主編程語言C++
編程語言C++ (語言數: 3)
平台
許可證Other
所有者活动
創建於2012-07-28 23:26:19
推送於2017-11-23 01:18:09
最后一次提交2013-03-19 18:54:32
發布數7
最新版本名稱v0.2.0 (發布於 )
第一版名稱v0.1.0 (發布於 )
用户参与
星數867
關注者數91
派生數81
提交數163
已啟用問題?
問題數16
打開的問題數7
拉請求數10
打開的拉請求數2
關閉的拉請求數3
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?