Trinity is a Byzantine Fault-Tolerant Distributed Publish-Subscribe System with Immutable Blockchain-based Persistence. Applications with multiple stakeholders that rely on a centralized communication model does not guarantee trustless communication. Trinity combines the publish-subscribe broker with the blockchain technology to guarantee persistence, ordering, and immutability across trust boundaries.
This work will appear at the IEEE International Conference on Blockchain and Cryptocurrency (ICBC 2019).
This is release 1.0, we are still working to improve it.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
To run Trinity on your computer, the following broker and blockchain software has to be installed on your machine.
Tendermint
Trinity is implemented and evaluated using the Tendermint blockchain framework. Please refer to the following documentation for installation of Tendermint.
Mosquitto MQTT Broker
MQTT broker is used as a publish-subscribe communication protocol in the implementation and evaluation of Trinity. Please install MQTT using the following documentation.
This repository has to be cloned on your machine to install Trinity.
Step 1
git clone https://github.com/ANRGUSC/Trinity.git
And then,
npm install
Once the above command is successfully executed on your system, trinity and all the other necessary libraries are available for use.
To test Trinity framework on your machine, the following steps must be followed:
Step 1
The brokerABCI application must be started first before starting the Tendermint consensus engine. Start brokerABCI on a terminal:
node brokerABCI.js
Step 2
Before starting the blockchain network, it must be configured appropriately. The following documentation explains the configuration details of the Tendermint framework (documentation).Start the Tendermint blockchain network on a new terminal:
tendermint init
Step 3
The brokerABCI and the blockchain framework are running, and it is ready to receive broker transactions and contracts. Start the trinityMarshall appplication, which pushes the registered topics to the blockchain network for the execution of smart contracts, concensus protocol, and block creation. Start Trinity application on a new terminal:
node trinityMarshal.js
Now one of the Trinity instance is ready for handling broker transactions.
Step 4
Any MQTT publisher can publish the data to the broker running on your machine. Libraries are available in languages such as Python, Node JS, Java, etc., for publishing data to MQTT broker. As an example, we provide Node JS-based application for publishing data. Start a publisher on a new terminal:
node tools/publisher.js
Now the data from registered publisher will be verified and stored on the Tendermint Blockchain. To understand the details of the consensus and block creation, please refer to the following [documentation] (http://tendermint.readthedocs.io/projects/tools/en/master/index.html).
Trinity was evaluated on a 20-node Raspberry Pi testbed. All the devices were connected through a LAN. Our preliminary results are available in our article here.
- Ubuntu - 16.04.1
- Node - 8.11.2
- npm - 5.6.0
- Mosquitto - 1.4.10
- Tendermint - 0.19.6
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
- Implementation of wrapper for connecting the broker with the Tendermint
- Preliminary support for smart contract
- APIs for fetching verified transactions from the Tendermint framework
- Extend the smart contract functionalities
- Support for aggregation of transactions
- User-friendly framework for adding/removing/reconfiguring validators
- Gowri Sankar Ramachandran [email protected]
- Kwame-Lante Wright [email protected]
- Bhaskar Krishnamachari [email protected]
This project is licensed under a permissive license - please see LICENSE.md for details