blob: f5c021140f3c6d23e29f7693c91c4a3e592b22ec [file] [log] [blame] [view]
---
title: Announcing App Engines New Go 1.11 Runtime
date: 2018-10-16
by:
- Eno Compton
- Tyler Bui-Palsulich
tags:
- appengine
summary: Google Cloud is announcing a new Go 1.11 runtime for App Engine, with fewer limits on app structure.
---
[App Engine](https://cloud.google.com/appengine/) launched
[experimental support for Go](/blog/go-and-google-app-engine)
in 2011. In the subsequent years, the Go community has grown significantly and
has settled on idiomatic
patterns for cloud-based applications. Today, Google Cloud is
[announcing a new Go 1.11 runtime](https://cloud.google.com/blog/products/application-development/go-1-11-is-now-available-on-app-engine)
for the App Engine standard environment that provides all the
power of App Enginethings like paying only for what you use, automatic scaling,
and managed infrastructurewhile supporting idiomatic Go.
Starting with Go 1.11, Go on App Engine has no limits on application structure,
supported packages, `context.Context` values, or HTTP clients. Write your Go
application however you prefer, add an `app.yaml` file, and your app is ready
to deploy on App Engine.
[Specifying Dependencies](https://cloud.google.com/appengine/docs/standard/go111/specifying-dependencies)
describes how the new runtime
supports [vendoring](/cmd/go/#hdr-Vendor_Directories) and
[modules](/doc/go1.11#modules) (experimental) for dependency
management.
Along with [Cloud Functions support for Go](https://twitter.com/kelseyhightower/status/1035278586754813952)
(more on that in a future post), App Engine provides a compelling way to run Go
code on Google Cloud Platform (GCP) with no concern for the underlying
infrastructure.
Lets take a look at creating a small application for App Engine. For the
example here, we assume a `GOPATH`-based workflow, although Go modules have
[experimental support](https://cloud.google.com/appengine/docs/standard/go111/specifying-dependencies)
as well.
First, you create the application in your `GOPATH`:
{{code "appengine/main.go"}}
The code contains an idiomatic setup for a small HTTP server that responds with
Hello, 世界.” If you have previous App Engine experience, youll notice the
absence of any call to `appengine.Main()`, which is now entirely optional.
Furthermore, the application code is completely portablethere are no ties to
the infrastructure that your application is deployed on.
If you need to use external dependencies, you can add those dependencies to a
`vendor` directory or to a `go.mod` file, both of which the new runtime
supports.
With the application code complete, create an `app.yaml` file to specify
the runtime:
runtime: go111
Finally, set your machine up with a Google Cloud Platform account:
- Create an account with [GCP](https://cloud.google.com).
- [Create a project](https://cloud.google.com/resource-manager/docs/creating-managing-projects).
- Install the [Cloud SDK](https://cloud.google.com/sdk/) on your system.
With all the setup complete, you can deploy using one command:
gcloud app deploy
We think Go developers will find the new Go 1.11 runtime for App Engine an
exciting addition to the available options to run Go applications. There is a
[free tier](https://cloud.google.com/free/). Check out the
[getting started guide](https://cloud.google.com/appengine/docs/standard/go111/building-app/)
or the
[migration guide](https://cloud.google.com/appengine/docs/standard/go111/go-differences)
and deploy an app to the new runtime today!