This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Este contenido no está disponible en el idioma seleccionado.
Chapter 6. Application Tutorials
6.1. Overview
This topic group includes information on how to get your application up and running in OpenShift Container Platform and covers different languages and their frameworks.
6.2. Quickstart Templates
6.2.1. Overview
A quickstart is a basic example of an application running on OpenShift Container Platform. Quickstarts come in a variety of languages and frameworks, and are defined in a template, which is constructed from a set of services, build configurations, and deployment configurations. This template references the necessary images and source repositories to build and deploy the application.
To explore a quickstart, create an application from a template. Your administrator may have already installed these templates in your OpenShift Container Platform cluster, in which case you can simply select it from the web console. See the template documentation for more information on how to upload, create from, and modify a template.
Quickstarts refer to a source repository that contains the application source code. To customize the quickstart, fork the repository and, when creating an application from the template, substitute the default source repository name with your forked repository. This results in builds that are performed using your source code instead of the provided example source. You can then update the code in your source repository and launch a new build to see the changes reflected in the deployed application.
6.2.2. Web Framework Quickstart Templates
These quickstarts provide a basic application of the indicated framework and language:
- CakePHP: a PHP web framework (includes a MySQL database) 
- Dancer: a Perl web framework (includes a MySQL database) 
- Django: a Python web framework (includes a PostgreSQL database) 
- NodeJS: a NodeJS web application (includes a MongoDB database) 
- Rails: a Ruby web framework (includes a PostgreSQL database) 
6.3. Ruby on Rails
6.3.1. Overview
Ruby on Rails is a popular web framework written in Ruby. This guide covers using Rails 4 on OpenShift Container Platform.
We strongly advise going through the whole tutorial to have an overview of all the steps necessary to run your application on the OpenShift Container Platform. If you experience a problem try reading through the entire tutorial and then going back to your issue. It can also be useful to review your previous steps to ensure that all the steps were executed correctly.
For this guide you will need:
- Basic Ruby/Rails knowledge
- Locally installed version of Ruby 2.0.0+, Rubygems, Bundler
- Basic Git knowledge
- Running instance of OpenShift Container Platform v3
6.3.2. Local Workstation Setup
					First make sure that an instance of OpenShift Container Platform is running and is available. For more info on how to get OpenShift Container Platform up and running check the installation methods. Also make sure that your oc CLI client is installed and the command is accessible from your command shell, so you can use it to log in using your email address and password.
				
6.3.2.1. Setting Up the Database
Rails applications are almost always used with a database. For the local development we chose the PostgreSQL database. To install it type:
sudo yum install -y postgresql postgresql-server postgresql-devel
$ sudo yum install -y postgresql postgresql-server postgresql-develNext you need to initialize the database with:
sudo postgresql-setup initdb
$ sudo postgresql-setup initdb
						This command will create the /var/lib/pgsql/data directory, in which the data will be stored.
					
Start the database by typing:
sudo systemctl start postgresql.service
$ sudo systemctl start postgresql.service
						When the database is running, create your rails user:
					
sudo -u postgres createuser -s rails
$ sudo -u postgres createuser -s railsNote that the user we created has no password.
6.3.3. Writing Your Application
If you are starting your Rails application from scratch, you need to install the Rails gem first.
gem install rails
$ gem install rails
Successfully installed rails-4.2.0
1 gem installedAfter you install the Rails gem create a new application, with PostgreSQL as your database:
rails new rails-app --database=postgresql
$ rails new rails-app --database=postgresqlThen change into your new application directory.
cd rails-app
$ cd rails-app
					If you already have an application, make sure the pg (postgresql) gem is present in your Gemfile. If not edit your Gemfile by adding the gem:
				
gem 'pg'
gem 'pg'
					To generate a new Gemfile.lock with all your dependencies run:
				
bundle install
$ bundle install
					In addition to using the postgresql database with the pg gem, you’ll also need to ensure the config/database.yml is using the postgresql adapter.
				
					Make sure you updated default section in the config/database.yml file, so it looks like this:
				
					Create your application’s development and test databases by using this rake command:
				
rake db:create
$ rake db:create
					This will create development and test database in your PostgreSQL server.
				
6.3.3.1. Creating a Welcome Page
						Since Rails 4 no longer serves a static public/index.html page in production, we need to create a new root page.
					
In order to have a custom welcome page we need to do following steps:
- Create a controller with an index action
- 
								Create a view page for the welcomecontrollerindexaction
- Create a route that will serve applications root page with the created controller and view
Rails offers a generator that will do all this necessary steps for you.
rails generate controller welcome index
$ rails generate controller welcome index
						All the necessary files have been created, now we just need to edit line 2 in config/routes.rb file to look like:
					
root 'welcome#index'
root 'welcome#index'Run the rails server to verify the page is available.
rails server
$ rails serverYou should see your page by visiting http://localhost:3000 in your browser. If you don’t see the page, check the logs that are output to your server to debug.
6.3.3.2. Configuring the Application for OpenShift Container Platform
						In order to have your application communicating with the PostgreSQL database service that will be running in OpenShift Container Platform, you will need to edit the default section in your config/database.yml to use environment variables, which you will define later, upon the database service creation.
					
						The default section in your edited config/database.yml together with pre-defined variables should look like:
					
For an example of how the final file should look, see Ruby on Rails example application config/database.yml.
6.3.3.3. Storing Your Application in Git
OpenShift Container Platform requires git, if you don’t have it installed you will need to install it.
						Building an application in OpenShift Container Platform usually requires that the source code be stored in a git repository, so you will need to install git if you do not already have it.
					
						Make sure you are in your Rails application directory by running the ls -1 command. The output of the command should look like:
					
Now run these commands in your Rails app directory to initialize and commit your code to git:
git init git add . git commit -m "initial commit"
$ git init
$ git add .
$ git commit -m "initial commit"Once your application is committed you need to push it to a remote repository. For this you would need a GitHub account, in which you create a new repository.
						Set the remote that points to your git repository:
					
git remote add origin git@github.com:<namespace/repository-name>.git
$ git remote add origin git@github.com:<namespace/repository-name>.gitAfter that, push your application to your remote git repository.
git push
$ git push6.3.4. Deploying Your Application to OpenShift Container Platform
To deploy your Ruby on Rails application, create a new Project for the application:
oc new-project rails-app --description="My Rails application" --display-name="Rails Application"
$ oc new-project rails-app --description="My Rails application" --display-name="Rails Application"
					After creating the the rails-app project, you will be automatically switched to the new project namespace.
				
Deploying your application in OpenShift Container Platform involves three steps:
- Creating a database service from OpenShift Container Platform’s PostgreSQL image
- Creating a frontend service from OpenShift Container Platform’s Ruby 2.0 builder image and your Ruby on Rails source code, which we wire with the database service
- Creating a route for your application.
6.3.4.1. Creating the Database Service
Your Rails application expects a running database service. For this service use PostgeSQL database image.
To create the database service you will use the oc new-app command. To this command you will need to pass some necessary environment variables which will be used inside the database container. These environment variables are required to set the username, password, and name of the database. You can change the values of these environment variables to anything you would like. The variables we are going to be setting are as follows:
- POSTGRESQL_DATABASE
- POSTGRESQL_USER
- POSTGRESQL_PASSWORD
Setting these variables ensures:
- A database exists with the specified name
- A user exists with the specified name
- The user can access the specified database with the specified password
For example:
oc new-app postgresql -e POSTGRESQL_DATABASE=db_name -e POSTGRESQL_USER=username -e POSTGRESQL_PASSWORD=password
$ oc new-app postgresql -e POSTGRESQL_DATABASE=db_name -e POSTGRESQL_USER=username -e POSTGRESQL_PASSWORD=passwordTo also set the password for the database administrator, append to the previous command with:
-e POSTGRESQL_ADMIN_PASSWORD=admin_pw
-e POSTGRESQL_ADMIN_PASSWORD=admin_pwTo watch the progress of this command:
oc get pods --watch
$ oc get pods --watch6.3.4.2. Creating the Frontend Service
To bring your application to OpenShift Container Platform, you need to specify a repository in which your application lives, using once again the oc new-app command, in which you will need to specify database related environment variables we setup in the Creating the Database Service:
oc new-app path/to/source/code --name=rails-app -e POSTGRESQL_USER=username -e POSTGRESQL_PASSWORD=password -e POSTGRESQL_DATABASE=db_name -e DATABASE_SERVICE_NAME=postgresql
$ oc new-app path/to/source/code --name=rails-app -e POSTGRESQL_USER=username -e POSTGRESQL_PASSWORD=password -e POSTGRESQL_DATABASE=db_name -e DATABASE_SERVICE_NAME=postgresql
						With this command, OpenShift Container Platform fetches the source code, sets up the builder image, builds your application image, and deploys the newly created image together with the specified environment variables. The application is named rails-app.
					
						You can verify the environment variables have been added by viewing the JSON document of the rails-app DeploymentConfig:
					
oc get dc rails-app -o json
$ oc get dc rails-app -o jsonYou should see the following section:
To check the build process:
oc logs -f build rails-app-1
$ oc logs -f build rails-app-1Once the build is complete, you can look at the running pods in OpenShift Container Platform.
oc get pods
$ oc get pods
						You should see a line starting with myapp-<number>-<hash>, and that is your application running in OpenShift Container Platform.
					
Before your application will be functional, you need to initialize the database by running the database migration script. There are two ways you can do this:
- Manually from the running frontend container:
First you need to exec into frontend container with rsh command:
oc rsh <FRONTEND_POD_ID>
$ oc rsh <FRONTEND_POD_ID>Run the migration from inside the container:
RAILS_ENV=production bundle exec rake db:migrate
$ RAILS_ENV=production bundle exec rake db:migrate
						If you are running your Rails application in a development or test environment you don’t have to specify the RAILS_ENV environment variable.
					
- By adding pre-deployment lifecycle hooks in your template. For example check the hooks example in our Rails example application.
6.3.4.3. Creating a Route for Your Application
						To expose a service by giving it an externally-reachable hostname like www.example.com use OpenShift Container Platform route. In your case you need to expose the frontend service by typing:
					
oc expose service rails-app --hostname=www.example.com
$ oc expose service rails-app --hostname=www.example.comIt’s the user’s responsibility to ensure the hostname they specify resolves into the IP address of the router. For more information, check the OpenShift Container Platform documentation on:
6.4. Setting Up a Nexus Mirror for Maven
6.4.1. Introduction
While developing your application with Java and Maven, you will most likely be building many times. In order to shorten the build times of your pods, Maven dependencies can be cached in a local Nexus repository. This tutorial will guide you through creating a Nexus repository on your cluster.
This tutorial assumes that you are working with a project that is already set up for use with Maven. If you are interested in using Maven with your Java project, it is highly recommended that you look at their guide.
					In addition, be sure to check your application’s image for Maven mirror capabilities. Many images that use Maven have a MAVEN_MIRROR_URL environment variable that you can use to simplify this process. If it does not have this capability, read the Nexus documentation to configure your build properly.
				
Furthermore, make sure that you give each pod enough resources to function. You may have to edit the pod template in the Nexus deployment configuration to request more resources.
6.4.2. Setting up Nexus
- Download and deploy the official Nexus container image: - oc new-app sonatype/nexus - oc new-app sonatype/nexus- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a route by exposing the newly created Nexus service: - oc expose svc/nexus - oc expose svc/nexus- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use oc get routes to find the pod’s new external address. - oc get routes - oc get routes- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output should resemble: - NAME HOST/PORT PATH SERVICES PORT TERMINATION nexus nexus-myproject.192.168.1.173.xip.io nexus 8081-tcp - NAME HOST/PORT PATH SERVICES PORT TERMINATION nexus nexus-myproject.192.168.1.173.xip.io nexus 8081-tcp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Confirm that Nexus is running by navigating your browser to the URL under HOST/PORT. To sign in to Nexus, the default administrator username is admin, and the password is admin123.
Nexus comes pre-configured for the Central Repository, but you may need others for your application. For many Red Hat images, it is recommended to add the jboss-ga repository at Maven repository.
6.4.2.1. Using Probes to Check for Success
This is a good time to set up readiness and liveness probes. These will periodically check to see that Nexus is running properly.
6.4.2.2. Adding Persistence to Nexus
If you do not want persistent storage, continue to Connecting to Nexus. However, your cached dependencies and any configuration customization will be lost if the pod is restarted for any reason.
Create a persistent volume claim (PVC) for Nexus, so that the cached dependencies are not lost when the pod running the server terminates. PVCs require available persistent volumes (PV) in the cluster. If there are no PVs available and you do not have administrator access on your cluster, ask your system administrator to create a Read/Write Persistent Volume for you. Otherwise, see Persistent Storage in OpenShift Container Platform for instructions on creating a persistent volume.
Add a PVC to the Nexus deployment configuration.
						This removes the previous emptyDir volume for the deployment config and adds a claim for one gigabyte of persistent storage mounted at /sonatype-work, which is where the dependencies will be stored. Due to the change in configuration, the Nexus pod will be redeployed automatically.
					
To verify that Nexus is running, refresh the Nexus page in your browser. You can monitor the deployment’s progress using:
oc get pods -w
$ oc get pods -w6.4.3. Connecting to Nexus
The next steps demonstrate defining a build that uses the new Nexus repository. The rest of the tutorial uses this example repository with wildfly-100-centos7 as a builder, but these changes should work for any project.
					The example builder image supports MAVEN_MIRROR_URL as part of its environment, so we can use this to point our builder image to our Nexus repository. If your image does not support consuming an environment variable to configure a Maven mirror, you may need to modify the builder image to provide the correct Maven settings to point to the Nexus mirror.
				
oc new-build openshift/wildfly-100-centos7:latest~https://github.com/openshift/jee-ex.git \ -e MAVEN_MIRROR_URL='http://nexus.<Nexus_Project>:8081/nexus/content/groups/public' oc logs build/jee-ex-1 --follow
$ oc new-build openshift/wildfly-100-centos7:latest~https://github.com/openshift/jee-ex.git \
	-e MAVEN_MIRROR_URL='http://nexus.<Nexus_Project>:8081/nexus/content/groups/public'
$ oc logs build/jee-ex-1 --follow
					Replace <Nexus_Project> with the project name of the Nexus repository. If it is in the same project as the application that is using it, you can remove the <Nexus_Project>.. Learn more about DNS resolution in OpenShift Container Platform.
				
6.4.4. Confirming Success
In your web browser, navigate to http://<Nexus IP>:8081/nexus/content/groups/public to confirm that it has stored your application’s dependencies. You can also check the build logs to see if Maven is using the Nexus mirror. If successful, you should see output referencing the URL http://nexus:8081.