This tutorial demonstrates how to use Google Kubernetes Engine (GKE) to expose your web application to the internet on a static external IP address and configure a domain name to point to your application.
This tutorial assumes you own a registered domain name, such as example.com.
Deploy your web application
The following manifest describes a Deployment that runs a sample web application container image:
Create the Deployment:
kubectl apply -f helloweb-deployment.yaml
Expose your application
You can expose your application on GKE using either of the following methods:
- Use a Service, which creates an external passthrough Network Load Balancer that works with regional IP addresses. 
- Use an Ingress, which creates an Application Load Balancer and supports global IP addresses. 
To learn more about the advantages and disadvantages of each method, see Setting up an external Application Load Balancer with Ingress.
Use a Service
To ensure that your application has a static external IP address, you must reserve a static IP address.
If you choose to expose your application using a Service, you must create a regional IP address. Global IP addresses only work with Ingress resource type, as explained in the next section.
To use a Service, create a static IP address named helloweb-ip in the
region us-central1:
gcloud
gcloud compute addresses create helloweb-ip --region us-central1
Find the static IP address that you created:
gcloud compute addresses describe helloweb-ip --region us-central1
The output is similar to the following:
...
address: 203.0.113.32
...
Config Connector
Note: This step requires Config Connector. Follow the installation instructions to install Config Connector on your cluster.
Save the manifest as compute-address-regional.yaml.
Apply the manifest to your cluster:
  kubectl apply -f compute-address-regional.yaml
Find the static IP address that you created:
  kubectl get computeaddress helloweb-ip -o jsonpath='{.spec.address}'
The following manifest describes a Service of type LoadBalancer, which creates an external passthrough Network Load Balancer to expose Pods with an external IP address.
Replace YOUR.IP.ADDRESS.HERE with the static IP address:
Create the Service:
kubectl apply -f helloweb-service-static-ip.yaml
View the reserved IP address associated with the load balancer:
kubectl get service
The output is similar to the following:
NAME               CLUSTER-IP      EXTERNAL-IP      PORT(S)          AGE
helloweb           10.31.254.176   203.0.113.32     80:30690/TCP     54s
Use an Ingress
If you choose to expose your application using an
Ingress,
you must
reserve a global static IP address.
Use the annotation kubernetes.io/ingress.global-static-ip-name to specify a global IP address.
To expose your application to clients and services in a region, use a regional static internal IP address while deploying an internal ingress resource for GKE along with the required annotations.
To learn how to use Ingress to expose your applications to the internet, see Setting up an external Application Load Balancer with Ingress.
To create a global static IP address named helloweb-ip:
gcloud
gcloud compute addresses create helloweb-ip --global
Find the static IP address that you created:
gcloud compute addresses describe helloweb-ip --global
The output is similar to the following:
...
address: 203.0.113.32
...
Config Connector
Note: This step requires Config Connector. Follow the installation instructions to install Config Connector on your cluster.
Save the manifest as compute-address-global.yaml.
Apply the manifest to your cluster:
  kubectl apply -f compute-address-global.yaml
The following manifest describes an Ingress that exposes a web application on a static IP with two resources:
- A Servicewithtype:NodePort
- An Ingressconfigured with the service name and static IP annotation
The kubernetes.io/ingress.global-static-ip-name annotation specifies the name
of the global IP address resource to be associated with the
load balancer.
Apply the manifest to your cluster:
kubectl apply -f helloweb-ingress-static-ip.yaml
View the IP address associated with the load balancer:
kubectl get ingress
The output is similar to the following
NAME       HOSTS     ADDRESS          PORTS     AGE
helloweb   *         203.0.113.32     80        4m
View your reserved static IP address
To verify that the load balancer is configured correctly, you can either use a
web browser to visit the IP address or use curl:
curl http://203.0.113.32/
The output is similar to the following:
Hello, world!
Hostname: helloweb-3766687455-8lvqv
Configure your domain name records
To have browsers querying your domain name, such as example.com, or subdomain
name, such as blog.example.com, point to the static IP address you reserved,
you must update the DNS (Domain Name Server) records of your domain name.
You must create an A (Address) type DNS record for your domain or subdomain name and have its value configured with the reserved IP address
DNS records of your domain are managed by your name server. Your name server might be the "registrar" where you registered your domain, a DNS service such as Cloud DNS, or another third-party provider.
- If your nameserver is Cloud DNS: Follow Cloud DNS Quickstart guide to configure DNS A record for your domain name with the reserved IP address of your application. 
- If your nameserver is another provider: Refer to your DNS providers documentation on setting DNS A records to configure your domain name. If you choose to use Cloud DNS instead, refer to Migrating to Cloud DNS. 
Visit your domain name
To verify that your domain name's DNS A records resolve to the IP address you reserved, visit your domain name.
To make a DNS query for your domain name's A record, run the host
command:
host example.com
The output is similar to the following:
example.com has address 203.0.113.32
You can now point your web browser to your domain name and visit your website.