You can jump right to the OpenShift Babygame if you can't wait to see it live at: http://babygame-ishereon.rhcloud.com/babygame.php.
We will assume you have registered a user at http://www.openshift.com.
Get Babygame code
First step is to pull a copy of the BabyGame from github.
Next you will want to setup your client tools for OpenShift access as outlined in their Quick Start. I am running Fedora 15 so just had to add the yum repo and install rhc. This brings us to the point of actually getting into setup of our applications new home.
Create your domain
# We need to create the domain for Express to start setting up # our URL with the client tooling using # rhc-create-domain -n domainname -l rhlogin # $ rhc-create-domain --help Usage: /usr/bin/rhc-create-domain Bind a registered rhcloud user to a domain in rhcloud. NOTE: to change ssh key, please alter your ~/.ssh/libra_id_rsa and ~/.ssh/libra_id_rsa.pub key, then re-run with --alter -n|--namespace namespace Namespace for your application(s) (alphanumeric - max 16 chars) (required) -l|--rhlogin rhlogin Red Hat login (RHN or OpenShift login with OpenShift Express access) (required) -p|--password password RHLogin password (optional, will prompt) -a|--alter Alter namespace (will change urls) and/or ssh key -d|--debug Print Debug info -h|--help Show Usage info # So we setup one for the Babygame. Note that I already have setup my ssh keys for OpenShift, # if you have not yet done that, then it will walk you through it. # $ rhc-create-domain -n ishereon -l [registered-user] -p [your-password] OpenShift Express key found at /home/[homedir]/.ssh/libra_id_rsa. Reusing... Contacting https://openshift.redhat.com Creation successful You may now create an application. Please make note of your local config file in /home/[homedir]/.openshift/express.conf which has been created and populated for you.
Create your application
Next we want to create our application, which means we want to tell the OpenShift Express which stack we need. This is done with the rhc-create-app client tool.
# Let's take a look at the options available before we setup a php stack for # our babygame app. # $ rhc-create-app --help Contacting https://openshift.redhat.com to obtain list of cartridges... (please excuse the delay) Usage: /usr/bin/rhc-create-app Create an OpenShift Express app. -a|--app application Application name (alphanumeric - max 16 chars) (required) -t|--type type Type of app to create (perl-5.10, jbossas-7.0, wsgi-3.2, rack-1.1, php-5.3) (required) -l|--rhlogin rhlogin Red Hat login (RHN or OpenShift login with OpenShift Express access) (Default: xxxxxxxxx) -p|--password password RHLogin password (optional, will prompt) -r|--repo path Git Repo path (defaults to ./$app_name) -n|--nogit Only create remote space, don't pull it locally -d|--debug Print Debug info -h|--help Show Usage info # It seems we can choose between several but we want the php-5.3 # stack (called a cartridge). I provide a user, password and location # for the git repo to be created called 'babygame-express', see the # documentation for the defaults. Let's watch the magic happen! # $ rhc-create-app -a babygame -t php-5.3 -l [registered-user] -p [password] -r /home/[homedir]/git-projects/babygame-express Found a bug? Post to the forum and we'll get right on it. IRC: #openshift on freenode Forums: https://www.redhat.com/openshift/forums Attempting to create remote application space: babygame Contacting https://openshift.redhat.com API version: 1.1.1 Broker version: 1.1.1 RESULT: Successfully created application: babygame Checking ~/.ssh/config Contacting https://openshift.redhat.com Found rhcloud.com in ~/.ssh/config... No need to adjust Now your new domain name is being propagated worldwide (this might take a minute)... retry # 1 - Waiting for DNS: babygame-ishereon.rhcloud.com retry # 2 - Waiting for DNS: babygame-ishereon.rhcloud.com retry # 3 - Waiting for DNS: babygame-ishereon.rhcloud.com retry # 4 - Waiting for DNS: babygame-ishereon.rhcloud.com Pulling new repo down Warning: Permanently added 'babygame-ishereon.rhcloud.com,220.127.116.11' (RSA) to the list of known hosts. Confirming application babygame is available Attempt # 1 Success! Your application is now published here: http://babygame-ishereon.rhcloud.com/ The remote repository is located here: ssh://firstname.lastname@example.org/~/git/babygame.git/ To make changes to your application, commit to /home/[homedir]/git-projects/babygame-express/. Then run 'git push' to update your OpenShift Express space
If we take a look at my given path to the repo we find a git-projects/babygame-express git repository! Note that if you decide to alter your domain name you will have to adjust the git repository config file to reflect where the remote repository is, see above the line with 'ssh:.....'. Also the page is already live at http://babygame-ishereon.rhcloud.com/, how about that!
It is just a splash screen to get you started, so now we move on to getting the babygame running.
First lets look at the provided README in our babygame-express project which gives some insight to the repository layout.
Repo layout =========== php/ - Externally exposed php code goes here libs/ - Additional libraries misc/ - For not-externally exposed php code ../data - For persistent data (full path in environment var: OPENSHIFT_DATA_DIR) deplist.txt - list of pears to install .openshift/action_hooks/build - Script that gets run every push, just prior to starting your app
The babygame app also comes with a README file that states we need to just add the babygame.php, const.inc.php, introtext.php, and *.jpg files to a webserver, so we will place these in the git repository that was created into the php directory.
# placing our application into our express git repo. # $ cp babygame/babygame.php git-projects/babygame-express/php/ $ cp babygame/const.inc.php git-projects/babygame-express/php/ $ cp babygame/introtext.php git-projects/babygame-express/php/ $ cp *.jpg git-projects/babygame-express/php/ # lets see what is going on in our project, for git commands please refer to git online help. # $ git st # On branch master # Untracked files: # (use "git add
..." to include in what will be committed) # # php/babyblue.jpg # php/babygame.php # php/babypink.jpg nothing added to commit but untracked files present (use "git add" to track) # now we need to add, commit and push them to the master repo. # $ git add php/*.jpg php/*.php $ git st # On branch master # Changes to be committed: # (use "git reset HEAD ..." to unstage) # # new file: php/babyblue.jpg # new file: php/babygame.php # new file: php/babypink.jpg # new file: php/introtext.php # new file: php/const.inc.php # $ git commit -m "Added babygame and images." [master 8b73d1a] Added babygame and images. 3 files changed, 364 insertions(+), 0 deletions(-) create mode 100644 php/babyblue.jpg create mode 100644 php/babygame.php create mode 100644 php/babypink.jpg $ git push origin Counting objects: 8, done. Delta compression using up to 2 threads. Compressing objects: 100% (6/6), done. Writing objects: 100% (6/6), 10.48 KiB, done. Total 6 (delta 1), reused 0 (delta 0) remote: Stopping application... remote: Waiting for stop to finish remote: Done remote: Running .openshift/action_hooks/build remote: Starting application... To ssh://email@example.com/~/git/babygame.git/ ff8218d..8b73d1a master -> master
Now we should be able to find our application online at http://babygame-ishereon.rhcloud.com/babygame.php.
# clean out the default files. # $ git rm php/index.php rm 'php/index.php' $ git rm php/health_check.php rm 'php/health_check.php' $ git st # On branch master # Changes to be committed: # (use "git reset HEAD
..." to unstage) # # deleted: php/health_check.php # deleted: php/index.php # $ git commit -m "Removed default files." [master 820db4f] Removed default files. 0 files changed, 0 insertions(+), 2 deletions(-) delete mode 100644 php/health_check.php delete mode 100644 php/index.php (100%) $ git push origin Counting objects: 5, done. Delta compression using up to 2 threads. Compressing objects: 100% (2/2), done. Writing objects: 100% (2/2), 384 bytes, done. Total 2 (delta 1), reused 0 (delta 0) remote: Stopping application... remote: Waiting for stop to finish remote: Done remote: Running .openshift/action_hooks/build remote: Starting application... To ssh://firstname.lastname@example.org/~/git/babygame.git/ 8b73d1a..820db4f master -> master
|Babygame without a database|
Setup mySQL database on OpenShift
So for now we have our project on line, but the MySQL database needs to be setup. The babygame without a database is just a bunch of garbled layout and empty tables. We can't have that now can we?
Let's get our mySQL database setup on OpenShift.
# First we need to add the mysql database instance to our Express instance, # by making use of the rhc-ctl-app client tool. # $ rhc-ctl-app --help Usage: /usr/bin/rhc-ctl-app Control an OpenShift express app -a|--app application Application name (alphanumeric) (required) -l|--rhlogin rhlogin Red Hat login (RHN or OpenShift login with OpenShift Express access) (Default: xxxxxx) -p|--password password RHLogin password (optional, will prompt) -c|--command command (start|stop|restart|reload|status|destroy) -L|--embedded-list List supported embedded cartridges -e|--embed (add-$cartridge|remove-$cartridge) eg: add-mysql-5.1 -b|--bypass Bypass warnings -d|--debug Print Debug info -h|--help Show Usage info # now lets add the mysql-5.1 embedded cartridge. # $ rhc-ctl-app -a babygame -l [registered-user] -p [password] -e add-mysql-5.1 Contacting https://openshift.redhat.com Contacting https://openshift.redhat.com API version: 1.1.1 Broker version: 1.1.1 RESULT: Mysql 5.1 database added. Please make note of these credentials: Root User: admin Root Password: XXXXXXXXX Database Name: babygame Connection URL: mysql://XXX.X.X.X:3306/
Now we need to add the const.inc.php file and adjust to reflect the proper db variables. So we adjust this and push the file to our repo.
# edit our const.inc.php file to add mysql database info and set the initial birth dates. # $ cat const.inc.php [skip boring parts] // Database settings. // define( "DB_SERVER", $_ENV['OPENSHIFT_DB_HOST'] ); define( "DB_USER", $_ENV['OPENSHIFT_DB_USERNAME'] ); define( "DB_PASSWORD", $_ENV['OPENSHIFT_DB_PASSWORD'] ); define( "DB_DATABASE", "babygame" ); # Add the config file, push to repo. # $ git add php/const.inc.php; git commit -m "Added mysql config file."; git push origin [master b7f9973] Added mysql config file. 1 files changed, 31 insertions(+), 0 deletions(-) create mode 100644 php/const.inc.php Counting objects: 6, done. Delta compression using up to 2 threads. Compressing objects: 100% (4/4), done. Writing objects: 100% (4/4), 778 bytes, done. Total 4 (delta 2), reused 0 (delta 0) remote: Stopping application... remote: Waiting for stop to finish remote: Done remote: Running .openshift/action_hooks/build remote: Starting application... To ssh://email@example.com/~/git/babygame.git/ 820db4f..b7f9973 master -> master
Managing your mySQL database
One problem I had was that the database was created, but not the table 'guesses' that I needed. To achieve this I had to put some configuration changes into the build script that runs on each push to the repo (causing a fresh deploy of your application).
# addded this to my .openshift/action_hooks/build file in # the babygame project. # set -e if [ -z $OPENSHIFT_DB_HOST ] then echo 1>&2 echo "Could not find mysql database. Please run:" 1>&2 echo "rhc-ctl-app -a $OPENSHIFT_APP_NAME -e add-mysql-5.1" 1>&2 echo "then make a sample commit (add whitespace somewhere) and re-push" 1>&2 echo 1>&2 exit 5 fi # check for database. if ! /usr/bin/mysql -u "$OPENSHIFT_DB_USERNAME" --password="$OPENSHIFT_DB_PASSWORD" -h "$OPENSHIFT_DB_HOST" -e "show tables;" $OPENSHIFT_APP_NAME > /dev/null then echo 1>&2 echo "Could not find mysql database. " 1>&2 echo "Creating database for application named: $OPENSHIFT_APP_NAME." 1 >&2 /usr/bin/mysqladmin -u "$OPENSHIFT_DB_USERNAME" --password="$OPENSHIFT_DB_PASSWORD" -h "$OPENSHIFT_DB_HOST" create "$OPENSHIFT_APP_NAME" fi # Confirm database exists, if not create it if ! /usr/bin/mysql -u "$OPENSHIFT_DB_USERNAME" --password="$OPENSHIFT_DB_PASSWORD" -h "$OPENSHIFT_DB_HOST" -e "select * from guesses;;" "$OPENSHIFT_APP_NAME" > /dev/null then echo echo "Schema not found! Importing schema from .openshift/action_hooks/baby.sql" echo /usr/bin/mysql -u "$OPENSHIFT_DB_USERNAME" --password="$OPENSHIFT_DB_PASSWORD" -h "$OPENSHIFT_DB_HOST" "$OPENSHIFT_APP_NAME" < "$OPENSHIFT_REPO_DIR/.openshift/action_hooks/baby.sql" echo echo "done." else echo "Database found, skipping import." fi
|Fully configured babygame!|
This completes the migration of the original PHP Babygame application from a local installation to the cloud with OpenShift Express!
I will be pushing this project soon to github at https://github.com/eschabell.
Happy guessing! :-)