cluster

command
v1.5.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 25, 2023 License: MIT Imports: 23 Imported by: 0

README

Cluster Start

Cluster is implemented using gossip and raft protocol.

Cluster uses redis to store inflight and retain messages and subscriptions across nodes.

Build

go build -o comqtt cmd/cluster/main.go

Usage

./comqtt -h
Usage of ./comqtt:
  -http string
        network address for web info dashboard listener (default ":8080")
  -members string
        seeds member list of cluster,such as 192.168.0.103:7946,192.168.0.104:7946
  -mode
        optional value 1 single or 2 cluster (default 1)
  -gossip-port int
        listening port for cluster node,if this parameter is not set,then port is dynamically bound
  -raft-port int
        listening port for raft node,if this parameter is not set,then port is dynamically bound      
  -redis string
        redis address for cluster mode (default "localhost:6379")
  -tcp string
        network address for TCP listener (default ":1883")
  -ws string
        network address for Websocket listener (default ":1882")
  -conf string
        read the program parameters from the config file
Configure Redis

Start redis and configure redis addr in conf*.yml

Create Cluster

Start three nodes on one laptop

1. Start first node
./comqtt --mode=2 --gossip-port=7946 --raft-port=8701
or
./comqtt --conf=./conf.yml

You should see the output

CoMQTT Broker initializing...
TCP :1883
Websocket :1882
$SYS Dashboard :8080
Mqtt Server Started!  
A node has joined: 0dcbdda9-cf28-4e11-a527-28179eb176ad
Local member 192.168.0.103:7946
Cluster Node Created! 
2. Start second node with first node as part of the member list
./comqtt --mode=true --gossip-port=7947 --raft-port=8702 --members=localhost:7946 --tcp=:1885 --ws=:1886 --http=:1881
or
./comqtt --conf=./conf2.yml

You should see the output

CoMQTT Broker initializing...
TCP :1885
Websocket :1886
$SYS Dashboard :1887
Mqtt Server Started!  
A node has joined: 18d26675-d04f-4114-bea2-163e7a68a219
2022/03/17 00:20:44 [DEBUG] memberlist: Initiating push/pull sync with:  192.168.0.103:7946
A node has joined: 0dcbdda9-cf28-4e11-a527-28179eb176ad
Local member 192.168.0.103:7947
Cluster Node Created! 

First node output will log the new connection

2022/03/17 00:20:44 [DEBUG] memberlist: Stream connection from=192.168.0.103:49756
2022/03/17 00:20:45 [DEBUG] memberlist: Initiating push/pull sync with: 18d26675-d04f-4114-bea2-163e7a68a219 192.168.0.103:7947
3. Start third node with first node as part of the member list
./comqtt --mode=true --gossip-port=7948 --raft-port=8703 --members=localhost:7946 --tcp=:1887 --ws=:1888 --http=:1882
or
./comqtt --conf=./conf3.yml
Performance (messages/second)
mqtt-stresser -broker tcp://localhost:1883 -num-clients=500 -num-messages=100

Start two nodes on one laptop and test at the same time.

A laptop:MacBook Pro (13-inch, M1, 16G).

1. First Node

Publishing Throughput

Fastest: 215575 msg/sec

Slowest: 7336 msg/sec

Median: 72832 msg/sec

Receiving Througput

Fastest: 72040 msg/sec

Slowest: 463 msg/sec

Median: 704 msg/sec

####2. Second Node

Publishing Throughput

Fastest: 208207 msg/sec

Slowest: 1009 msg/sec

Median: 16794 msg/sec

Receiving Througput

Fastest: 305033 msg/sec

Slowest: 512 msg/sec

Median: 960 msg/sec

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL