Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jtblin/nginx-k8s
nginx reverse proxy for kubernetes which automagically serves all services based on their domain name.
https://github.com/jtblin/nginx-k8s
Last synced: 19 days ago
JSON representation
nginx reverse proxy for kubernetes which automagically serves all services based on their domain name.
- Host: GitHub
- URL: https://github.com/jtblin/nginx-k8s
- Owner: jtblin
- License: other
- Created: 2015-12-13T11:01:31.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2015-12-13T11:34:19.000Z (about 9 years ago)
- Last Synced: 2024-10-28T09:07:04.839Z (2 months ago)
- Language: Nginx
- Size: 2.93 KB
- Stars: 5
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# nginx-k8s
Simple nginx reverse proxy for [kubernetes](http://kubernetes.io) which automagically serves all services
deployed on k8s based on domain name.## Usage
git clone [email protected]:jtblin/nginx-k8s.git
Update "mydomain.tld" in [default.conf](./default.conf) with your domain name:
"~^(www\.)?(?.+)\.mydomain\.tld$";
Build the docker image:
docker build -t myrepo/nginx-k8s .
Update the `PROXY_DOMAIN` environment variable in [nginx-k8s.yaml](./nginx-k8s.yaml) with the url of your k8s api
server, the image name, and create the replication and service controller.docker push myrepo/nginx-k8s
kubectl create -f nginx-k8s.yamlFind the node ports (`NodePort`) of your `nginx-k8s` service:
kubectl describe svc nginx
Create a load balancer including all kubernetes nodes (not the master) with a listener on the `http` node port.
You can terminate SSL on the ELB and add a healthcheck pointing to the `health` NodePort of the `nginx` service
for the path `/healthz`.Deploy services to your kubernetes cluster, and set their domain name in your registar pointing to the
load balancer created above. The subdomain part of the FQDN needs to be the same as the k8s service name. Profit!## Specs, caveats and rationale
* The image is based on `alpine` linux so it is quite small (15Mb).
* This works because services are accessible on k8s at `/api/v1/proxy/namespaces/default/services/`.
* This config will only work for the `default` namespace. If you want to use a different namespace, update accordingly.
* This only works for services that expose only one port. If you need to expose more ports, just create more services.
* The overhead of going through the kube proxy might not be suitable for production use.
* This was done in anger because of the limitations with the current `LoadBalancer` type in k8s.
* Requires DaemonSets extension (from v1.1): http://kubernetes.io/v1.1/docs/admin/daemons.html