Getting Your PetClinic Application Up and Running¶
For this workshop you will be using the iconic Spring PetClinic application. The Spring PetClinic is a sample application designed to show how the Spring stack can be used to build simple, but powerful database-oriented applications. The official version of PetClinic demonstrates the use of Spring Boot with Spring MVC and Spring Data JPA.
You will not be focusing on the ins and outs of the PetClinic application itself, but rather on leveraging OpenShift tooling to build a PetClinic cloud native application and a DevSecOps pipeline for the application.
You will start by building your PetClinic application from the source code and connecting it to a MySQL database.
Lab Guide
- For the images in this lab:
- the green arrows or boxes denote something to look at or reference
- the red arrows or boxes denote something to click on or type.
OpenShift Cluster
You will be logging into our on-premises s390x architecture (IBM Z / IBM LinuxONE) OpenShift cluster for this lab. You will each be given a student user and your project name will be studentxx where xx is your student number. The project name depicted in the diagrams below is student00. You will be operating in your assigned project for the entirety of the lab.
Eliminate Extra Newlines
There are copy and paste boxes throughout the lab. When using these boxes, sometimes a newline will be added to the pasted result (you will know it when you see it as your cursor will be moved to the next line with whitespace shown). Please delete these newlines to stay on the happy path .
Logging into the on-premises WSC OpenShift Cluster¶
-
You will login with your assigned user and password using the link here.
-
Navigate to the project of your assigned user (it will be studentxx where xx is your number for the lab):
Deploying MySQL database¶
-
First, you need to setup your mysql database. Luckily, this is very easy on OpenShift with the mysql template available from the main developer topology window. Follow the steps in the diagram below to bring up the available database options. (Note your project name will be different than the picture below)
Now you can start the lab!
-
Next, select the
MySQL (Ephemeral)
tile.Why Ephemeral?
You are using the Ephemeral implementation because this a short-lived demo and you do not need to retain the data. In a staging or production environment, you will most likely be using a MySQL deployment backed by a Persistent Volume Claim. This stores the data in a Persistent Volume (basically a virtual hard drive), and the data will persist beyond the life of the container.
-
Click on instantiate template.
-
Fill the wizard with the parameters as shown in the image below (your namespace will be different from the image below):
petclinic
Click the
Create
button. -
A minute or two later, in the
Topology
view of your OpenShift Console, you should seemysql
in theRunning
state. (Click on the Topology icon formysql
to bring up the side panel)
Find the Repo in your gogs account¶
-
Log into the locally hosted gogs git server here (if not already logged in) using your username and password.
-
Navigate to the spring-petclinic repo by clicking on it on the right side of the login page.
-
Copy your repo URL using the copy button for the next section.
That's it! You are ready to move on to the next section.
Building and Deploying PetClinic Application¶
There are multiple ways OpenShift enables cloud native application developers to package up their applications and deploy them. For PetClinic, you will be building your container image from source, leveraging OpenShift's S2I (Source to Image) capability. This allows you to quickly test the building, packaging, and deployment of your application, and gives you the option to create and use a DevSecOps pipeline from this workflow. It's a good way to start to understand how OpenShift Pipelines work.
-
Start with choosing Add From Git:
-
Enter the repo URL you copied before in the
Git Repo URL
field. Expand theShow Advanced Git Options
section, and type inmain
for theGit Reference
. This tells OpenShift which git repo and branch to pull the source code from. -
Scroll down to the
Builder
section. Select theJava
tile and selectopenj9-11-el8
as the builder container image version. As you can see OpenShift offers many different builder container images to help you build container images from a variety of programming languages. Your list of builder container images might differ from the screen shot. For Java on Z, the recommended JVM isOpenJ9
because it has built-in s390x optimizations as well as container optimizations. -
In the General section, put in the following entries for Application Name and Name.
-
Scroll down to the Pipelines section, select the checkbox next to
Add pipeline
. You can also expand theShow pipeline visualization
section to see a visual of the build pipeline. -
You are almost there! You will need to configure a couple of Advanced Options. First, click on
Show advanced Routing options
in the Advanced Options section to expand the Routing options. -
In the Routing options section, only fill out the Security options as follows. You can leave the rest alone. These options will enable only TLS access to your PetClinic application.
-
You are done with configurations of this panel. Scroll all the way down and hit the
Create
button which will kick off the pipeline build of your PetClinic application. In a few seconds you will see your Topology with the new application icon. Hit the little pipeline icon in the diagram below to view the build logs. You might see errors associated with ImageStream not being able to pull the application image during the build process. This does not mean that the build has failed. The pipeline creates the ImageStream first and then goes through the actual build process, and since the build process takes 10-15 minutes to complete, this error will be there until then. -
The pipeline will go through three tasks:
1. fetch-repository - this Pipeline task will git clone your PetClinic repo for the build task.
2. build - this Pipeline task is the build process which itself is broken down into a few sub-steps. This is the longest task in the pipeline, and can take up to 15 minutes. The steps that it goes through are as follows:
build steps
- STEP-GENERATE: this step generates the environment and Dockerfiles that will be used to create the OCI container image later on during the build and push step
- STEP-BUILD-AND_PUSH: this is the multi-step build process of creating an OCI container image out of your Java application PetClinic followed by a push. It will download the required Maven Java packages, compile the Java application, run through a set of 39 unit tests on the application, and finally build the application jar file and the OCI container image. If the tests fail, this step will not complete. Finally, this step pushes the built OCI container image to the OpenShift image registry.
3. deploy - this Pipeline task will deploy the newly built container image as a running deployment in your project. After this, your application will be running in a pod and be accessible via a route.
Below is an image of the log of a successful build task:
-
Now if you go back to the Topology view, you should see the application has been successfully deployed to OpenShift as well. From here you can click on the
open URL
circle, and a new browser tab should open to lead you to your PetClinic's front page. It can take a couple of minutes before the application is accessible through its URL so if it doesn't come up right away wait a few minutes and try again.
Interacting with Your PetClinic Application and MySQL database¶
In this section, you will add a new owner to the Pet Clinic application, and then go into your MySQL container to see if that owner was successfully added.
1. Your Pet Clinic should look something similar to this. Go to the Find Owners tab, and create a new owner.
2. Click on the Add Owner
button, and add an owner of your own, for example:
3. You can then go back to Find Owners
and try searching for the owner that you just added. It should come back with the search results similar to the following.
4. Now let's check the MySQL database to make sure that the new owner you just added is in there.
Return to your OpenShift console, from the Topology view, click on the mysql
icon. This will bring up a side panel, and then click on the mysql
pod (your pod name will be different than the picture):
In the pod panel, go to the Terminal tab.
Now type in the following commands in your mysql
terminal (copy and paste box below image):
mysql -u root -h mysql -ppetclinic
use petclinic;
show tables;
Let's run a SQL command now to verify that the owner that you added through the application is indeed in the database (copy and paste box below image):
select * from owners;
Tip
If you added a different user than alice you should see that user in place of alice on your screen.
Please let the instructors know, if you don't see your owner you added listed.
Summary ¶
Congratulations, you have completed this part of the workshop! You have your virtual pet clinic up and running and have created an OpenShift Pipelines pipeline that you will build on in the next sections of the lab to achieve CI/CD. You may move on to the next part by clicking Next
on the bottom right of the page.
Created: April 23, 2021