tvl-depot/users/wpcarro/playbooks/nix_gcr
Vincent Ambo aa122cbae7 style: format entire depot with nixpkgs-fmt
This CL can be used to compare the style of nixpkgs-fmt against other
formatters (nixpkgs, alejandra).

Change-Id: I87c6abff6bcb546b02ead15ad0405f81e01b6d9e
Reviewed-on: https://cl.tvl.fyi/c/depot/+/4397
Tested-by: BuildkiteCI
Reviewed-by: sterni <sternenseemann@systemli.org>
Reviewed-by: lukegb <lukegb@tvl.fyi>
Reviewed-by: wpcarro <wpcarro@gmail.com>
Reviewed-by: Profpatsch <mail@profpatsch.de>
Reviewed-by: kanepyork <rikingcoding@gmail.com>
Reviewed-by: tazjin <tazjin@tvl.su>
Reviewed-by: cynthia <cynthia@tvl.fyi>
Reviewed-by: edef <edef@edef.eu>
Reviewed-by: eta <tvl@eta.st>
Reviewed-by: grfn <grfn@gws.fyi>
2022-01-31 16:11:53 +00:00
..
cloud_run.nix style: format entire depot with nixpkgs-fmt 2022-01-31 16:11:53 +00:00
config.lisp subtree(users/wpcarro): docking briefcase at '24f5a642' 2021-12-14 02:15:47 +03:00
README.md subtree(users/wpcarro): docking briefcase at '24f5a642' 2021-12-14 02:15:47 +03:00

Nix + Google Cloud Run (i.e. GCR)

I'm documenting how I currently deploy projects that I package with Nix on Google Cloud Run.

I'd like to automate this workflow as much as possible, and I intend to do just that. For now, I'm running things manually until I can design an generalization that appeals to me.

Dependencies

  • nix-build
  • docker
  • gcloud

Step-by-step

  1. Use nix-build to create our Docker image for Cloud Run.
> nix-build ./cloud_run.nix

This outputs a Docker image at ./result.

  1. Load the built image (i.e. ./result) into docker so that we can tag it and push it to the Google Container Registry (i.e. GCR).
> sudo docker load <./result
  1. (Optionally) Run the image locally to verify its integrity.
> sudo docker run -d -p 8080:4242 <name>:<tag>
  1. Tag and push the image to GCR.
> sudo docker tag <name>:<label> gcr.io/<google-cloud-project-id>/<name>:<latest>
  1. Visit Google Cloud Run; create a new service with "Create Service"; select the uploaded Docker image from the "Container Image URL" field; click "Create" to deploy.

Notes

You may need to authorize gcloud by running the following:

> sudo gcloud auth login --no-launch-browser

You must use sudo here since the docker invocations are prefixed with sudo as well.

Todos

  • If possible, prefer using a command line tool like gcloud to create the Cloud Run service.