< Previous Challenge - Home - Next Challenge >
We started out with some very simple, default networking that Kubernetes gives us for free. But this is rarely what we'll need to go into production. Now we'll get a little more in depth on networking in Kubernetes, and investigate DNS as well as Ingress Controllers.
In this challenge you will be enabling DNS, installing an Ingress Controller and learning how the "Ingress" resource in Kubernetes works.
In the previous challenges, we accessed our service via an IP address. Humans prefer names to IP addresses, so let's create a DNS name for accessing our service.
- Your first task is to add a dns label to your content-web service.
- Your service should now be available at the url http://[myserviceuniquelabel].[location].cloudapp.azure.com.
- Verify that the DNS record has been created (nslookup or dig), and then test this url in your browser.
- Discuss with your coach how you might link a 'real' DNS name (eg, conferenceinfo.fabmedical.com) with this "azure-specific" DNS name (eg, conferenceinfo.eastus.cloudapp.azure.com)
Switching gears, we will now start working with ingress controllers, which allow you to route http requests.
- Delete the existing content-web service.
- Create an nginx ingress controller. (Hint: use helm)
- Deploy the content-web service and create an Ingress resource for it.
- The reference template (which will need editing!) can be found in the Challenge 10 Resources folder:
template-web-ingress-deploy.yaml
- The reference template (which will need editing!) can be found in the Challenge 10 Resources folder:
- Show your coach that you can access the ingress in your browser via IP address
Just like in part 1, you will now add a metadata annotation to the ingress controller to configure a dns name.
- Your first challenge is to determine how to add a dns label to the ingress controller that you deployed using helm. Note the following:
- You already have an ingress controller (from step 2a) so you don't need to create a new one or do a fresh install.
- Ignore any notes about creating and using a static IP. For this challenge, a dynamic IP is fine.
- Don't forget to add the host name to your ingress YAML template.
- Verify that the DNS record has been created (nslookup or dig), and then access the application using the DNS name, e.g:
http://[new-dns-label].[REGION].cloudapp.azure.com
- The nginx Ingress Controller is installed in your cluster
- You've recreated a new Ingress for content-web that allows access through a domain name.
Make sure you review these! (Hint Hint)