This project uses the scripts found in openshift-project-tools to setup and maintain OpenShift environments (both local and hosted). Refer to the OpenShift Scripts documentation for details.
These instructions assume:
- You have Git, Docker, and the OpenShift CLI installed on your system, and they are functioning correctly. The recommended approach is to use either Homebrew (MAC) or Chocolatey (Windows) to install the required packages.
- 2019.02.17 - There seems to be a problem running a local cluster on OpenShift CLI versions greater than 3.9. If the version you try does not start, try reverting to OpenShift CLI Version 3.9.
- You have followed the OpenShift Scripts environment setup instructions to install and configure the scripts for use on your system.
- You have forked and cloned a local working copy of the project source code.
- You are using a reasonable shell. A "reasonable shell" is obvious on Linux and Mac, and is assumed to be the git-bash shell on Windows.
- You may have trouble with other Windows bash shells - putty, winpty, etc. If you have trouble, make sure you are using git-bash.
- You are working from the top level
./openshift
directory for the project.
Good to have:
- A moderate to advanced knowledge of OpenShift. There are two good PDFs available from Red Hat and O'Reilly on OpenShift for Developers and DevOps with OpenShift.
For the commands mentioned in these instructions, you can use the -h
parameter for usage help and options information.
When working with openshift, commands are typically issued against the server-project
pair to which you are currently connected. Therefore, when you are working with multiple servers (local, and remote for instance) you should always be aware of your current context so you don't inadvertently issue a command against the wrong server and project. Although you can login to more than one server at a time it's always a good idea to completely logout of one server before working on another.
The automation tools provided by openshift-project-tools
hide some of these details from you, in that they perform project context switching automatically. However, what they don't do is provide server context switching. They assume you are aware of your server context and you have logged into the correct server.
Some useful commands to help you determine your current context:
oc whoami -c
- Lists your current server and user context.oc project
- Lists your current project context.oc project [NAME]
- Switch to a different project context.oc projects
- Lists the projects available to you on the current server.
cd /<PathToWorkingCopy>/openshift
oc-cluster-up.sh
This will start your local OpenShift cluster using persistence so your configuration is preserved across restarts.
To cleanly shutdown your local cluster use oc-cluster-down.sh
.
Login to your local OpenShift instance on the command line and the Web Console, using developer
as both the username and password. To login to the cluster from the command line, you can get a login token from the Web Console: Login to the console. From the ? dropdown select Command Line Tools. Click on the Copy To Clipboard icon next to the oc login
line.
generateLocalProjects.sh
This command will only work on a local server context. It will fail if you are logged into a remote server. This will generate four OpenShift projects; tools, dev, test, and prod. The tools project is used for builds and DevOps activities, and dev, test, and prod are a set of deployment environments.
If you need (or want) to reset your local environments you can run generateLocalProjects.sh -D
to delete all of the OpenShift projects.
initOSProjects.sh
This will initialize the projects with permissions that allow images from one project (tools) to be deployed into another project (dev, test, prod). For production environments will also ensure the persistent storage services exist.
If you are running locally you will see some "No resources found." messages. These can safely by ignored.
When you are working with a local cluster you should generate a set of local param files. This will ensure, at the very minimum, the CPU and Memory resources (limits and requests) are configured properly to avoid builds and deployments from hanging due to lack of sufficient resources.
Before generating the local files you must create the file settings.local.sh
to override the project settings. You can start with an empty file by running touch settings.local.sh
. A likely change you will want to do if you are developing using this platform is to add this to the file:
export GIT_URI="https://github.com/bcgov/family-law-act-app.git"
and change bcgov
to your own fork of the application. As necessary, override other project settings in this file.
Once the local settings are ready, generate a set of local params by running:
genParams.sh -l
Local setting and param files are ignored by Git, so you cannot accidentally commit them to the repository.
The python:3.6
image that the django build uses may not be available in your local openshift cluster.
To solve this update your django-build.local.param
as follows;
Replace the line:
# SOURCE_IMAGE_TAG=3.6
With:
SOURCE_IMAGE_TAG=3.5
Run:
genBuilds.sh
This will generate and deploy the build configurations into the tools
project. Follow the instructions written to the command line.
If the project contains any Jenkins pipelines a Jenkins instance will be deployed into the tools
project automatically once the first pipeline is deployed by the scripts. OpenShift will automatically wire the Jenkins pipelines to Jenkins projects within Jenkins.
Use -h
to get advanced usage information. Use the -l
option to apply any local settings you have configured; when working with a local cluster you should always use the -l
option.
If you are adding build and image configurations to the application you can re-run this script. You will encounter errors for any of the resources that already exist, but you can safely ignore these errors and allow the script to continue.
If you are updating build and image configurations use the -u
option.
If you are adding and updating build and image configurations, run the script without the -u
option first to create the new resources and then again with the -u
option to update the existing configurations.
Run:
genDepls.sh -e <EnvironmentName, one of [dev|test|prod]>
Use "dev" for a local installation. This will generate and deploy the deployment configurations into the selected project; dev
, test
, or prod
. Follow the instructions written to the command line.
Use -h
to get advanced usage information. Use the -l
option to apply any local settings you have configured; when working with a local cluster you should always use the -l
option.
If you are adding deployment configurations you can re-run this script. You will encounter errors for any of the resources that already exist, but you can safely ignore these errors and allow the script to continue.
If you are updating deployment configurations use the -u
option.
If you are adding and updating deployment configurations, run the script without the -u
option first to create the new resources and then again with the -u
option to update the existing configurations.
Note:
Some settings on some resources are immutable. To replace these resources you will need to delete and recreate the associated resource(s).
Updating the deployment configurations can affect (overwrite) auto-generated secretes such as the database username and password.
Care must be taken with resources containing credentials or other auto-generated resources. You must ensure such resources are replaced using the same values._
In the current instance of the deployment, the routes created are explicitly defined for the Pathfinder (BC Gov) instance of OpenShift. Run the following script to create the default routes for your local environment:
updateRoutes.sh
The generation of builds and deployments may hang because the environment on which you are running has fewer resources (especially less memory) than is requested in the templates. The scripts give you some guidance as to what you need to do to manually fix your current setup run.
Notably:
- Cancel the current action (build or deploy)
- Remove the resources settings in either the YAML (build config) or be clearing the fields in the "Resource Limits" screen (deployment config).
The scripts also have a mechanism to override default parameters that should allow you to eliminate these hangs from occurring in the first place. The BuildConfig and DeploymentConfig overrides occur by setting values in template "param" files that override the defaults for the app. Refer to the Generate local parameters
section for details.