๐Ÿ“ฆ Kong / kong-operator

Kubernetes Operator for Kong Gateways

โ˜… 88 stars โ‘‚ 31 forks ๐Ÿ‘ 88 watching โš–๏ธ Apache License 2.0
team-k8s
๐Ÿ“ฅ Clone https://github.com/Kong/kong-operator.git
HTTPS git clone https://github.com/Kong/kong-operator.git
SSH git clone git@github.com:Kong/kong-operator.git
CLI gh repo clone Kong/kong-operator
Patryk Maล‚ek Patryk Maล‚ek chore: add test and manifest sample for cross namespace KongCertificate -> Secret ref (#3094) 5a2fdf7 11 minutes ago ๐Ÿ“ History
๐Ÿ“‚ main View all commits โ†’
๐Ÿ“ .github
๐Ÿ“ api
๐Ÿ“ charts
๐Ÿ“ cmd
๐Ÿ“ config
๐Ÿ“ controller
๐Ÿ“ docs
๐Ÿ“ hack
๐Ÿ“ ingress-controller
๐Ÿ“ internal
๐Ÿ“ logo
๐Ÿ“ modules
๐Ÿ“ pkg
๐Ÿ“ scripts
๐Ÿ“ test
๐Ÿ“„ .dockerignore
๐Ÿ“„ .gitattributes
๐Ÿ“„ .gitignore
๐Ÿ“„ .golangci.yaml
๐Ÿ“„ .mise.toml
๐Ÿ“„ .mockery.yaml
๐Ÿ“„ CHANGELOG.md
๐Ÿ“„ CODEOWNERS
๐Ÿ“„ debug.Dockerfile
๐Ÿ“„ Dockerfile
๐Ÿ“„ FEATURES.md
๐Ÿ“„ go.mod
๐Ÿ“„ go.sum
๐Ÿ“„ LICENSE
๐Ÿ“„ LICENSES
๐Ÿ“„ Makefile
๐Ÿ“„ osv-scanner.toml
๐Ÿ“„ PROJECT
๐Ÿ“„ README.md
๐Ÿ“„ renovate.json
๐Ÿ“„ SECURITY.md
๐Ÿ“„ skaffold.yaml
๐Ÿ“„ VERSION
๐Ÿ“„ README.md

Kong Operator

KGO logo

Kong Operator is a Kubernetes Operator that can manage your Kong Ingress Controller, Kong Gateway Data Planes, or both together when running on Kubernetes.

With Kong Operator, users can:

  • Deploy and configure Kong Gateway services.
  • Customise deployments using PodTemplateSpec to:
  • [Set image],

Current Features

The following features are considered supported:

  • Kong Gateway Deployment & Configuration Management using the Gateway API
  • Creation of Kong Gateways using the DataPlane API
  • Kong Gateways upgrades, downgrades and autoscaling
  • Creation of Kong Ingress Controller instances using the ControlPlane API
  • Hybrid Mode Attachment using the DataPlane API
  • Configuration and management of AIGateways (experimental feature)
See our Features Page for details on these capabilities.

API stability

The operator provides 2 APIs:

  • YAML / manifests API which users use to apply their manifests against Kubernetes clusters.
  • Go API through types exported under api/
and other exported packages.

This project:

  • Follows [Kubernetes API versioning] for the YAML API.
  • This is considered part of the user contract.
  • Tries to not break users implementing against operator's Go API but does not
offer a non breaking guarantee.

Quick Start and documentation

If you are eager to start with the operator, you can visit the quick start section of the documentation. Alternatively, the complete docs provide a full and detailed description of how to thoroughly use this project.

Container images

Release images

Release builds can be found on Docker Hub in kong/kong-operator repository.

At the moment we're providing images for:

  • Linux amd64
  • Linux arm64

main branch builds

Nightly pre-release builds of the main branch are available from the kong/nightly-kong-operator repository hosted on Docker Hub.

Development

Prerequisites

In order to build the operator you'll have to have Go installed on your machine. In order to do so, follow the instructions on its website[go-dev-site].

Build process

Building the operator should be as simple as running:

make build

This Makefile target will take care of everything from generating client side code, generating Kubernetes manifests, downloading the dependencies and the tools used in the build process and finally, it will build the binary.

After this step has finished successfully you should see the operator's binary bin/manager.

You can also run it directly via make run which will run the operator on your machine against the cluster that you have configured via your KUBECONFIG.

Adding new CRDs

Whenever you add a new CRD:

  • Ensure that it is included in project's PROJECT file. This is necessary for creation of
a bundle for external hubs like Operator Hub's community operators.
  • Annotate the CRD and any new type it depends on with the right markers to make sure it will be included
in the generated documentation. See the markers used in scripts/crds-generator for reference.

Install the Nightly Build

Every night a new container image is built from the main development branch.

It can be installed using the helm chart from the main repo:

git clone https://github.com/kong/kong-operator && cd kong-operator

helm upgrade --install kong-operator ./charts/kong-operator -n kong-system \
  --create-namespace \
  --set image.tag=nightly \
  --set image.repository=kong/nightly-kong-operator \
  --set env.ENABLE_CONTROLLER_KONNECT=true

[!NOTE]
When using the nightly tag the operator version assumed is the one of the Chart.appversion, which is set to the latest release.
If a specific version is required (e.g., to enable version-gated features) you can specify it by adding the --set image.effectiveSemver=<DESIRED_VERSION> argument.

Seeking Help

Please search through the posts on the discussions page as it's likely that another user has run into the same problem. If you don't find an answer, please feel free to post a question.

If you've found a bug, please open an issue.

For a feature request, please open an issue using the feature request template.

You can also talk to the developers behind Kong in the #kong channel on the Kubernetes Slack server.

Community Meetings

You can join bi-weekly meetups hosted by Kong to ask questions, provide feedback, or just to listen and hang out.

See the Online Meetups Page to sign up and receive meeting invites and Zoom links.