mirror of
https://github.com/postmannen/ctrl.git
synced 2025-01-20 22:52:13 +00:00
updated readme
This commit is contained in:
parent
64a22c84e9
commit
243c98ad0c
1 changed files with 35 additions and 4 deletions
39
README.md
39
README.md
|
@ -246,8 +246,16 @@ clone the repository, then cd `./steward/cmd` and do `go build -o steward`, and
|
||||||
|
|
||||||
### How to Run
|
### How to Run
|
||||||
|
|
||||||
|
#### nats-server (the message broker)
|
||||||
|
|
||||||
The broker for messaging is Nats-server from <https://nats.io>. Download, run it, and use the `-brokerAddress` flag on Steward to point to it.
|
The broker for messaging is Nats-server from <https://nats.io>. 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 <https://nats.io/>.
|
||||||
|
|
||||||
|
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.
|
On some central server which will act as your command and control server.
|
||||||
|
|
||||||
`./steward --node="central"`
|
`./steward --node="central"`
|
||||||
|
@ -258,6 +266,14 @@ One the nodes out there
|
||||||
|
|
||||||
Use the `-help` flag to get all possibilities.
|
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
|
#### 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.
|
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.
|
You can save the content to myfile.JSON and append it to the `socket` file.
|
||||||
|
|
||||||
`nc -U ./steward.sock < example/toShip1-REQCliCommand.json`
|
`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
|
## TODO
|
||||||
|
|
||||||
- Encryption between Node instances and brokers.
|
- Implement a workflow request type that will allow steps to be executed, and rollback if something failed during execution.
|
||||||
|
|
||||||
- Authentication between node instances and brokers.
|
|
||||||
|
|
||||||
## Disclaimer
|
## 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.
|
Also read the license file for further details.
|
||||||
|
|
Loading…
Add table
Reference in a new issue