This project is useful if you want to try MTA on an OpenShift instance.
If you just want to test MTA using the images we have made available in the docker.io repository, go straight to the OpenShift template deployment section.
If you have made some changes to MTA and you want to test them on an OpenShift instance, in the next paragraph you'll find all the information for building your own docker images so that you're free to test your code.
There's also the case that you don't have an OpenShift instance available and, in this scenario, Red Hat Container Development Kit can help you working locally on your machine with any need for an OpenShift instance to test your changes to the code. In this case please follow the instructions in the Working with Red Hat Container Development Kit section.
For building this project and creating Docker images you have to have a Docker instance running locally on your machine so that you can pull the built images.
Next you'll find some basic instructions to install Docker based on your local OS.
- Install Docker:
$ sudo dnf install docker - Configure
dockergroup (ref. Manage Docker as a non-root user):$ sudo groupadd docker$ sudo usermod -aG docker $USER- Log out and log back in so that your group membership is re-evaluated
- Test Docker is working:
$ docker run hello-world
For any issue related to installation, you can refer to Docker documentation.
For any other platform you can follow the detailed instructions provided in the Install Docker guide from Docker.
You need an account on https://hub.docker.com in order to push your images and have them available in the docker.io repository.
So sign up yourself to Docker Hub at https://hub.docker.com taking care that the Docker ID you choose will be the <your_docker_id> value in the next steps.
- Login on https://access.redhat.com/login
- Go to Registry Service accounts
- Create a New Service Account if you don't have one
- Click on the service account and go to "Docker Login" tab.
- Copy the bash command
- Paste that command in a shell window on your local machine and execute it
- Now your local Docker installation will have the credentials in ~/.docker/config.json
- Build this project:
$ mvn clean install -Ddocker.name.windup.web=<your_docker_id>/windup-web-openshift -Ddocker.name.windup.web.executor=<your_docker_id>/windup-web-openshift-messaging-executor - Push images to docker hub:
$ docker login$ docker push <your_docker_id>/windup-web-openshift$ docker push <your_docker_id>/windup-web-openshift-messaging-executor
If you want you can also set the tag for the built images (e.g. if you are working on a specific branch and you want to create images tagged with the branch name), you just have to add the tag name to the docker.name.windup.web and docker.name.windup.web.executor system properties' values (i.e. from the above example -Ddocker.name.windup.web=<your_docker_id>/windup-web-openshift:tag_value -Ddocker.name.windup.web.executor=<your_docker_id>/windup-web-openshift-messaging-executor:tag_value)
Now that your images are available on docker.io repository, you have to reference them in MTA template in order to use these images in the deployments.
- open
./templates/src/main/resources/web-template-empty-dir-executor.jsonin an IDE or text editor - change all the
"image"values to point todocker.io/<your_docker_id>/instead ofdocker.io/windup3/
There are two different ways for deploying MTA on OpenShift based upon if you have cluster-admin privileges: if you have those privileges you can decide to follow Template deployment in OpenShift catalog (because you can operate on the default openshift project) or Import template in Openshift Web Console otherwise you can just go with the latter approach (Import template in Openshift Web Console)
There are different templates available to be imported in your OpenShift instance. The table below summarizes the different use cases for each template
| Template | Requirements | Description |
|---|---|---|
web-template-empty-dir-executor.json |
OpenShift | The recommended template to deploy MTA on OCP The analysis data between the executor pod and the web console one are sent using REST web services |
web-template-empty-dir-executor-shared-storage.json |
OpenShift with ReadWriteMany (RWX) storage |
This template deploys MTA on OCP using a shared storage between the executor pod and the web console one to share the analysis data |
- login to Openshift:
$ oc login - create the template:
$ oc create -f ./templates/src/main/resources/web-template-empty-dir-executor.json -n openshift
Now, if you go to OpenShift Web Console home page, you'll see the Migration Toolkit for Applications (ref. screenshot-0) in the list of the available templates and so you can deploy it to a project just like any other template.
screenshot-0: in OpenShift Web Console (v3.7) Browse Catalog page you can see the Migration Toolkit for Applications 4.1 icon (4th row, 2nd column)
- copy the raw content of file web-template-empty-dir-executor.json
- paste it in the "Import YAML / JSON" wizard in Openshift Web Console (ref. screenshot-1)
- save and wait for the deployment to end
screenshot-1: in OpenShift Web Console (v3.7) Import YAML / JSON wizard you can paste template raw content
If you want to build locally your own images without the need to push them to the Docker repository, you can use Red Hat Container Development Kit (CDK).
"Red Hat Container Development Kit provides a pre-built Container Development Environment based on Red Hat Enterprise Linux to help you develop container-based applications quickly." (ref. Red Hat Container Development Kit documentation).
For installing CDK, please refer to the https://developers.redhat.com web site where you can find the Hello World! guide.
Once you have a fully working CDK instance, you can follow the next steps:
- [optional]
$ systemctl stop docker(do this only if you have Docker running on your machine) $ minishift docker-envto display the command you need to type into your shell in order to configure your Docker client since the command output will differ depending on OS and shell type- execute the command from the step before
$ docker psto test that it's working fine and you can see in output a list of running containers$ oc login -u developer -p whateverto login to CDK OpenShift (the-ppassword parameter can really be whatever value you want for thedeveloperpre-built user in the CDK)$ docker login -u developer -p $(oc whoami -t) $(minishift openshift registry)to log into the CDK OpenShift Docker registry$ mvn clean install -Ddocker.name.windup.web=$(minishift openshift registry)/$(oc project -q)/windup-web-openshift:latest -Ddocker.name.windup.web.executor=$(minishift openshift registry)/$(oc project -q)/windup-web-openshift-messaging-executor:latestto build the Docker images for this project with the right tags to push them to CDK OpenShift Docker registry$ docker push $(minishift openshift registry)/$(oc project -q)/windup-web-openshiftto push the image to the registry to create an image stream$ docker push $(minishift openshift registry)/$(oc project -q)/windup-web-openshift-messaging-executorto push the image to the registry to create an image stream- now, before proceeding, you have to follow the above instructions about OpenShift template deployment
- once you have successufully deployed, you can change the deployments to point to your local images.
Go toDeploymentsweb page and:- choose
mta-web-consoledeployment page - select
Actions=>Editfrom the top right button (ref.)
- check the
Deploy images from an image stream tagbox and select the values for theImage Stream Tagcomboboxes selecting your project's name asNamespace,windup-web-openshiftforImage StreamandlatestforTag
- push the
Savebutton at the bottom of the page - repeat these steps for
mta-web-console-executordeployment usingwindup-web-openshift-messaging-executorasImage Streamcombox value
- choose
Now your deployments are using the Docker images you have built locally on your machine and, whenever you update these images, new deployments will be triggered automatically when docker push command executes.
If you need more informations about how to interact with the CDK OpenShift Docker registry, please refer to the Accessing the OpenShift Docker Registry guide.