The main tool to build, upload, and develop in general the Juju charms.
Project description
Charmcraft is for Kubernetes operator developers
Charmcraft supports Kubernetes operator development.
Charmcraft enables collaboration between charmed operator developers, and publication on Charmhub, home of the Charmed Operator Collection.
Use charmcraft
to:
- Init a new charmed operator file structure
- Build your operator into a charmed operator for distribution
- Register your charmed operator name on Charmhub
- Upload your charmed operators to Charmhub
- Release your charmed operators into channels
You can use charmcraft with operators written in any language but we recommend the Python Operator Framework on Github which is also on PyPI for ease of development and collaboration.
Charmcraft and the Charmed Operator Framework extend the operator pattern beyond Kubernetes with universal operators that drive Linux and Windows apps. The universal operator pattern is very exciting for multi-cloud application management.
Install
The easiest way to install charmcraft
is with
sudo snap install charmcraft --beta
There are multiple channels other than --beta
. See the full list with
snap info charmcraft
. We recommend either latest/stable
or latest/beta
for everyday charming. With the snap you will always be up to date as
Charmhub services and APIs evolve.
You can also install from PyPI with pip3 install --user charmcraft
Initialize a charm operator package file structure
Use charmcraft init
to create a new template charm operator file tree:
$ mkdir my-new-charm; cd my-new-charm
$ charmcraft init
Charm operator package file and directory tree initialized.
TODO:
README.md: Describe your charm in a few paragraphs of Markdown
README.md: Provide high-level usage, such as required config or relations
actions.yaml: change this example to suit your needs.
config.yaml: change this example to suit your needs.
metadata.yaml: fill out the charm's description
metadata.yaml: fill out the charm's summary
metadata.yaml: replace with containers for your workload (delete for non-k8s)
metadata.yaml: each container defined above must specify an oci-image resource
src/charm.py: change this example to suit your needs.
src/charm.py: change this example to suit your needs.
src/charm.py: change this example to suit your needs.
You will now have all the essential files for a charmed operator, including
the actual src/charm.py
skeleton and various items of metadata. Charmcraft
assumes you want to work in Python so it will add requirements.txt
with
the Python operator framework ops
, and other conventional development
support files.
Build your charm
With a correct metadata.yaml
and with ops
in requirements.txt
you can
build a charmed operator with:
$ charmcraft build
Created 'test-charm.charm'.
charmcraft build
will fetch additional files into the tree from PyPI based
on requirements.txt
and will compile modules using a virtualenv.
The charmed operator is just a zipfile with metadata and the operator code itself:
$ unzip -l test-charm.charm
Archive: test-charm.charm
Length Date Time Name
--------- ---------- ----- ----
221 2020-11-15 08:10 metadata.yaml
[...]
25304 2020-11-15 08:14 venv/yaml/__pycache__/scanner.cpython-38.pyc
--------- -------
812617 84 files
Now, if you have a Kubernetes cluster with the Juju OLM accessible you can issue
juju deploy ./my-new-charm.charm --resource httpbin-image=kennethreitz/httpbin
.
You do not need to publish your operator on Charmhub, you can pass the charmed
operator file around directly to users, or for CI/CD purposes.
Charmhub login and charm name reservations
Charmhub is the world's largest repository of operators. It makes it easy to share and collaborate on operators. The community are interested in operators for a very wide range of purposes, including infrastructure-as-code and legacy application management, and of course Kubernetes operators.
Use charmcraft login
and charmcraft logout
to sign into Charmhub.
Charmhub name registration
You can register operator names in Charmhub with charmcraft register <name>
.
Many common names have been reserved, you are encouraged to discuss your
interest in leading or collaborating on a charmed operator in
Charmhub Discourse.
Charmhub naming policy is the principle of least surprise - a well-known name should map to an operator that most people would expect to get for that name.
Operators in Charmhub can be renamed as needed, so feel free to register a temporary name, such as - as a placeholder.
Operator upload and release
Charmhub operators are published in channels, like:
latest/stable
latest/candidate
latest/beta
latest/edge
1.3/beta
1.3/edge
1.2/stable
1.2/candidate
1.0/stable
Use charmcraft upload
to get a new revision number for your freshly built
charmed operator, and charmcraft release
to release a revision into any
particular channel for your users.
Charmcraft source
Get the source from github with:
git clone https://github.com/canonical/charmcraft.git
cd charmcraft
virtualenv venv
. venv/bin/activate
pip install -r requirements.txt
python -m charmcraft
If you would like to run the tests you can do so with
pip install -r requirements-dev.txt
./run_tests
Contributions welcome!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file charmcraft-1.0.0.tar.gz
.
File metadata
- Download URL: charmcraft-1.0.0.tar.gz
- Upload date:
- Size: 61.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bdf5cd1400c5111eccd838ebe0852ff757e8252888f0f8714903c4f66bfc06a0 |
|
MD5 | f5d469b8df23cd1dee9917e0e9bf4320 |
|
BLAKE2b-256 | 120c8ee129e9d079c12b2a0b38a57512c56832c76a7df8d20ba417f3295b0009 |
File details
Details for the file charmcraft-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: charmcraft-1.0.0-py3-none-any.whl
- Upload date:
- Size: 74.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 83e4caeff2e304b99a7e0fbb7fda717789b8ae13ce49efd4f1e739f52da69339 |
|
MD5 | 0511d27d42933e7839b27f5b30dc98c1 |
|
BLAKE2b-256 | ebc8e5f8d9ef373deb86e15440710140596af9a91c89e951467a4499f7fa36aa |