Skip to content

NGINX Ingress Operator for NGINX and NGINX Plus Ingress Controllers

License

Notifications You must be signed in to change notification settings

tetramin/nginx-ingress-operator

 
 

Repository files navigation

Continuous Integration

NGINX Ingress Operator

The NGINX Ingress Operator is a Kubernetes/OpenShift component which deploys and manages one or more NGINX/NGINX Plus Ingress Controllers which in turn handle Ingress traffic for applications running in a cluster.

Learn more about operators in the Kubernetes Documentation.

To install a specific version of the NGINX Ingress Controller with the operator, a specific version of the NGINX Ingress Operator is required.

The following table shows the relation between the versions of the two projects:

NGINX Ingress Controller NGINX Ingress Operator
1.10.x 0.1.0
1.9.x 0.0.7
1.8.x 0.0.6
1.7.x 0.0.4
< 1.7.0 N/A

Note: The NGINX Ingress Operator works only for NGINX Ingress Controller versions after 1.7.0.

Getting Started

  1. Install the NGINX Ingress Operator. See docs.
  2. Deploy a new NGINX Ingress Controller using the NginxIngressController Custom Resource:

NGINX Ingress Operator Releases

We publish NGINX Ingress Operator releases on GitHub. See our releases page.

The latest stable release is 0.1.0. For production use, we recommend that you choose the latest stable release.

Development

It is possible to run the operator in your local machine. This is useful for testing or during development.

Run Operator locally

  1. Have access to a Kubernetes/Openshift cluster.
  2. Apply the latest CRD:
    kubectl apply -f deploy/crds/k8s.nginx.org_nginxingresscontrollers_crd.yaml
    
  3. Apply the NGINX Ingress Controller CRDs:
    kubectl apply -f build/kic_crds
    
  4. Run make run-local.

The operator will run in your local machine but will be communicating with the cluster. The operator will only watch the default namespace when deployed locally.

Update CRD

If any change is made in the CRD in the go code, run the following commands to update the changes in the CRD yaml:

  1. make generate-crds
  2. Apply the new CRD definition again in your cluster kubectl apply -f deploy/crds/k8s.nginx.org_nginxingresscontrollers_crd.yaml.

Run tests

Run make test to run unit tests locally.

Contributing

If you'd like to contribute to the project, please read our Contributing guide.

About

NGINX Ingress Operator for NGINX and NGINX Plus Ingress Controllers

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 94.8%
  • Dockerfile 3.1%
  • Makefile 1.3%
  • Shell 0.8%