aa122cbae7
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> |
||
---|---|---|
.. | ||
cloud_run.nix | ||
config.lisp | ||
README.md |
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
- Use
nix-build
to create our Docker image for Cloud Run.
> nix-build ./cloud_run.nix
This outputs a Docker image at ./result
.
- Load the built image (i.e.
./result
) intodocker
so that we can tag it and push it to the Google Container Registry (i.e. GCR).
> sudo docker load <./result
- (Optionally) Run the image locally to verify its integrity.
> sudo docker run -d -p 8080:4242 <name>:<tag>
- Tag and push the image to GCR.
> sudo docker tag <name>:<label> gcr.io/<google-cloud-project-id>/<name>:<latest>
- 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.