Many Rafay Systems customers use Red Hat OpenShift as their platform of choice for building, deploying, running and scaling Kubernetes containerized applications. OpenShift is flexible and versatile; it can be deployed in public and private clouds, using physical or virtual servers, or both. OpenShift has proven to be of great value for operations and development teams. But getting started with OpenShift can be somewhat daunting.
This blog will help you to get started with OpenShift to create an application, configure Continuous Integration (CI) and scale the application on-demand.
First, we will setup a sample Node.js application on an OpenShift cloud. Before starting, you should have the following:
- An OpenShift online account -> https://www.OpenShift.com/products/online/
- A GitHub account. -> https://github.com
- Git installed locally ->https://help.github.com/en/articles/set-up-git
To start, you need to fork the OpenShift Node.js sample application on GitHub and clone the repository to your local environment so that you can deploy and make modifications to the application.
- On GitHub, fork a Github repository (OpenShift/nodejs-ex) by clicking on the top-right corner button on the page.
- Copy the URLs from GitHub
- Now, execute the command below on your local terminal to check out the sample application and go to the new directory.
Now, you have the local copy of the GitHub repository. You can you can make modifications and deploy on OpenShift.
Getting Familiar with the OpenShift Web Interface
To get familiar with the OpenShift online GUI, visit -> https://docs.OpenShift.com/online/architecture/infrastructure_components/web_console.html#architecture-infrastructure-components-web-console
Build a New Application
To build a new app, setup a Nodejs application using the web interface on OpenShift Online as follows:
1. Click on “Create Project”. If you are using a free account and already have a project, you must delete your existing project as only one project is allowed.
2. Give a unique name to your project on OpenShift. (e.g.: Nodejs-setup). The fields “Display Name” and “Description” are optional.
4. Name the resource that will be created by this application and the GitHub URL that was forked. Select the checkbox “create route” to access the application publicly.
5. Click on ‘Create’ to deploy your application.
6. Check the status of the application by clicking the status and selecting the nodejs project.
7.Click on the location tab to view the nodejs welcome page.
8. This confirms that you have successfully deployed a nodejs app on OpenShift.
Configure Continuous Integration (CI)
Now we will implement a CI workflow so that a rebuild of the application will get triggered when you push any changes to the GitHub repository. To accomplish this, we have to configure GitHub webhook URL from the application into GitHub repository using the following steps.
1. In the OpenShift Online web console:
a. Select the nodejs project containing your application.
b. Navigate through the Builds section , the click the name of your Node.js application.
c. From the configuration tab, click on the box next to GitHub Webhook URL to copy your GitHub Webhook.
2. Next, add the webhook to the GitHub repository:
a. In GitHub, click ’Add Webhook’ in the GitHub Webhook settings. Paste the payload URL into the Payload URL field. Ensure ‘Content’ type field is set to ’application/json’, instead of the default ‘application/x-www-form-urlencoded’. Then, click ‘Add Webhook’ to finish adding the webhook to your project:
b. GitHub now attempts to ping the OpenShift Online server to ensure that the communication is successful. If it is correctly configured, you will see a green check mark next to your new webhook URL in GitHub.
3. Finally, if you push a code change to your forked repository, the nodejs application on OpenShift will be rebuilt automatically.
Building a Code change
Now it is time to push the modified code to the application.
1. On your local desktop, use an editor to modify the GitHub code for the file (nodejs-ex/views/index.html)
2. Make some changes that will be visible from your application. For instance, change the title on line 6.
3. Commit the changes to GitHub and push the changes to master.
4. If your webhooks are configured correctly, your OpenShift project will rebuild and deploy itself. To view the changes, open the web browser.
Scaling on Demand
To meet the demands of increased traffic volume, you can add additional pods to your Node.js service.
- In the OpenShift dashboard, view the overview page for your project. Click the up-arrow button under the Nodejs service to add an additional replica of your application.
The Nodejs quickstart is configured to use 512 MB of memory per pod. You can check your quota usage in the web console:
- For the web console GUI, navigate to the project containing your application.
- Click on settings tab and scroll to the section titled Quota compute-resources to view usage:
In this blog, we have seen how it easy it is to build, deploy and scale a Nodejs application using a Red Hat OpenShift. But this is probably just the first part of your application lifecycle journey. There is much more required. In the next installment, we'll go deep to show how Rafay and OpenShift work together.
The Rafay platform works seamlessly with OpenShift to deliver SaaS-based lifecycle management capabilities. The platform automates the repetitive work devops teams carry out to keep Kubernetes environments up and running in OpenShift and other environments. Our users love the product and continue to help us make it better. If you’d like to see a demo, feel free to get in touch or simply contact us at firstname.lastname@example.org.