Spotted a bug? Have a great idea? Help us make google.dev great!

IP addresses are used to balance, scatter, and manage traffic coming into your environment. This is built into the configurations of your routers, firewalls, and most hardware and software. Planning out internal and external IP address logic is crucial in maintaining the flexibility and security of your cloud environment. As such, it is important to understand how IP addresses can affect your workloads and how they interact with internal and public network traffic. In this codelab, you will learn how to reserve and assign Compute Engine instance external IP addresses to enable communication to the public Internet.

What are IP addresses?

IP addresses are very important in TCP/IP networking. It's the address that recognized and understood by instances and networking devices, so that they can communicate with each other. Each VM instance in GCP will have an internal IP address and typically an external IP address. The internal IP address is used to communicate between instances in the same VPC network, while the external IP address is used to communicate with instances in other networks or the Internet. These IP addresses are ephemeral by default but can be statically assigned.

Internal IPs are allocated to instances from the subnet's IP range via DHCP. By default, internal IPs are ephemeral and will be released if the instance is deleted. However, you can reserve a static internal IP address from the subnet's IP address range.

External IPs are also assigned via DHCP from a Google-provided pool. These IPs are mapped to the internal IPs of the VM instances for you. You can reserve static external IP addresses if needed. Static External IP Addresses can be either global or regional depending on your requirements. For example, global static IP addresses are available for global forwarding rules used for global load balancing.

What you'll build

  • A Compute Engine instance with Apache 2.0 installed
  • An external IP address reservation

What you'll learn

  • How to remove an IP address from an instance
  • How to reserve an IP address and assign it to an instance
  • Best practices around IP addresses

What you'll need

  • A Google Cloud Platform account

Self-paced environment setup

If you don't already have a Google Account (Gmail or Google Apps), you must create one. Sign-in to Google Cloud Platform console (console.cloud.google.com) and create a new project:

Remember the project ID, a unique name across all Google Cloud projects. It will be referred to later in this codelab as PROJECT_ID.

Next, you'll need to enable billing in the Cloud Console in order to use Google Cloud resources.

Running through this codelab shouldn't cost you more than a few dollars, but it could be more if you decide to use more resources or if you leave them running (see "cleanup" section at the end of this document).

New users of Google Cloud Platform are eligible for a $300 free trial.

Initialize your Project environment

Compute → Compute Engine → VM Instances

The GCP Marketplace offers ready-to-go development stacks, solutions, and services to accelerate development. We'll use a Compute Engine image from the Marketplace to test out external IP address functionality. Head to the GCP Marketplace to deploy a preconfigured LAMP stack on Compute Engine.

Menu → Marketplace

Search for the term "Apache". Select the LAMP Stack Click to Deploy image.

Click Launch on Compute Engine.

Give the instance the name lamp-1. Under Networking, leave the instance in the Default VPC network and the Default subnetwork for the us-central1-f zone. Ensure the Allow HTTP traffic checkbox is selected. Change the external IP address option from ephemeral to none.

Click Deploy. You will be brought to the Deployment Manager homepage and see that your resources are being spun up.

Once the stack is finished deploying you will see a green check mark indicating completion. Notice that in the right hand menu under "Get Started with LAMP stack," the Visit the Site option is greyed out. When you hover over it, it explains that it is inaccessible from the public Internet because the instance does not have an external IP address.

In order to access the site, you must reserve and assign an external IP address to the lamp-1 instance. Head to the IP Addresses page.

Networking → VPC Networks → External IP addresses

Click Reserve Static Address.

Give it the name lamp-1-ip. Leave the rest as default, but assign the IPv4 address to our lamp-1 instance.

You should now be able to access the sample app that comes preinstalled on the lamp-1 instance. Head back to the Deployment Manager homepage.

Tools → Deployment Manager → Deployments

Click on the lamp-1 instance. Click on Visit the Site, as it should no longer be greyed out.

You can now see the default welcome page used to test the Apache server through the static external IP address!

You now know the basics of reserving and assigning a static external IP address to a Compute Engine instance on Google Cloud Platform.

What we've covered

  • How instances are affected by external IP addresses
  • How to deploy a preconfigured image using the GCP Marketplace
  • How to reserve and assign a static external IP address to a Compute Engine instance

Next Steps

Delete Compute Engine instances with the following commands in the Cloud Shell:

gcloud compute instances delete lamp-1 

Delete the external IP address created with the following commands:

gcloud compute addresses delete lamp-1-ip