This container image can be deployed on a Kubernetes cluster. It runs a web app, that displays the following:
- a default Hello Kubernetes! message
- namespace, pod, and node details
- container image details
$ curl http://192.168.49.2:31285/hello-kubernetes -X POST | jq
{
"message": "Hello Kubernetes!",
"namespace": "hello-kubernetes",
"pod": "hello-kubernetes-hello-kubernetes-d9d468894-tns46",
"podIP": "10.244.0.11",
"node": "minikube (Linux 5.13.0-28-generic)",
"reqProtocol": "http",
"reqHostname": "192.168.49.2",
"reqPath": "/",
"reqMethod": "POST",
"container": "eduardobaitello/hello-kubernetes:2.0.0 (linux/amd64)"
}
You can deploy hello-kubernetes
to your Kubernetes cluster using Helm 3. The Helm chart installation and configuration options can be found in the Deploy using Helm guide.
When running through the following examples, ensure that you are in the chart directory in the repo, since you are referencing a local helm chart.
cd deploy/helm
Deploy the hello-kubernetes
app into the hello-kubernetes
namespace with the default "Hello world!" message. The app is exposed via a public Load Balancer on port 80 by default - note that a LoadBalancer service typically only works in cloud provider based Kubernetes offerings.
helm install --create-namespace --namespace hello-kubernetes hello-world ./hello-kubernetes
# get the LoadBalancer ip address.
kubectl get svc hello-kubernetes-hello-world -n hello-kubernetes -o 'jsonpath={ .status.loadBalancer.ingress[0].ip }'
Deploy the hello-kubernetes
app into the hello-kubernetes
namespace with an "I just deployed this on Kubernetes!" message. The app is exposed via a public Load Balancer on port 80 by default - note that a LoadBalancer service typically only works in cloud provider based Kubernetes offerings.
helm install --create-namespace --namespace hello-kubernetes custom-message ./hello-kubernetes \
--set message="I just deployed this on Kubernetes!"
# get the LoadBalancer ip address.
kubectl get svc hello-kubernetes-custom-message -n hello-kubernetes -o 'jsonpath={ .status.loadBalancer.ingress[0].ip }'
Deploy the hello-kubernetes
app into the hello-kubernetes
namespace. This example assumes that an ingress has been deployed and configured in the cluster, and that the ingress has a path of /app/hello-kubernetes/
mapped to the hello-kubernetes
service.
The hello-kubernetes
app can be reached on the ip address of the ingress via the /app/hello-kubernetes/
path.
helm install --create-namespace --namespace hello-kubernetes ingress ./hello-kubernetes \
--set ingress.enabled=true \
--set ingress.pathPrefix="/app/hello-kubernetes/" \
--set service.type="ClusterIP"
If you'd like to explore the various Helm chart configuration options, then read the Deploy with Helm documentation. You can also discover more about the ingress configuration options in the Deploy with ingress documentation
If you'd like to build the hello-kubernetes
container image yourself and reference from your own registry or DockerHub repository, then you can get more details on how to do this in the Build and push container images documentation.