Skip to content

Sample code for Cloud Run to use a static IP for outgoing requests via a SSH tunnel over a GCE instance

Notifications You must be signed in to change notification settings

kubosuke/cloud-run-static-outbound-ip

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Static Outbound IP example for Cloud Run applications (golang)

me @kubosuke tweaked fork source repository for running golang app.

This repository contains an example of a Google Cloud Run application that runs an SSH tunnel through a GCE instance within the container to route outbound requests of the Cloud Run application through the static IP of the GCE instance.

⚠️ Read the accompanying blog post of https://github.com/ahmetb as well: https://ahmet.im/blog/cloud-run-static-ip/

Before you begin

  1. Launch Google Cloud Shell (recommended, as it has al the tools required pre-installed).

  2. Clone this repository and cd into it.

Create a tunnel instance on GCE

  1. Create a set of ssh key pairs so that your container can SSH into the VM.

    ssh-keygen -q -f ssh_key

    Note that the private SSH key, which is a secret, will be bundled into the container image, which can be compromised if anyone gets access to your source code/build system. You can also use other means of delivering this key to the container in the runtime (e.g. by downloading from a GCS bucket, or using a secrets manager).

  2. Create a Google Compute Engine instance (f1-micro in us-central1 with name "tunnel"):

    gcloud compute instances create "tunnel" \
        --zone=us-central1-b \
        --machine-type=f1-micro
  3. (Optional) You can go to the Cloud Console and promote this VM’s ephemeral IP address to be a "static IP address". But, long as you don't delete this VM, its IP address will not change.

  4. Upload the SSH public key (not a secret) to the VM to authenticate as user "tunnel":

    gcloud compute instances add-metadata "tunnel" \
        --zone=us-central1-b
        --metadata-from-file ssh-keys=<(echo "tunnel:$(cat ssh_key.pub)")

(Optional) Inspect the application source code

Take time to understand:

  • entrypoint.sh: runs a SSH client (as SOCKS5 TCP proxy server via GCE VM) and the golang application server.

    By setting HTTPS_PROXY environment variable you don't need to update your code to use the SOCKS5 proxy.

  • main.go: starts a go app querying https://ifconfig.me/ip and sends its result back.

  • Dockerfile invokes entrypoint.sh via tini init system.

Deploy Cloud Run application

  1. Set up $PROJECT variable in your shell to your current project.

    PROJECT="$(gcloud config get-value core/project -q)"
  2. Build and push the container image to Google Conatiner Registry.

    gcloud builds submit --tag gcr.io/$PROJECT/sample-tunnel
  3. Find the EXTERNAL_IP address of the Compute Engine VM named "tunnel" you created earlier:

    gcloud compute instances list --filter=name=tunnel
  4. Deploy to Cloud Run, by setting GCE_IP environment variable to the IP of the VM:

    gcloud beta run deploy sample-tunnel \
        --set-env-vars="GCE_IP=x.y.z.t" \
        --platform=managed \
        --region us-central1 \
        --allow-unauthenticated \
        --image=gcr.io/$PROJECT/sample-tunnel

Query the application

When you visit the application’s public URL/ip/ , you will see that the IP address that it used to query https://ifconfig.me/ip is the IP address of the GCE instance.


Don't forget to check out the accompanying blog post: https://ahmet.im/blog/cloud-run-static-ip/

About

Sample code for Cloud Run to use a static IP for outgoing requests via a SSH tunnel over a GCE instance

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 48.4%
  • Dockerfile 28.6%
  • Shell 23.0%