- Create Google App Engine Application
- Enable App Engine Admin API
- Configure GitHub App Trigger
- Run Cloud Build
- Continuous Deployment of Changes
- Unit Testing
- Disable the Application
The third lab will deploy a NodeJS Web Application to App Engine using Cloud Build.
At this time, there is a 1:1 mapping between an application on App Engine and the project it is deployed to and deleting an application is not supported. To stop traffic and stop costs incurred by App Engine, the application can be disabled instead. However, you can delete a service in App Engine, except for the
default
service. See here for more information on App Engine.
Create the Google App Engine Application that the pipeline will deploy to.
- Navigate to
App Engine
from the top left menu, it will be under theCompute
sub-heading.
You will notice that there is currently no application and the option to create one is available.
Note that you can use the UI to create the application. However, we will use the
gcloud
command to show an alternative for automation use.
-
Open Cloud Shell.
-
Create the Google App Engine Application.
gcloud app create --region=us-central
- Refresh the page. You will see that your App Engine application has been created.
That's it for the application creation! Now you can deploy your web service to App Engine. This action (creating an application
on App Engine) creates an isolated environment to deploy and run your web service over multiple servers but does not actually deploy it yet. In an App Engine project, you can deploy multiple microservices as separate services, previously known as modules in App Engine. The application we created has a default service that we will deploy to and host our site.
Since we will be using Cloud Build to deploy our application, we need to enable the App Engine Admin API
. This will allow other services, such as Cloud Build, to administer on App Engine.
Note that you can use the UI to enable the API. However, we will use the
gcloud
command to show an alternative for automation use.
-
Navigate to
APIs & Services
from the top left menu. -
Click the + Enable APIs and Services on the top heading.
-
In the search field, enter
App Engine Admin API
. Select it from the populated results. -
Notice that there is an Enable button. If you choose to enable the API through the UI you can skip steps 5 - 8.
-
Open Cloud Shell
-
Enable the
App Engine Admin API
gcloud services enable appengine.googleapis.com
-
Go back to the API library by clicking the back arrow at the top left.
-
Select the
App Engine Admin API
again from the result list. Notice that the API is now enabled and can be used by Cloud Build.
It is important to note that any account which has the
Editor
role, such as the Cloud Build service account for the labs, will automatically have permissions to administer App Engine. To follow the standard rule of least privilege, a more appropriate role would be theApp Engine Admin
role, which provides permission to App Engine.
We will now configure a Cloud Build trigger that will run the build, test, and deployments steps to get your code running on App Engine.
-
Open the Triggers page in the Google Cloud Console and click Create Trigger
-
Similar to Lab 1 and Lab 2, enter a name (E.g.,
lab3-trigger
) and description (E.g.,trigger for lab 3
) for your trigger. -
Under Event, select
Push to a new branch
. -
Under Source, select the repository that was connected earlier (E.g., githubuser/MyDevOpsBootCamp (GitHub App)). Enter
.*
for branch to trigger build on all branches. -
Expand the 'Show Included and Ignored File Filters' section and enter
lab_3/**
under 'Included files filter (glob)' to indicate that only changes under thelab_3/
folder should trigger a build. -
Enter
lab_3/cloudbuild-lab3.yaml
under 'Cloud Build configuration file (YAML or JSON)'. This configuration file defines the build steps that will be performed when a build is triggered. -
Click Create to finish creating the trigger on Cloud Build.
The workflow we just created is triggered by changes made to the files in the lab_3/
directory. Let's make a change here to kick off the workflow. The readme.txt
can be modified by simply adding a new line or some text. The act of committing this change to the master
branch will instruct GitHub Actions to kick off our workflow.
-
Navigate to Code, and browse to the
lab_3/readme.txt
file. Click the pencil icon to edit the file, and add a new line. Provide a commit message and commit your change. -
Navigate to Cloud Build -> History and you should see the build executing with the lab3-trigger name.
-
The workflow for Lab 3 is going to take a few minutes to execute. While it is running take a look at the application configuration file (E.g.,
app/app.yaml
) to see how App Engine will configure environment.
Although the mapping is 1-to-1 between project and App Engine application, you can create more than one service in the application. The application includes a default service, appropriately named
default
, which cannot be deleted. For more information see the Google documentation here.
- Once the build finishes, open a browser window and navigate to to
https://<Project ID>.<Region code>.r.appspot.com
. Replace<Project ID>
with your Project ID and<Region code>
in this example, the region codeuc
is forus-central
. The URL can also be found on thegcloud app deploy
step of the Cloud Build pipeline.
Note that
https://<Project ID>.appspot.com
will also display the website. However, App Engine is moving away from this URL designation and will make the region required for all new application. See here for more information.
Here is how the website you just deployed will look like
We will make some changes to the code and watch the pipeline automatically deploy those changes to the application.
-
Navigate to Code, open the
lab_3/app/public
directory and open theindex.html
file. -
Find the Octodex image element (
img
tag) identified with theid
attributeoctodex
.
- Go to https://octodex.github.com/ and copy the image address of an Octodex that you like.
- Update the
alt
andsrc
attribute of the octodeximg
tag with description and copied address, respectively.
- Enter a commit message and click
Commit changes
.
- Navigate to Cloud Build -> History and you should see the build executing with the lab3-trigger name.
- When the build finishes executing, open your browser and refresh or go to the
<Project name>.<Region code>.r.appspot.com
website to observe the change in the application.
We have deployed our application successfully due to the defined unit tests passing successfully. We will now intentionally introduce an error into the application.
- Navigate to Code, open the
lab_3/app/
directory and open theindex.js
file.
- Change the
Hello, World!
text in the service/path
response. It can be any misspelling or a completely different text, as long as it is different.
- Enter a commit message and click
Commit changes
.
- Navigate to Cloud Build -> History to observe the build, which will fail.
- Click on the build to take a look at the more granular steps the build is running and expand the
npm test
step.
- Notice that the
API test
unit test failed and thegcloud app deploy
step was skipped. This is the default behaviour when an error occurs and the build is in a failed state.
- Fix the build by correcting the
lab_3/app/index.js
file with the proper text and commit the change.
To mimimize billing usage in your project, we can disable the application to reduce costs incurred by the application. Since the application can only be deleted along with the project, disabling it is the best way, unless of course, you would like to delete the project.
-
From the Google Cloud Console menu, select
App Engine
underCompute
. -
Select Settings at the bottom at the bottom of the left menu.
-
Click on the Disable application button. Enter the
Project ID
when prompted. -
Click Disable.
Links to more learning:
- App Engine Overview: https://cloud.google.com/appengine/docs/standard/nodejs/an-overview-of-app-engine
- App Engine Routing: https://cloud.google.com/appengine/docs/standard/nodejs/how-requests-are-routed
- App Engine Configuration (NodeJS): https://cloud.google.com/appengine/docs/standard/nodejs/config/appref
- Cloud Build Configuration: https://cloud.google.com/cloud-build/docs/build-config
- Unit Testing: https://en.wikipedia.org/wiki/Unit_testing