• Stars
    star
    406
  • Rank 102,574 (Top 3 %)
  • Language
    Go
  • License
    Apache License 2.0
  • Created about 4 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Drop-in Service Discovery capabilities for Google Cloud Run.

runsd

runsd is a drop-in binary to your container image that runs on Google Cloud Run (fully managed) that allows your services to discover each other and authenticate automatically without needing to change your code.

It helps you bring existing microservices, for example from Kubernetes, to Cloud Run. It’s not language-specific and works with external tools and binaries.

Goal: This tool is developed since Cloud Run does not have built-in service discovery and automatic service-to-service authentication features. The goal is to provide the functionality until the official features ship. It is expected the experience will be quite similar and the migration will be quite easy once the official feature becomes available.

Note: This project is not a support component of Cloud Run. It's developed as a community effort and provided as-is without any guarantees.

Features

runsd does its job in your container, entirely in userspace and does not need to run with any additional privileges or permissions to work.

runsd feature list

DNS Service Discovery

With runsd, other Cloud Run services in the same GCP project can be resolved using hostname http://SERVICE_NAME[.REGION[.run.internal]].

The goal of this project is to provide a solution until Cloud Run has an officially supported feature. Therefore, you should not use the fully qualified domain name format listed above in your code. Only use formats:

  • http://<SERVICE_NAME> and
  • http://<SERVICE_NAME>.<REGION>.

runsd service discovery

Automatic Service Authentication

Normally, to have Cloud Run services that make requests to each other (for example, microservices), your program needs to fetch an identity token from the metadata service and set it as a header on the outbound request.

With runsd, this is no longer needed since authentication handled out-of-the-box. This means you don't need to change your code when you bring your apps to Cloud Run from other platforms that have name-based DNS resolution (such as like Kubernetes or Compute Engine):

Cloud Run authentication before & after

Installation

For my tracking purposes, please fill out the form at https://forms.gle/kCgEEiRqrmHhM65g6 if you are using runsd. Your feedback will be important in shaping this feature.

To install runsd in your container, you need to download its binary and prefix your original entrypoint with it.

For example:

ADD https://github.com/ahmetb/runsd/releases/download/<VERSION>/runsd /bin/runsd
RUN chmod +x /bin/runsd
ENTRYPOINT ["runsd", "--", "/app"]

In the example above, change <VERSION> to a version number in the Releases page. It is wise to pick a version and use it as long as you can until you hit a bug.

After installing runsd, it will have no effect while running locally. However, while on Cloud Run, you can now query other services by name over http://.

Note that your traffic is still secure –as the request is upgraded to HTTPS before it leaves your container.

Usage

After installing runsd as your new entrypoint, you container can now make requests to other Cloud Run services in the same project directly by name, e.g. http://hello.

Note that:

  • You can use http://hello to connect to a service within the same region.

  • You can use http://hello.us-central1 notation if the service is deployed in another region (but the same project).

  • Do not use https:// or port 443. You need to make requests using http over port 80 for runsd to work. (HTTPS is added before your request leaves the container.)

Quickstart

You can deploy this sample application to Cloud Run to try out querying other private Cloud Run services without tokens and without full .run.app domains by directly using curl.

This sample app has runsd as its entrypoint and it will show you a form that you can use to query other private Cloud Run services easily with curl.

Below, replace <HASH> with the random string part of your Cloud Run URLs (e.g. 'dpyb4duzqq' if the URLs for your project are 'foo-dpyb4duzqq-uc.run.app').

gcloud alpha run deploy curl-app --platform=managed
   --region=us-central1 --allow-unauthenticated --source=example \
   --set-env-vars=CLOUD_RUN_PROJECT_HASH=<HASH>

Note: Do not forget to delete this service after you try it out, since it gives unauthenticated access to your private services.

Architecture

runsd Architecture Diagram

runsd has a rather hacky architecture, but most notably does 4 things:

  1. runsd is the new entrypoint of your container, and it runs your original entrypoint as its subprocess.

  2. runsd updates /etc/resolv.conf of your container with new DNS search domains and sends all DNS queries to localhost:53.

  3. runsd runs a DNS server locally inside your container localhost:53. This resolves internal hostnames to a local proxy server inside the container (localhost:80) and forwards all other domains to the original DNS resolver.

  4. runsd runs an HTTP proxy server on port 80 inside the container. This server retrieves identity tokens, adds them to the outgoing requests and upgrades the connection to HTTPS.

Troubleshooting

By default runsd does not log anything to your application in order to not confuse you or mess with your log collection setup.

If you need to expose more verbose logs, change the entrypoint in your Dockerfile from ENTRYPOINT ["runsd", "--", ...] to;

ENTRYPOINT ["runsd", "-v=5", "--", ...]

You can adjust the number based on how much detailed logs you want to see.

If the logs don't help you troubleshoot the issues, feel free to open an issue on this repository; however, don’t have any expectations about when it will be resolved. Patch and more tests are always welcome.

Limitations and Known Issues

  1. All names like http://NAME will resolve to a Cloud Run URL even if they don't exist. Therefore, for example, if http://hello doesn't exist, it will will still be routed to a URL as if it existed, and it will get HTTP 404.
  2. Similar to previous item http://metadata will be assumed as a Cloud Run service instead of instance metadata server. To prevent this, use its FQDN metadata.google.internal. with a trailing dot.
  3. No structured logging support, but this should not impact you since the runsd binary is not supposed to log anything except the errors by default.
  4. WebSockets, gRPC (incl. streaming) and SSE works. Please file issues if it does not work.

This is not an official Google project.

More Repositories

1

kubectx

Faster way to switch between clusters and namespaces in kubectl
Go
14,832
star
2

kubernetes-network-policy-recipes

Example recipes for Kubernetes Network Policies that you can just copy paste
5,497
star
3

go-linq

.NET LINQ capabilities in Go
Go
3,426
star
4

kubectl-aliases

Programmatically generated handy kubectl aliases.
Shell
3,235
star
5

kubectl-tree

kubectl plugin to browse Kubernetes object hierarchies as a tree 🎄 (star the repo if you are using)
Go
2,788
star
6

cloud-run-faq

Unofficial FAQ and everything you've been wondering about Google Cloud Run.
Shell
2,292
star
7

gke-letsencrypt

Tutorial for installing cert-manager on GKE get HTTPS certificates from Let’s Encrypt (⚠️NOW OBSOLETE⚠️)
623
star
8

govvv

"go build" wrapper to add version info to Golang applications
Go
535
star
9

go-dexec

It's like Go os/exec package but for Docker. What if you could exec programs remotely with the same interface as os/exec?
Go
424
star
10

kubectl-foreach

Run kubectl commands in all/some contexts in parallel (similar to GNU xargs+parallel)
Go
406
star
11

personal-dashboard

📊 Programmatically collecting and reporting various stats about myself daily
Go
337
star
12

wagl

🐝 DNS Service Discovery for Docker Swarm. Works out of the box. (NOW OBSOLETE, USE SWARM MODE)
Go
284
star
13

gen-crd-api-reference-docs

API Reference Docs generator for Kubernetes CRDs (used by Knative, Kubeflow and others)
Go
271
star
14

serverless-registry-proxy

Serverless reverse proxy for exposing container registries (GCR, Docker Hub, Artifact Registry etc) on custom domains.
Go
248
star
15

orman

lightweight and minimalist ORM for Java/Android. works with SQLite & MySQL. (not actively maintained)
Java
247
star
16

sheets-url-shortener

A simple short URL redirect service built on top of Google Sheets, and runs for cheap on Google Cloud Run serverless.
Go
178
star
17

In-Stock

📱 Is the new iDevice in town yet? (no longer maintained)
Objective-C
158
star
18

RectangleWin

Hotkey-driven window snapping to edges and corners using hotkeys on Windows 10/11.
Go
157
star
19

go-httpbin

http://httpbin.org endpoints for your Go tests
Go
121
star
20

dotfiles

Ahmet's dotfiles and macOS customizations
Shell
120
star
21

kubectl-extras

A collection of mini plugins for kubectl.
Shell
113
star
22

twitter-audit-log

Back up Twitter follow/mute/block lists periodically using GitHub Actions
Go
93
star
23

goodbye

Notify yourself when someone unfollows you on Twitter
Go
87
star
24

kubectl-pods_on

kubectl plugin to query Pods by Node names or selectors
Go
83
star
25

cloud-run-multi-region-terraform

Deploy a Cloud Run app to all available regions using Terraform.
HCL
80
star
26

azurefs

Mount Microsoft Azure Blob Storage as local filesystem in Linux (inactive)
Python
70
star
27

baklava

Go
64
star
28

cloud-run-iap-terraform-demo

Deploy an IAP-secured application to Cloud Run using Terraform (e.g. an admin portal or internal company app)
HCL
63
star
29

cloud-run-travisci

Example config for deploying from Travis CI to Google Cloud Run
Python
54
star
30

go-cursor

ANSI escape code helpers for Go
Go
53
star
31

public-speaking

@ahmetb's public speaking engagements & bio
50
star
32

multi-process-container-lazy-solution

Sample code accompanying the blog post:
Python
50
star
33

cloudrun-iamviz

Visualize call permissions between Cloud Run services
Go
48
star
34

serverless-url-redirect

Simple click-to-deploy serverless URL redirect service
Shell
38
star
35

goclone

Clone Go projects to a clean GOPATH and start hacking right away.
Shell
35
star
36

coffeelog

Sample multi-tier cloud-native application hosted on Google Kubernetes Engine (GKE)
Go
34
star
37

skaffold-from-laptop-to-cloud

Docker Voting App deployed to Kubernetes with Skaffold 3 different ways
JavaScript
32
star
38

cloud-run-static-outbound-ip

[DEPRECATED] Sample code for Cloud Run to use a static IP for outgoing requests via a SSH tunnel over a GCE instance
Python
29
star
39

rundev

(alpha, contact me if you’re using)
Go
28
star
40

dlog

Go library to parse the Docker Logs stream
Go
28
star
41

multi-process-container

Example docker container image with multiple services supervised by s6 init process
Shell
28
star
42

coredns-grpc-backend-sample

Sample CoreDNS gRPC proxy backend written in Go
Go
26
star
43

zone-printer

Small web app to print Google Cloud compute region it’s deployed to
Go
25
star
44

turkish-deasciifier-java

Turkish deASCIIfier library for Java
Java
24
star
45

ytaudio

Go
24
star
46

qs

URL query parameters from Go structs
Go
22
star
47

kcat

Syntax highlighting for Kubernetes manifests [WIP]
Go
19
star
48

cloud-run-deploy-via-api-go

Go
18
star
49

docker-registry-driver-azure

[⚠️DO NOT USE THIS - DEPRECATED ⚠️] Docker Registry – Azure Blob Storage Driver
Python
16
star
50

twitch-bot

Go
14
star
51

dailybbble

Archiving and serving what is popular on Dribbble every day
Python
13
star
52

docker-chocolatey

Chocolatey 'docker' package
PowerShell
12
star
53

comcasted

Are you being “Comcast-ed”? Test your speed every 5min and see if you're getting what you're paying.
Python
12
star
54

sorucevap

Go
11
star
55

open-diary-format

Because all diary keeping apps suck. Here's a standard format.
11
star
56

ytdl

Serverless video downloader app (using youtube-dl)
Go
11
star
57

Spark.NET

Wicked ▁▂▃▅▂▇ in your C# programs
C#
10
star
58

permalinker

Right click → Save to cloud → Permalink on your clipboard
Python
10
star
59

kubectl-runbridge

Go
9
star
60

radyo

a js radio plays similar tracks using last.fm & youtube. for my personal usage.
9
star
61

tfjs-cloudrun

JavaScript
9
star
62

gophercon-ist

8
star
63

leetcode-solutions

my solutions to http://leetcode.com/onlinejudge problems
Java
7
star
64

kubernetes-secrets-propagation-delay

Go
7
star
65

tmdb-downloader

Downloads tmdb movies data sequentially and saves to mongodb
Python
7
star
66

sample-bundle-deployment-controller

A sample CRD that deploys a bundle of arbitrary Kubernetes resources with pruning/kustomization capabilities.
Go
7
star
67

simplegauges

Practical time series gauges for daily stats (used in personal-dashboard project)
Python
6
star
68

kubectl-runproxy

🧪[experimental]☢️ a local k8s apiserver to make Cloud Run API work with kubectl (don't use this)
Go
4
star
69

cloudrun-socketio-whiteboard

JavaScript
4
star
70

mysqlbackup

simple python script to get gzipped mysql dumps with easy connection strings
4
star
71

hizlisozluk

Hizli Sozluk Android app
Java
3
star
72

futuremedium-resizer

a handy proportional image resizer and cropper for Java
Java
3
star
73

blobmetadb

Watches your application’s Microsoft Azure Blob Storage requests and keeps record of your blobs on Redis.
C#
3
star
74

instagger

Lamest tool ever. Adds and removes hashtags to your instagram posts.
Go
2
star
75

orman-demos

demo projects playground for orman framework
Java
2
star
76

permalinker-chrome

Chrome extension for Permalinker. Right click any image on the web → Save to cloud → Share link with friends
JavaScript
2
star
77

orman-clickgame

a click game implemented with orman and sqlite
Java
2
star
78

cs352project

a useless CS 352 CRUD term project. uploading only for code storage purposes.
PHP
2
star
79

swap

file name swapping utility for Unix systems
C
2
star
80

github-activity-recorder

2
star
81

home-ac-stats

Push stats from Sensibo AC controller to Google Cloud Monitoring
Go
2
star
82

blog-docker

Docker image for my blog's nginx server 🌵
Nginx
1
star
83

runstatic

Go
1
star
84

krew-index-autoapprove

Go
1
star
85

rtmpsave

Listens to a RTMP stream, encodes to specified audio format and uploads audio to Azure Blob Storage
Go
1
star
86

kubectl-colorful

Shell
1
star
87

yayinakisi

Yayin Akisi Android App
Java
1
star
88

colorify

colorify windows phone 7 app
C#
1
star