Skip to main content

Easy customization of kubernetes manifests

Project description

ksux

A simple way for templating kubernetes manifests.

Requirements

This is a python package. So the only requirements are python3 and pip

Installation

  • Optional: Create a virtual env.
# option 1: virualvenv
virtualvenv ksux
source ksux/bin/activate

# option 2: venv
python -m venv ksux
source ksux/bin/activate

# option 3: conda
conda create -n ksux python
conda activate ksux
  • Install
pip install ksux

How does it work?

tldr.

ksux -b <path_to_base_dir> -p <path_to_patches_dir> -o <output_dir>

Let's say that you have many manifests in some directory (base directory) that you wish to patch with patches (in the patches) directory.

Patches could be in yaml or json format (as well as your manifests). However, they must adhere to following schema:

name: <patch_description>
target:
  apiVersion: <apiVersion of targeted resource>
  kind: <Deployment type of targeted resource>
  name: <name of targeted resource>
ops:
  - name: <operation description>
    path: <path to the part of the manifest to be patched>
    value: <value which should be replaced or added>
    action: <add|replace|remove>

each patch file must be a list of patches. E.g.:

- name: deployment_patches
  target:
    apiVersion: apps/v1
    kind: Deployment
    name: web
  ops:
    - name: replace_image
      path: /spec/template/spec/containers/nginx/image
      value: nginx:1.23
      action: replace
- name: service_patches
  target:
    apiVersion: v1
    kind: Service
    name: nginx-service
  ops:
    - name: add_https_port
      path: /spec/ports
      value:
        name: https
        port: 443
        protocol: TCP
        targetPort: 443
      action: add
    - name: rename_http_port
      path: /spec/ports/http/name
      action: replace
      value: new_name

Then all you need to do, is run:

ksux -b <path_to_base_dir> -p <path_to_patches_dir> -o <output_dir>

This will save all patched manifests to the output dir. You can use the --dry-run flag

ksux -b <path_to_base_dir> -p <path_to_patches_dir> --dry-run

For list of all options see:

ksux --help

the op path

This is a pretty cool thing. Similar to kustomize path, however you can target list item by names of child objects. E.g. say you have a list of ports in a service:

apiVersion: v1
kind: Service
metadata:
  labels:
    app: nginx-service
  name: nginx-service
spec:
  ports:
    - name: new_name
      port: 80
      protocol: TCP
      targetPort: 80
    - name: https
      port: 443
      protocol: TCP
      targetPort: 443
  selector:
    app: web
  type: ClusterIP

To target the https service and change its name, you can specify the path: /spec/ports/https/name and then set the value to the new name 💪.

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

ksux-0.1.0.tar.gz (8.7 kB view details)

Uploaded Source

Built Distribution

ksux-0.1.0-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file ksux-0.1.0.tar.gz.

File metadata

  • Download URL: ksux-0.1.0.tar.gz
  • Upload date:
  • Size: 8.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for ksux-0.1.0.tar.gz
Algorithm Hash digest
SHA256 3ce4b36e26ae1cbd025217bb6bb619cefaead3f7c078b94cc04a2fc072618e87
MD5 e4fc2d20e82875cb6e1c3cef9dbc1ec3
BLAKE2b-256 be3b364d680d9ffa902f358e7db1ddf0dd54f919c350a2472bc600d6b14e70d7

See more details on using hashes here.

File details

Details for the file ksux-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: ksux-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for ksux-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5fcec7574a37bc8c21498d5a5f3d9b53b54a375b8dfc2261c076acd1cfdde544
MD5 0c7b18f6551ae63784e1c9b2c538411c
BLAKE2b-256 cd865d57f98ed473c713b15c3070a1ad3f8dc9c31ef11a9843ec1ff975ccf4d4

See more details on using hashes here.

Supported by

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