3.3 KiB
Exposing containers
-
kubectl exposecreates a service for existing pods -
A service is a stable address for a pod (or a bunch of pods)
-
If we want to connect to our pod(s), we need to create a service
-
Once a service is created,
kube-dnswill allow us to resolve it by name(i.e. after creating service
hello, the namehellowill resolve to something) -
There are different types of services, detailed on the following slides:
ClusterIP,NodePort,LoadBalancer,ExternalName
Basic service types
-
ClusterIP(default type)- a virtual IP address is allocated for the service (in an internal, private range)
- this IP address is reachable only from within the cluster (nodes and pods)
- our code can connect to the service using the original port number
-
NodePort- a port is allocated for the service (by default, in the 30000-32768 range)
- that port is made available on all our nodes and anybody can connect to it
- our code must be changed to connect to that new port number
These service types are always available.
Under the hood: kube-proxy is using a userland proxy and a bunch of iptables rules.
More service types
-
LoadBalancer- an external load balancer is allocated for the service
- the load balancer is configured accordingly
(e.g.: aNodePortservice is created, and the load balancer sends traffic to that port)
-
ExternalName- the DNS entry managed by
kube-dnswill just be aCNAMEto a provided record - no port, no IP address, no nothing else is allocated
- the DNS entry managed by
The LoadBalancer type is currently only available on AWS, Azure, and GCE.
Running containers with open ports
- Since
pingdoesn't have anything to connect to, we'll have to run something else
.exercise[
-
Start a bunch of ElasticSearch containers:
kubectl run elastic --image=elasticsearch:2 --replicas=7 -
Watch them being started:
kubectl get pods -w
]
The -w option "watches" events happening on the specified resources.
Note: please DO NOT call the service search. It would collide with the TLD.
Exposing our deployment
- We'll create a default
ClusterIPservice
.exercise[
-
Expose the ElasticSearch HTTP API port:
kubectl expose deploy/elastic --port 9200 -
Look up which IP address was allocated:
kubectl get svc
]
Services are layer 4 constructs
-
You can assign IP addresses to services, but they are still layer 4
(i.e. a service is not an IP address; it's an IP address + protocol + port)
-
This is caused by the current implementation of
kube-proxy(it relies on mechanisms that don't support layer 3)
-
As a result: you have to indicate the port number for your service
-
Running services with arbitrary port (or port ranges) requires hacks
(e.g. host networking mode)
Testing our service
- We will now send a few HTTP requests to our ElasticSearch pods
.exercise[
-
Let's obtain the IP address that was allocated for our service, programatically:
IP=$(kubectl get svc elastic -o go-template --template '{{ .spec.clusterIP }}') -
Send a few requests:
curl http://$IP:9200/
]
--
Our requests are load balanced across multiple pods.