As Cloud computing continues to expand, I'm always looking to learn new things, and looking out for the next big thing on the web. But from time to time, I like to come back to Google to see how its Cloud Platform is doing - and I must say, Google seems to always have everything figured out.
A few years ago, I had my first experience with Google App Engine (GAE) working on a powerful bookkeeping platform, and I remember how simple it was to get everything up and running. I didn't have to do any additional work, such as setting user groups, network, and security - all I had to do was write code, unit tests, and get it running on GAE. Awesome, right?App Engine is a platform provided by Google as a service (PaaS) to leverage the easy development of cloud applications with flexibility and reliability. It abstracts away infrastructure, so you can focus solely on code, and also offers automatic scaling for web applications. In App Engine, applications are sandboxed and run across multiple servers.
Google offers a free plan, that enables the basic usage of almost every Google Cloud feature. If you want to learn more, check out this link: https://cloud.google.com/free/docs/always-free-usage-limits.
First Things First
I'd recommend these articles if you're not used to GO packaging/configuration:
Last but not least, you will need Google Cloud SDK, which can be downloaded here: https://cloud.google.com/sdk.
Setting Up Your Cloud Project
If you already know how to create an App Engine project, you can jump right to Creating Your App. If you're still learning, then the very first step is to open Google Cloud Console, then:
1. Click on 'Select a project':
2. Click on '+' to add a new project:
3. Set your project name, which may differ from your project ID:
4. Now, your project is being created. It can take up to 5 minutes, so keep your eyes on the notification panel. As soon as the project is ready, you should be able to select it:
Then, you will be redirected to the location page. Select any location (I usually go with us-east1). After that, you will need to execute backend creation, which can take up to 5 minutes to execute.
As usual, to be sure that the GAE project is working, we'll create a basic Hello World! app. In order to do that, go ahead, and create a Github repo for your code. Within this repo, I'll add two files:
app.yaml
runtime: go api_version: go1.8 handlers: - url: /.* script: _go_appThis file tells the App Engine service which runtime to use, including language and API versions. It also defines which URLs should be handled by this Go program. In other words, it requests that URLs that match this regex (/.*) be handled by this specific program. The _go_app is used only for the development server, which means it's ignored in production servers.
main.go
package main import ( "fmt" "net/http" ) // This will be the entry point for _GAE_, we'e using GO default http package to pass the request to a handler func func init() { http.HandleFunc("/", handler) } // This will handle requests on the default path and return Hello World on the response func handler(w http.ResponseWriter, r *http.Request) { fmt.Fprint(w, "Hello, world!!!") }This file is super straightforward. Like the comments state, we're passing requests on the root level of our app to the handler func, and returning a Hello World from there.
Assuming you have already installed Google Cloud SDK on your machine, you should be able to run the following command from your terminal:
gcloud init
This will start a command-line wizard that will ask you to authenticate via your Google Account, and set your project. The third step should ask you to select the GAE project, or select the project created earlier.
Now, it's finally time to test your app. In order to do that, first run this command from your project's root directory.
dev_appserver.py app.yaml
If everything worked, you should see an output similar to this one:
INFO 2017-09-21 02:50:22,725 devappserver2.py:692] Skipping SDK update check.
INFO 2017-09-21 02:50:22,771 api_server.py:272] Starting API server at: http://localhost:52474
INFO 2017-09-21 02:50:22,774 dispatcher.py:205] Starting module "default" running at: http://localhost:8080
INFO 2017-09-21 02:50:22,776 admin_server.py:116] Starting admin server at: http://localhost:8000
Now, go ahead and check your http://localhost:8080. You should see the Hello World!!! message.
Now that the app is working, we can deploy it to see it run on GAE effectively. Run this command from your terminal:
gcloud app deploy
(You will be asked to confirm if you want to deploy the app, go with YesThat's it! If you're error free on the last command, then you should see the app URL. Alternatively, you can run this command to open your browser on the app URL:
gcloud app browse
As I mentioned at the beginning of this post, Google makes it easy for you to get your services up and running on its platform. The project setup is super straight-forward, and the outcome is pretty amazing. I hope I was able to help you create your basic project on GAE. I'll be publishing a new article in the near future showing how to create a basic REST service and put it onto GAE, so stay tuned!