Exposing Services

Overview

There are several ways you can expose your service after you deploy it on OpenShift. The following sections describe the various methods and when to use them.

Routes

If you are deploying a Web application, the most common way to expose it is by a route. A route exposes the service as a host name. You can create a route using the Web console or the CLI:

  1. oc expose svc/frontend --hostname=www.example.com

To see a full example of creating an application and exposing it with a route, see the Minishift Quickstart section.

NodePort Services

In case the service you want to expose is not HTTP based, you can create a NodePort service. In this case, each OpenShift node will proxy that port into your service. To access this port on your Minishift VM, you need to configure an Ingress IP using oc expose with the parameter type=LoadBalancer.

A common use-case for Ingress IP Self-Service is the ability to expose a database service. The following example shows the complete workflow to create and expose a MariaDB instance using Minishift:

  1. $ minishift start
  2. $ eval $(minishift oc-env)
  3. $ oc new-app -e MYSQL_ROOT_PASSWORD=admin https://raw.githubusercontent.com/openshift/origin/master/examples/db-templates/mariadb-persistent-template.json
  4. $ oc rollout status -w dc/mariadb
  5. $ oc expose dc mariadb --type=LoadBalancer --name=mariadb-ingress
  6. $ oc export svc mariadb-ingress
  7. ....
  8. ports:
  9. - nodePort: 30907
  10. ....

After the service is exposed, you can access MariaDB with the mysql CLI using the Minishift VM IP and the exposed NodePort service.

  1. $ mysql --user=root --password=admin --host=$(minishift ip) --port=30907

Port Forwarding

Using oc port-forward

If you want to quickly access a port of a specific pod of your cluster, you can also use the oc port-forward command of the OpenShift CLI.

  1. $ oc port-forward POD [LOCAL_PORT:]REMOTE_PORT

Using VirtualBox tools

In case you’re using the VirtualBox driver plugin there is another method you can use for port forwarding. This method will allow for permanent port forwarding as well as for forwarding multiple ports at the same time. This method requires you to set up a nodePort as outlined above.

If we go by the example above, we can do the following:

  1. $ VBoxManage controlvm minishift natpf1 "mariadb,tcp,,3306,,30907"

This will allow us to communicate with the mariadb service on localhost:3306 which might be convenient if you don’t want to change default ports. Additionally, an important advantage of this way of forwarding ports is that we can talk to a service as opposed to just a single pod.