Copper is the basic material for creating pipelines. It helps to run local actions with docker.
Copper offers three basic services
- MQTT broker to manage services end points
- fetcher executes fetch actions such as retrieve repos from github
- runner bootstraps execution of actions from a yaml workflow file
see this example repo for how to use copper in a light weight mode with a docker compose file and a workflow file
https://github.com/HomeSmartMesh/website_light/tree/main
In this repo, copper is cloned as a submodule for development purpose
https://github.com/HomeSmartMesh/website_services
A workflow is a list of actions, where each has an action
field. This field represents the MQTT topic on which the service endpoint is provided.
- A runner service will publish each action entry on its topic to trigger it
- it will then await the finish topic e.g.
fetcher/fetch/finish
- Then continue with the next entry
- action: fetcher/fetch
type: github
repository: MicroWebStacks/astro-big-doc
ref: main
filter: content/*
resource: test-website
- action: markdown/build
resource: test-website
path: /fetch/test-website/content
a service consists of
- a docker container as a Dockerfile or folder
- an mqtt client to manage services and events
- optionally for bootstrapping a MANIFEST environemnt variable can be passed to use a local file
- Services lifecycle management
- start and stop a service
- Lambda single shot a service for a single request
- Requests
- subscribe to offer a service
- publish to trigger
- publish status and completion
- Resources
- subscribe to consume
- publish to produce
- a core service within copper
- a local repo service
- a remote url service
- collection of mosquitto logs allows to trace services publish and subscribe to generate a dependencies graph
two types of corss services interactions will be used :
-
Event based
- suitable for long running jobs
- single instance
- central MQTT broker
A slow interaction is an an operation that
- can require a long time to process such as more than 30s or minutes or hours.
- is only initiated by a single service client
- requests do not need to be queued
- is needed sporadically or scheduled with jobs which period is necessarily bigger if not significantly bigger than the time it takes them to complete
-
REST API
- suitable for fast running jobs
- multiple instances of independent clients
- http REST API
A fast interaction is an an operation that
- completes necessarily within less any default request timeout config
- can be initiated by any number of independent clients
- requests need to be queued
- is needed very frequently such as converting a high number of files
as alternative to wrapping everything in a service API call, it is possible to execute docker commands from within docker with the Docker-in-Docker approach. This requires mounting the docker socket to communicate with the daemon.
- remove PyYaml could not isntall on windows and dependabot alert
- make filter optional and support glob variant