/majordomo

Majordomo Project

Primary LanguageCMozilla Public License 2.0MPL-2.0

A service oriented broker that implements the Majordomo protocol

This broker connects a set of clients to a set of workers who register particular "services". Client requests are then sent to workers according to their availability, and replies sent back to the original clients.

This implementation was developed using zproject and zproto projects.

The protocol, Majordomo Protocol 0.2, is specified in 18/MDP

For the older implementation, based on the Guide, see majordomo/libmdp.

Reference implementations of older wire protocols:

Architecture

  • Definitions of messages and codecs are in XML files in the directory src
  • Due to the peculiar nature of the Majordomo protocol, there is one type of server, know as broker, and two types of clients: client and worker. mdp_broker.xml defines the broker's state machine; mdp_client.xml and mdp_worker.xml define the client's and worker's state machine respectively.
  • project.xml was adapted from zproject. generate.sh was copied directly from zproject. It generates autogen.sh (which is used in the first step of configuring the project).

Contribution process

  • C4 process is at http://rfc.zeromq.org/spec:16.
  • All commits are be backed by issues.
  • All commits are made as pull requests from forked work repository.

Building and installing

  • ./autogen.sh
  • ./configure
  • make
  • make install

See also