Running a basic Apache web server

A virtual machine instance on Google Compute Engine can be controlled like any standard Linux server. Deploy a simple Apache web server to learn the basics of running a server on a virtual machine instance.


You'll need a fresh Linux instance with HTTP traffic allowed.

  • Follow the Quickstart instructions to create a new Linux instance and connect to it.

Install Apache

  1. Use the Debian package manager to install the apache2 package.

    sudo apt-get update && sudo apt-get install apache2 -y
  2. Overwrite the Apache web server default web page with the following command:

    echo '<!doctype html><html><body><h1>Hello World!</h1></body></html>' | sudo tee /var/www/html/index.html

Test your server

Test that your instance is serving traffic on its external IP.

  1. Go to the VM Instances page in the Google Cloud Platform Console.

    Go to the VM Instances page

  2. Click the external IP for your instance under the EXTERNAL IP column.

You should now see the "Hello World!" page.

Clean up

When you're done experimenting, follow the clean up instructions in the Quickstart to avoid incurring charges for the virtual machine instance.


Receiving a Connection Refused error

If you are seeing a Connection Refused error, it is possible that:

  • Your VM instance is not publicly accessible because the VM instance does not have the proper tag that allows Compute Engine to apply the appropriate firewall rules or your project does not have a firewall rule that allows traffic to your instance's external IP address.

  • You are trying to access the VM using an https address. Check that your URL is http://[EXTERNAL_IP] rather than https://[EXTERNAL_IP].

To ensure that your VM instance has the correct tags:

  1. Go to the VM Instances page in the Google Cloud Platform Console.

    Go to the VM Instances page

  2. Click the name of the instance that you are trying to connect to.
  3. Under Firewalls, make sure the Allow HTTP traffic box is checked. If it is not checked, check it.
  4. Save your changes. This ensures that the correct tags are added to the VM instance.

To ensure that the correct firewall rule exists:

  1. Go to the Firewall rules page in the Google Cloud Platform Console.

    Go to the Firewall rules page

  2. Look for a firewall rule that allows all IP ranges through tcp:80. Usually, this rule is named the default-allow-http rule.
  3. If a rule does not exist, create one.
    1. Click on Create firewall rule.
    2. Enter a name for the rule, such as default-allow-http.
    3. Under Source IP ranges, enter to allow traffic from all sources.
    4. Under Protocols and ports, check Specified protocols and ports and enter tcp:80.
    5. Create your firewall rule.

Test your server again by going to the external IP address of the instance:


Send feedback about...

Compute Engine Documentation