Difficulty: Easy
Time: 30 minutes
Tasks:
- Task 2: Fork and clone the tutorial repo
- Task 3: Create a new automated build
- Task 4: Manually Trigger a Build
- Task 5: Review the build results
- Task 6: Trigger an Automated build
An automated build is a Docker image build that is triggered by a code change in a GitHub or Bitbucket repository. By linking a remote code repository to a Docker Hub automated build repository, you can build a new Docker image every time a code change is pushed to your code repository.
While Docker Hub supports linking both GitHub and Bitbucket repositories, this lab uses a GitHub repository. If you don't already have one, make sure you have a GitHub account. A basic account is free.
This lab clones and later pushes a GitHub repository using the HTTPS protocol.
The git
commands you use in the lab require that you set your config. Finally,
if you do have a GitHub account and that account is using two-factor
authentication, you need to create a token before attempting the docker push
. Without
the token you cannot authenticate over HTTPS.
-
Log into Docker Hub.
-
Navigate to Profile > Settings > Linked Accounts & Services.
-
Click the
Link GitHub
optionThe system prompts you to choose between Public and Private and Limited Access. The Public and Private connection type is required if you want to use Automated Builds.
-
Press
Select
under Public and Private connection type.If you are not logged into GitHub, the system prompts you to enter GitHub credentials before prompting you to grant access. After you grant access to your code repository, the system returns you to Docker Hub and the link is complete.
Automated builds rely on you having a code repository that contains a Dockerfile and build context. In this step, you fork a copy of a demo repo into your GitHub account. A fork allows you to make changes to the repo without affecting other users.
After forking the demo repo, you'll clone the code to one of your nodes. The demo repository defines a container for an Nginx web server with a very simple index.html
file
-
In a browser window navigate to http://www.github.com/mikegcoleman/dceu_tutorial8
-
Click the Fork button in the upper right hand corner of the page.
GitHub redirects you into your own version of the tutorial repository. When it
is done, your browser URL should be https://github.com/<your github user name>/dceu_tutorial8
.
-
Open a terminal window and SSH into your
node-3
host.ssh -i <identity file> ubuntu@<Node-3 public IP Address>
For example:
$ ssh -i user23.pem [email protected]
-
Change to your home directory.
$ cd
-
Inside the terminal window, clone your GitHub repo.
If you want to copy and paste the URL, click the clipboard under “HTTPS clone url” on your GitHub repo web page.
git clone https://github.com/<github username>/dceu_tutorial8.git
For example:
$ git clone http://www.github.com/moxiegirl/dceu_tutorial8.git
Cloning into 'dceu_tutorial8'...
remote: Counting objects: 7, done.
remote: Compressing objects: 100% (5/5), done.
remote: Total 7 (delta 0), reused 7 (delta 0), pack-reused 0
Unpacking objects: 100% (7/7), done.
Checking connectivity... done.
-
Take a moment to investigate your new repository.
$ cd dceu_tutorial8/ $ ls Dockerfile index.html README.md
You'll find a Dockerfile
and the index.html
at the root.
Now that you have a repository, let's create an automated build that fires off any time a change is pushed to our GitHub repository.
-
In your web browser, navigate back to http://hub.docker.com and log in if you aren't already.
-
Select
Create
>Create Automated Build
from Docker Hub.
The system prompts you with a list of User/Organizations and code repositories.
- Select your GitHub account from the User/Organizations list on the left.
The list of repositories change.
- Pick the
dceu_tutorial8
project to build.
If you have a long list of repos, use the filter box above the list to restrict the list. After you select the project, the system displays the Create Automated Build dialog.
-
Type in "DockerCon EU tutorial" for the Short Description
-
Click
Create
It can take a few minutes for your automated build job to be created. When the system is finished, it places you in the detail page for your Automated Build repository.
Before you trigger an automated build by pushing to your GitHub dceu_tutorial8
fork, you'll trigger a manual build. Triggering a manual build ensures everything is working correctly.
- From your automated build page.
- Choose
Build Settings
.
At the top of the Build Settings dialog is a list of configured builds. You can build from a code branch or by build tag.
Docker builds everything listed whenever a push is made to the code repository. If you specify a particular branch or tag, you can manually build that image by pressing the Trigger. If you use a regular expression syntax (regex) to define your build branch or tag, Docker does not give you the option to manually build.
-
Press the + (plus sign).
-
Choose Type > Branch.
You can build by a code branch or by an image tag. You can enter a specific value or use a regex to select multiple values. To see examples of regex, press the Show More link on the right of the page.
-
Enter the
master
for the name of the branch. -
Leave the Dockerfile location as is.
Recall the file is in the root of your code repository.
-
Specify
latest
for the Tag Name. -
Press Save Changes.
A Trigger button appears by your new build configuration.
- Press the trigger button.
You can only trigger one build at a time and no more than one every five minutes. If you already have a build pending, or if you recently submitted a build request, Docker ignores new requests.
The Build Details page shows a log of your build systems:
-
Navigate to the Build Details page.
-
Wait until your image build is done.
You may have to manually refresh the page and your build may take several minutes to complete.
-
Copy the Docker Pull Command from the right side of the page.
-
Switch back to your terminal window and pull down your newly built image
docker pull <docker hub username>/dceu_tutorial8
For example:
$ docker pull moxiegirl/dceu_tutorial8 Using default tag: latest latest: Pulling from moxiegilr/dceu_tutorial8 90d7a4de1ef5: Pull complete 60b05e04b5b6: Pull complete 95d79d93cde4: Pull complete Digest: sha256:eab8584e5b08227637ff7ff77b933e062f3abb031b6e423bbf465d408632eae9 Status: Downloaded newer image for moxiegirl/dceu_tutorial8:latest
-
Run the image to make sure it's executing correctly
docker run -d -p 80:80 --name mywebserver <docker hub username>/dceu_tutorial8
-
In your web browser, navigate to your
node-3
public IP address.You should see a web page with some simple text.
-
Switch back to your terminal window, stop and remove your running container
$ docker stop mywebserver mywebserver $ docker rm mywebserver mywebserver
-
Remove the web server image
docker rmi <docker hub username>/dceu_tutorial8
For example:
$ docker rmi moxiegirl/dceu_tutorial8
Untagged: moxiegirl/dceu_tutorial8:latest
Deleted: b10dfa917433ffa9d607e455f8ff6fb1eef3e05e8155114133a469bc286acf4f
Deleted: 30ed62e32a0400ca3eaf690994084145f5ddee6a43907330ba3a56f7f6e8026c
Deleted: c1c8f9501c437973ed0aa768a937e4e64143af6c02efb0b0793fa9e4d3005e33
Deleted: 914c82c5a678cf9fa73c25d91d30f5e174ac69f6b494890d262cc58f43b304ef
Deleted: a96311efcda8ee1e48c0f499d54ad1c2a5387376d43c379837f38562e85a03f2
Deleted: edeba58b4ca77142435dfa2b190c0b3922e7bb4bcfb55c786d091baec7a5dbcd
Now that you've confirmed your image builds manually, you'll push a change to
the GitHub repo. This change will trigger an automated build of your
dceu_tutorial8
Docker image.
-
In your terminal window, change to the
dceu_tutorial8
directory.$ cd ~/dceu_tutorial8
-
Change the
index.html
file for the webserver.$ echo 'Hello Automated Build' > index.html
Make sure to use single quotes (').
-
List the
index.html
file's contents to make sure they were updated.$ cat index.html Hello Automated Build
-
Set your Git config if you haven't already.
git config --global user.email "[email protected]" git config --global user.name "Firstname Lastname"
-
Add the updated file to your GitHub repo
$ git add .
-
Commit the change
$ git commit -m "update index.html" [master 72e748d] update index.html 1 file changed, 1 insertion(+), 1 deletion(-)
-
Push you changes to the GitHub repo.
$ git push origin master
The system prompts you for your GitHub username and password.
Counting objects: 3, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 277 bytes | 0 bytes/s, done.
Total 3 (delta 1), reused 0 (delta 0)
To https://github.com/<github username>/dceu_tutorial8.git
-
In your web browser, navigate back to Docker Hub.
-
Go to your
dceu_tutorial8
Build Details page and confirm that there is a new build.
Do not move to the next step until your build completes. You may have to manually refresh the page.
-
Copy the "Docker Pull Command" from the page's right hand side.
-
Switch back to your terminal window and pull down your newly built image.
$ docker pull <docker hub username>/dceu_tutorial8 Using default tag: latest latest: Pulling from <docker hub username>/dceu_tutorial8 90d7a4de1ef5: Pull complete 60b05e04b5b6: Pull complete 95d79d93cde4: Pull complete Digest: sha256:eab8584e5b08227637ff7ff77b933e062f3abb031b6e423bbf465d408632eae9 Status: Downloaded newer image for <docker hub username>/dceu_tutorial8:latest
-
Run the
webserver
to make sure it's executing correctly$ docker run -d -p 80:80 --name mywebserver <docker hub username>/dceu_tutorial8 b9d2496ba15ebd61d288028ae45f2479267ed4c183920b3080ebe2735eca133e
-
Now, in your web browser navigate to your
node-3
IP address.You should see a web page with the text
"Hello Automated Build"
.
Congrats!! You have completed this lab and learned how to integrate GitHub and Docker Hub to automate your image builds!
If you plan to do another lab, you need to cleanup your EC2 instances. Cleanup removes any environment variables, configuration changes, Docker images, and running containers. To do a clean up,
-
Log into each EC2 instance you used and run the following:
$ source /home/ubuntu/cleanup.sh
-
In your web browser, navigate to your
dceu_tutorial8
repository on Docker Hub -
Click Settings (not Build Settings).
-
Press Delete.
-
Enter the repository name
dceu_tutorial8
when prompted. -
Press Delete.
-
In your browser, navigate \GitHub
dceu_tutorial8
repo.https://github.com/<github username>/dceu_tutorial8
-
On the right hand side of the web page click Settings.
-
Scroll down to the Danger Zone and click Delete this Repository.
-
Enter the repository name.
<github username>/dceu_tutorial8
-
Press I understand the consequences, to delete this repository.
Docker Hub documentation.