From 243c98ad0c656fcf0f81f3ce3ed0daecbcab014f Mon Sep 17 00:00:00 2001 From: postmannen Date: Fri, 16 Apr 2021 15:27:28 +0200 Subject: [PATCH] updated readme --- README.md | 39 +++++++++++++++++++++++++++++++++++---- 1 file changed, 35 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 6255d06..71635eb 100644 --- a/README.md +++ b/README.md @@ -246,8 +246,16 @@ clone the repository, then cd `./steward/cmd` and do `go build -o steward`, and ### How to Run +#### nats-server (the message broker) + The broker for messaging is Nats-server from . Download, run it, and use the `-brokerAddress` flag on Steward to point to it. +There is a lot of different variants of how you can setup and confiure Nats. Full mesh, leaf node, TLS, Authentication, and more. You can read more about how to configure the Nats broker called nats-server at . + +Some example configuration for the nats-server are located in the `doc` folder in this repository. + +#### Steward + On some central server which will act as your command and control server. `./steward --node="central"` @@ -258,6 +266,14 @@ One the nodes out there Use the `-help` flag to get all possibilities. +A complete example to start a central node called `central`. + +`./steward --nodeName="central" --defaultMessageRetries=3 --defaultMessageTimeout=5 -subscribersDataFolder="./data" --centralNodeName="central" -startSubREQErrorLog="*" -subscribersDataFolder="./var" -brokerAddress="127.0.0.1:4222"` + +And start another node that will be managed via central. + +`./steward --nodeName="ship1" -startPubREQHello=200 --centralNodeName="central" -promHostAndPort=":12112" -brokerAddress="127.0.0.1:4222"` + #### Start subscriber flags The start subscribers flags take a string value of which nodes that it will process messages from. Since using a flag to set a value automatically sets that value also in the config file, a value of RST can be given to turn off the subscriber. @@ -468,6 +484,23 @@ To send and Op Command to start a subscriber on a node ] ``` +Tail a log file on a node, and save the result of the tail centrally at the directory specified. + +```json +[ + { + "directory": "./my/log/files/", + "fileExtension": ".log", + "toNode": "ship2", + "data": ["./test.log"], + "method":"REQTailFile", + "ACKTimeout":5, + "retries":3, + "methodTimeout": 200 + } +] +``` + You can save the content to myfile.JSON and append it to the `socket` file. `nc -U ./steward.sock < example/toShip1-REQCliCommand.json` @@ -499,12 +532,10 @@ For CliCommand message to a node named "ship1" of type Command and it wants an A ## TODO -- Encryption between Node instances and brokers. - -- Authentication between node instances and brokers. +- Implement a workflow request type that will allow steps to be executed, and rollback if something failed during execution. ## Disclaimer -All code in this repository are to be concidered not-production-ready. The code are the attempt to concretize the idea of a purely async management system where the controlling unit is decoupled from the receiving unit, and that that we know the state of all the receiving units at all times. +All code in this repository are to be concidered not-production-ready, and the use is at your own responsibility. The code are the attempt to concretize the idea of a purely async management system where the controlling unit is decoupled from the receiving unit, and that that we know the state of all the receiving units at all times. Also read the license file for further details.