Manage multiple apps across one or more k8s clusters.
Project description
GitOps
Manage multiple apps across one or more k8s clusters.
Overview
Using CI/CD for applications is a wonderful technique to ease the pain of DevOps,wouldn't it be nice to apply the same workflow to cluster provisioning?
GitOps is a two-part system. A library of commands is used to manage a single-tenanted cluster within a git repository, and the server component watches the repository and provisions the calculated changes.
Currently Kubernetes/Helm is the only supported cluster interface. All changes to the cluster are performed as applications of Helm charts.
Installation
Secrets should be placed in secrets.env. The example file secrets.example.env has the environment variables you will need to supply.
Gitops has a helm chart defining its deployment. Invoke scripts are provided to make deployment painless. See tasks.py.
Add export GITOPS_APPS_DIRECTORY=~/<cluster-apps-folder> to invoke gitops from any directory.
Roadmap
- Handle failure on initial application deployment.
- Better error reporting on failures.
- Forced redeployment interface.
- Make kubernetes specific code modular so that we can start to support multiple deployment methods.
- Invoke commands and other tools should be extracted from the uptick-cluster repo, added here and packaged up. Package should create /usr/bin/gitops to act as a CLI interface. Convert invoke commands to this new interface.
- Add a command to create a template cluster repo (ala uptick-cluster) and give instructions to push it up and set up a webhook.
Developer experience should look something like:
pip install gitops
gitops create-repository
-> Creates cluster repo (maybe with examples?)
-> Explains or pushes repo up somewhere.
-> Explains or sets up a webhook on that repo.
gitops create-secrets
-> Either downloads secrets from AWS using awscli or
-> Prompts for each secret individually.
gitops deploy-server
-> helm upgrade gitops chart... (see tasks.py:deploy)
# Use as normal anywhere you want (like uptick-cluster invoke scripts)
gitops summary
gitops bump```
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 Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gitops-0.3.23-py3-none-any.whl.
File metadata
- Download URL: gitops-0.3.23-py3-none-any.whl
- Upload date:
- Size: 24.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.54.0 CPython/3.8.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d542c5d12fe7e13187a72a97726a30eb95ea05de3c8f8b5ed54de7bb3902d6b9
|
|
| MD5 |
b81d064dc8851f4775be5694a179c237
|
|
| BLAKE2b-256 |
239e9b8c9f71822ccd1b50ad285814ad11516d70e3b3a5c28de5bfd413f0d88a
|