Skip to main content

Nginx sidecar container abstractions for k8s charms.

Project description

nginx-k8s

nginx-k8s provides abstractions for Juju Charms to run a sidecar Nginx container and a corresponding Prometheus exporter. The supported Nginx configuration is not meant to fully cover all Nginx features, but a minimal subset sufficient to cover our immediate use cases.

To install, add charmlibs-nginx-k8s to your requirements. Then in your Python code, import as:

from charmlibs import nginx_k8s

Check out the reference docs on the charmlibs docsite.

Getting started

To get started, you can add two sidecar containers to your charm's charmcraft.yaml and in charm.py, instantiate the Nginx and NginxPrometheusExporter classes in your initializer and call their .reconcile() methods whenever you wish to synchronize the configuration files.

import ops

from charmlibs import nginx_k8s


class MyCharm(ops.CharmBase):
    def __init__(self, framework: ops.Framework):
        super().__init__(framework)
        self._nginx = nginx_k8s.Nginx(
            self.unit.get_container("nginx"),  # container name as defined in charmcraft.yaml
            nginx_config=nginx_k8s.NginxConfig(
                server_name="foo",
                upstream_configs=[
                    nginx_k8s.NginxUpstream(name="foo", port=4040, group="backend"),
                    nginx_k8s.NginxUpstream(name="bar", port=4041, group="frontend"),
                ],
                server_ports_to_locations={8080: [
                    nginx_k8s.NginxLocationConfig(
                        path="/", 
                        backend="foo", 
                        backend_url="/api/v1", 
                        headers={"a": "b"},
                        modifier="=",
                        is_grpc=True, 
                        upstream_tls=True
                    ),
                ]}
            )
        )
        self._nginx_pexp = nginx_k8s.NginxPrometheusExporter(
            self.unit.get_container('nginx-pexp-container')
        )

        self.framework.observe(self.on.nginx_container_pebble_ready, self._on_reconcile)
        self.framework.observe(self.on.nginx_pexp_container_pebble_ready, self._on_reconcile)

    def _on_reconcile(self, _):
        self._nginx.reconcile(
            upstreams_to_addresses={
                "foo": {"http://example.com"},
                "bar": {"http://example.io"},
            }
        )
        self._nginx_pexp.reconcile()

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

charmlibs_nginx_k8s-0.0.1.post0.tar.gz (27.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

charmlibs_nginx_k8s-0.0.1.post0-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file charmlibs_nginx_k8s-0.0.1.post0.tar.gz.

File metadata

File hashes

Hashes for charmlibs_nginx_k8s-0.0.1.post0.tar.gz
Algorithm Hash digest
SHA256 f0da7e64025c45fe984f2c0cf54e4c1cf7183e5121ee3038c29d3c6512d6b45a
MD5 f7b48472cabce19b38cfcb3eb26d2f49
BLAKE2b-256 4107e5a5a3b73e3f29c405dd93d292c34dd6740611a01c669eb397d73d2ec4ca

See more details on using hashes here.

Provenance

The following attestation bundles were made for charmlibs_nginx_k8s-0.0.1.post0.tar.gz:

Publisher: publish.yaml on canonical/charmlibs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file charmlibs_nginx_k8s-0.0.1.post0-py3-none-any.whl.

File metadata

File hashes

Hashes for charmlibs_nginx_k8s-0.0.1.post0-py3-none-any.whl
Algorithm Hash digest
SHA256 fae69f2691abbc20aaddf826ad0c42733296f698ca7cf1063bfba605566fc574
MD5 dd32545d94d201b2d2e875c9d897a3ab
BLAKE2b-256 5b6de0be380d8bf0b456140a1b3ab7c763200dc209f89e61b6d33af7f99dbc90

See more details on using hashes here.

Provenance

The following attestation bundles were made for charmlibs_nginx_k8s-0.0.1.post0-py3-none-any.whl:

Publisher: publish.yaml on canonical/charmlibs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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