An open API service indexing awesome lists of open source software.

https://github.com/openshift/router

Ingress controller for OpenShift
https://github.com/openshift/router

Last synced: 5 months ago
JSON representation

Ingress controller for OpenShift

Awesome Lists containing this project

README

          

openshift-router
================

This repository contains the OpenShift routers for NGINX, HAProxy, and F5. They read `Route` objects out of the
OpenShift API and allow ingress to services. HAProxy is currently the reference implementation. See the details
in each router image.

These images are managed by the `cluster-ingress-operator` in an OpenShift 4.0+ cluster.

The template router code (`openshift-router`) is generic and creates config files on disk based on the state
of the cluster. The process launches proxies as children and triggers reloads as necessary after new config
has been written. The standard logic for handling conflicting routes, supporting wildcards, reporting status
back to the Route object, and metrics live in the standard process.

Deploying to Kubernetes
-----------------------

The OpenShift router can be run against a vanilla Kubernetes cluster, although some of the security protections
present in the API are not possible with CRDs.

To deploy, clone this repository and then run:

$ kubectl create -f deploy/

You will then be able to create a `Route` that points to a service on your cluster and the router pod will
forward your traffic from port 80 to your service endpoints. You can run the example like:

$ kubectl create -f example/

And access the router via the node it is located on. If you're running locally on minikube or another solution,
just run:

$ curl http://localhost -H "Host: example.local"

to see your route and:

$ kubectl get routes

to see details of your routes.