Chapter 6. Running the data virtualization operator to deploy a virtual database
The data-virtualization operator helps to automate the configuration and deployment of virtual databases.
The Data Virtualization Operator processes a virtual database custom resource (CR) to deploy a virtual database object on OpenShift. By running the operator with different CRs, you can create virtual databases from a range of data sources.
Virtual databases that you deploy to OpenShift in this Technology Preview are not available in Fuse Online.
6.1. Installing the Data Virtualization Operator on OpenShift
Install the Data Virtualization Operator so that you can use it to deploy virtual database images to OpenShift from YAML-based custom resources (CRs).
You can install the data virtualization operator on OpenShift 3.11 or greater. On OpenShift 4.2 and later the Operator is available in the OperatorHub.
After you add the operator to your OpenShift cluster, you can use it to build and deploy virtual database images from a range of data sources.
Prerequisites
- You have cluster-admin access to an OpenShift 3.11 or 4.2 or greater cluster.
-
You can use the
oc
command-line tool to connect to interact with your OpenShift 3.11 cluster, or you have access to the OpenShift 4.2 or greater web console. - You have the 2020.Q1 release of Red Hat Integration.
- You have Developer access to an OpenShift server and you are familiar with using the OpenShift console and CLI.
Procedure
- Install the operator using one of the following methods, depending on the version of OpenShift that you are running.
Installing on OpenShift 3.11
From a terminal window, log in to the OpenShift cluster as a cluster administrator.
oc login
- Create or open a project where you want to deploy a virtual database.
Type the following commands:
export OP_ROOT=https://raw.githubusercontent.com/teiid/teiid-operator/7.6-0.0.x/deploy oc create -f $OP_ROOT/crds/virtualdatabase.crd.yaml 1 oc create -f $OP_ROOT/service_account.yaml oc create -f $OP_ROOT/role.yaml oc create -f $OP_ROOT/role_binding.yaml oc create -f $OP_ROOT/operator.yaml
- 1
- If you previously created a CRD in the cluster, the command returns an error, reporting that the CRD already exists. You can ignore the message.
Type the following commands to create a pull secret that you can use to access the Red Hat image registry:
oc create secret docker-registry dv-pull-secret / --docker-server=registry.redhat.io / --docker-username=$username / 1 --docker-password=$password / --docker-email=$email_address oc secrets link builder dv-pull-secret oc secrets link builder dv-pull-secret --for=pull
- 1
- Substitute the user name and password that you use to log in to the Red Hat Customer Portal.
If the command completes with no errors, the operator is deployed to your OpenShift instance within the current OpenShift project.
To enable the data virtualization operator to retrieve images from the Red Hat registry so that you can create virtual databases, link the secret that you created in Step 4 to the service account for the operator.
oc secrets link dv-operator dv-pull-secret --for=pull
Installing on OpenShift 4.2 or greater
From a terminal window, type the following commands to log in to the OpenShift cluster and create a pull secret that you can use to access the Red Hat image registry:
oc login oc create secret docker-registry dv-pull-secret / --docker-server=registry.redhat.io / --docker-username=$username / 1 --docker-password=$password / --docker-email=$email_address oc secrets link builder dv-pull-secret oc secrets link builder dv-pull-secret --for=pull
- 1
- Use your Red Hat Customer Portal login credentials.
- Log in to the OpenShift web console as a cluster administrator.
- From the OpenShift menu, expand Operators and click OperatorHub.
- Click Data Virtualization Operator 7.6.0 provided by Red Hat, Inc., and then click Install.
From the Create Operator Subscription page, verify that the selected namespace matches the name of the project where you want to install the operator, and then click Subscribe.
The Installed Operators page lists the Data Virtualization Operator and reports the status of the installation.
- From the OpenShift menu, expand Workloads and click Pods to check the status of the operator pod. After a few minutes, the pod for the operator service begins to run.
To enable the data virtualization operator to retrieve images from the Red Hat registry so that you can create virtual databases, link the secret that you created in Step 1 to the service account for the operator.
oc secrets link dv-operator dv-pull-secret --for=pull
Additional resources
6.2. Deploying virtual databases
After you create a virtual database and its corresponding CR file, run the Data Virtualization Operator to deploy the database to Openshift.
Prerequisites
- A cluster administrator added the Data Virtualization Operator to the OpenShift cluster where you want to deploy the virtual database.
- You have access to an OpenShift cluster in which the Data Virtualization Operator is installed.
- You have a CR in YAML format that provides information about how to configure and deploy the virtual database.
- The Operator has access to the Maven repositories that contain the dependencies that the build requires.
- OpenShift can access the data source that is referenced in the CR.
Procedure
- From a terminal window, log in to OpenShift and open the project where you want to create the virtual database.
-
On your computer, change to the directory that contains the
.yaml
file that contains the CR. Type the following command to run the operator to create the virtual database:
oc create -f <cr_filename.yaml>
Replace
<cr_filename.yaml>
with the name of the CR file for your data source. For example,oc create -f dv-customer.yaml
After the deployment completes, a virtual database service is added to the OpenShift cluster. The name of the service matches the name that is specified in the custom resource.
Type the following command to verify that the virtual database is created:
oc get vdbs
OpenShift returns the list of virtual databases in the project. To see whether a particular virtualization is available, type the following command:
oc get vdb <dv-name>
The deployed service supports connections from the following clients:
- JDBC clients through port 31000.
- postgreSQL clients, including ODBC clients, through port 5432.
- OData clients, through an HTTP endpoint and route.