1
0
Fork 0
mirror of https://github.com/postmannen/ctrl.git synced 2025-01-18 21:59:30 +00:00
ctrl is an event driven infrastructure-controller / fleet-manager written in go
Find a file
2021-02-02 13:06:37 +01:00
cmd chanced it into it's own package 2021-02-01 11:13:38 +01:00
file.txt checking file for updates and reading content 2021-02-02 13:06:37 +01:00
getmessagefromfile.go checking file for updates and reading content 2021-02-02 13:06:37 +01:00
go.mod checking file for updates and reading content 2021-02-02 13:06:37 +01:00
go.sum checking file for updates and reading content 2021-02-02 13:06:37 +01:00
inmsg.txt checking file for updates and reading content 2021-02-02 13:06:37 +01:00
LICENSE Initial commit 2021-01-25 15:18:11 +01:00
publisher.go checking file for updates and reading content 2021-02-02 13:06:37 +01:00
README.md added type naming standard for subject and moved subscriber into the same package 2021-01-29 14:22:36 +01:00
subscriber.go Moved out the error handling from the process run 2021-02-01 13:41:04 +01:00

steward

Async management of Edge units.

Concepts/Ideas

Terminology

  • Node: An installation of an operating system with an ip address
  • Process: One message handler running in it's own thread with 1 subject for sending and 1 for reply.
  • Message:
    • Command: Something to be executed on the message received. An example can be a shell command.
    • Event: Something that have happened. An example can be transfer of syslog data from a host.

Naming

Subject

Subject naming are case sensitive, and can not contain the space are the tab character.

<nodename>.<command/event>.<method>

Nodename: Are the hostname of the device. This do not have to be resolvable via DNS, it is just a unique name for the host to receive the message.

Command/Event: Are type of message sent. command or event. Description of the differences are mentioned earlier.

Method: Are the functionality the message provide. Example could be shellcommand or syslogforwarding

Complete subject example

For syslog of type event to a host named "ship1"

ship1.event.syslogforwarding

and for a shell command of type command to a host named "ship2"

ship2.command.shellcommand