Skip to main content

The Python library behind great charms

Project description

The Charmed Operator Framework

This Charmed Operator Framework simplifies operator development for model-driven application management.

Operators emerged from the Kubernetes community; an operator is software that drives lifecycle management, configuration, integration and daily actions for an application. Operators simplify software management and operations. They capture reusable app domain knowledge from experts in a software component that can be shared.

This project extends the operator pattern to enable charmed operators, not just for Kubernetes but also operators for traditional Linux or Windows application management.

Operators use a Charmed Operator Lifecycle Manager (Charmed OLM) to coordinate their work in a cluster. The system uses Golang for concurrent event processing under the hood, but enables the operators to be written in Python.

Simple, composable operators

Operators should 'do one thing and do it well'. Each operator drives a single microservice and can be composed with other operators to deliver a complex application.

It is better to have small, reusable operators that each drive a single microservice very well. The operator handles instantiation, scaling, configuration, optimisation, networking, service mesh, observability, and day-2 operations specific to that microservice.

Operator composition takes place through declarative integration in the OLM. Operators declare integration endpoints, and discover lines of integration between those endpoints dynamically at runtime.

Pure Python operators

The framework provides a standard Python library and object model that represents the application graph, and an event distribution mechanism for distributed system coordination and communication.

The OLM is written in Golang for efficient concurrency in event handling and distribution. Operators can be written in any language. We recommend this Python framework for ease of design, development and collaboration.

Better collaboration

Operator developers publish Python libraries that make it easy to integrate your operator with their operator. The framework includes standard tools to distribute these integration libraries and keep them up to date.

Development collaboration happens at Charmhub.io where operators are published along with integration libraries. Design and code review discussions are hosted in the Charmhub discourse. We recommend the Open Operator Manifesto as a guideline for high quality operator engineering.

Event serialization and operator services

Distributed systems can be hard! So this framework exists to make it much simpler to reason about operator behaviour, especially in complex deployments. The Charmed OLM provides operator services such as provisioning, event delivery, leader election and model management.

Coordination between operators is provided by a cluster-wide event distribution system. Events are serialized to avoid race conditions in any given container or machine. This greatly simplifies the development of operators for high availability, scale-out and integrated applications.

Model-driven Operator Lifecycle Manager

A key goal of the project is to improve the user experience for admins working with multiple different operators.

We embrace model-driven operations in the Charmed Operator Lifecycle Manager. The model encompasses capacity, storage, networking, the application graph and administrative access.

Admins describe the application graph of integrated microservices, and the OLM then drives instantiation. A change in the model is propagated to all affected operators, reducing the duplication of effort and repetition normally found in operating a complex topology of services.

Administrative actions, updates, configuration and integration are all driven through the OLM.

Getting started

A package of operator code is called a charmed operator or “charm. You will use charmcraft to register your operator name, and publish it when you are ready. There are more details on how to get a complete development environment setup over in the documentation

Charmed Operators written using the Charmed Operator Framework are just Python code. The goal is to feel natural for somebody used to coding in Python, and reasonably easy to learn for somebody who is not a pythonista.

The dependencies of the operator framework are kept as minimal as possible; currently that's Python 3.5 or greater, and PyYAML (both are included by default in Ubuntu's cloud images from 16.04 on).

For a brief intro on how to get started, check out the Hello, World! section of the documentation!

Testing your charmed operators

The operator framework provides a testing harness, so you can check your charmed operator does the right thing in different scenarios, without having to create a full deployment. pydoc3 ops.testing has the details, including this example:

harness = Harness(MyCharm)
# Do initial setup here
relation_id = harness.add_relation('db', 'postgresql')
# Now instantiate the charm to see events as the model changes
harness.begin()
harness.add_relation_unit(relation_id, 'postgresql/0')
harness.update_relation_data(relation_id, 'postgresql/0', {'key': 'val'})
# Check that charm has properly handled the relation_joined event for postgresql/0
self.assertEqual(harness.charm. ...)

Talk to us

If you need help, have ideas, or would just like to chat with us, reach out on the Charmhub Mattermost.

We also pay attention to the Charmhub Discourse

You can deep dive into the API docs if that's your thing.

Operator Framework development

To work in the framework itself you will need Python >= 3.5. Linting, testing, and docs automation is performed using tox.

The following are likely to be useful during development:

# Run linting and unit tests
tox

# Run tests, specifying whole suite or specific files
tox -e unit
tox -e unit test/test_charm.py

# Format the code using isort
tox -e fmt

# Generate a local copy of the Sphinx docs in docs/_build
tox -e docs

For more in depth debugging, you can enter any of tox's created virtualenvs provided they have been run at least once:

# Enter the unit testing virtualenv
source .tox/unit/bin/activate

# Enter the linting virtualenv
source .tox/lint/bin/activate

For improved performance on the tests, ensure that you have PyYAML installed with the correct extensions:

apt-get install libyaml-dev
pip install --force-reinstall --no-cache-dir pyyaml

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

ops-1.3.0.tar.gz (197.1 kB view details)

Uploaded Source

Built Distribution

ops-1.3.0-py3-none-any.whl (132.0 kB view details)

Uploaded Python 3

File details

Details for the file ops-1.3.0.tar.gz.

File metadata

  • Download URL: ops-1.3.0.tar.gz
  • Upload date:
  • Size: 197.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.3 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for ops-1.3.0.tar.gz
Algorithm Hash digest
SHA256 a7589e3e6eabce44c5f2e7edb78d62987128364a168b7b12cddb7fa446d99b17
MD5 019cf24313cd91cff7b148219e0814dd
BLAKE2b-256 04e85d71147b77dc77a5417ba705c191a91cc06a8e7fc907cb25120eca9d6495

See more details on using hashes here.

File details

Details for the file ops-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: ops-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 132.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.3 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for ops-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 37ccca420ba995abec2c39ef396fb9c643db246ac290c8380166f54e982d2770
MD5 53c4a2f58d3a162ed96fc3d842cc9f75
BLAKE2b-256 2b70386218534053deb623f8848392e3ec276cda66c4c5f03e4525c8d3d797b5

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