Skip to main content

Runs collector plugins and sends the result to fixcore.

Project description

fixworker

Fix worker daemon

Table of contents

Overview

fixworker does all the collection and cleanup work in Fix. It is connected to fixcore over a websocket connection and waits for instructions. By default it subscribes to the collect and cleanup actions as well as tag tasks.

fixworker loads collector plugins like AWS, GCP, Slack, Onelogin, etc. Only those plugins have knowledge about how to communicate with each cloud. How to collect resources and how to clean them up.

There can be one or more instances of fixworker in a Fix deployment. A single fixworker can collect many clouds or you could have multiple fixworker collecting one cloud or even one account in one cloud each.

More information can be found below and in the docs.

Usage

fixworker uses the following commandline arguments:

  --subscriber-id SUBSCRIBER_ID
                        Unique subscriber ID (default: fix.worker)
  --psk PSK             Pre-shared key
  --verbose, -v         Verbose logging
  --quiet               Only log errors
  --fixcore-uri FIXCORE_URI
                        fixcore URI (default: https://localhost:8900)
  --override CONFIG_OVERRIDE [CONFIG_OVERRIDE ...]
                        Override config attribute(s)
  --ca-cert CA_CERT     Path to custom CA certificate file
  --cert CERT           Path to custom certificate file
  --cert-key CERT_KEY   Path to custom certificate key file
  --cert-key-pass CERT_KEY_PASS
                        Passphrase for certificate key file
  --no-verify-certs     Turn off certificate verification

ENV Prefix: FIXWORKER_ Every CLI arg can also be specified using ENV variables.

For instance the boolean --fork would become FIXWORKER_FORK=true.

Details

Once fixworker is started you do not have to interact with it at all. It will just sit there, wait for work and do its job. The following are details on how fixworker works internally and how it integrates with fixcore.

Actions and Tasks

Think of actions and tasks like topics and queues in a messaging system. Actions are broadcast to everyone subscribed for that action. A task is always given to exactly one worker that knows how to handle it.

Actions

When the collect workflow within fixcore is triggered (by either an event or a schedule or because the user manually triggered it), fixcore will broadcast a "start collecting all the cloud accounts you know about" message to all the subscribed workers. Once all the workers finish collecting and sent their graph to the core, the workflow will proceed to the next step which would be plan_cleanup. This one tells anyone interested to start planing their cleanup based on the just collected graph data. Once everyone has planed their cleanup and flagged resources that should get cleaned up with the desired.clean = true flag, the workflow proceeds to the cleanup step which again notifies anyone subscribed to now perform cleanup of those flagged resources. Because the cleaner within fixworker has knowledge of all dependencies in the graph, it will ensure that resources are cleaned up in the right order.

Tasks

When a plugin or a user decides that a resource tag should be added, changed or removed, e.g. by running

search id = i-039e06bb2539e5484 | tag update owner lukas

fixcore will put this tagging task onto a task queue. This task is then consumed by a fixworker that knows how to perform tagging for that particular resource and its particular cloud and account. In our example above where we are setting the tag owner: lukas for an AWS EC2 instance with ID i-039e06bb2539e5484 the task would be given to a fixworker that knows how to update AWS EC2 instance tags in that resources account.

Contact

If you have any questions feel free to join our Discord or open a GitHub issue.

License

See LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fixinventoryworker-4.1.0.tar.gz (18.3 kB view details)

Uploaded Source

Built Distribution

fixinventoryworker-4.1.0-py3-none-any.whl (23.3 kB view details)

Uploaded Python 3

File details

Details for the file fixinventoryworker-4.1.0.tar.gz.

File metadata

  • Download URL: fixinventoryworker-4.1.0.tar.gz
  • Upload date:
  • Size: 18.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for fixinventoryworker-4.1.0.tar.gz
Algorithm Hash digest
SHA256 35246d9073334b1c76e535604129664488032b0fad41a9801d48c2cafa71e17d
MD5 329426f90e2bd841d82fb6101d53fffc
BLAKE2b-256 13729ec7be6f50bb9d5e4f41ce1a86d87ede6110ed31a0d5e713ea58695d0dd8

See more details on using hashes here.

File details

Details for the file fixinventoryworker-4.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for fixinventoryworker-4.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8cf5cd437be90d68f75e1068f8de78933022e8f325c18be07587b1beed95357d
MD5 8e7e30720f7edf088415ae17d72c7806
BLAKE2b-256 c65ff6e111ae5a45c3a063bfdd1a8ba3bc1344963c3effc7200456ef9b991707

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page