KEMBAR78
Platform Extensions | PDF | Cloud Computing | Linux
0% found this document useful (0 votes)
257 views116 pages

Platform Extensions

Uploaded by

Abhy Singh
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
257 views116 pages

Platform Extensions

Uploaded by

Abhy Singh
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 116

OpenText™ Documentum™ Platform and

Platform Extensions

Cloud Deployment Guide

This guide contains information about deploying and


configuring cloud-native Documentum Platform and Platform
Extensions products on different Cloud environments.

EDCSYCD160700-IGD-EN-02
OpenText™ Documentum™ Platform and Platform Extensions
Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
Rev.: 2019-Sept-25
This documentation has been created for software version 16.7.
It is also valid for subsequent software versions as long as no new document version is shipped with the product or is
published at https://knowledge.opentext.com.

Open Text Corporation

275 Frank Tompa Drive, Waterloo, Ontario, Canada, N2L 0A1

Tel: +1-519-888-7111
Toll Free Canada/USA: 1-800-499-6544 International: +800-4996-5440
Fax: +1-519-888-0677
Support: https://support.opentext.com
For more information, visit https://www.opentext.com

Copyright © 2019 Open Text. All Rights Reserved.


Trademarks owned by Open Text.

One or more patents may cover this product. For more information, please visit https://www.opentext.com/patents.

Disclaimer

No Warranties and Limitation of Liability

Every effort has been made to ensure the accuracy of the features and techniques presented in this publication. However,
Open Text Corporation and its affiliates accept no responsibility and offer no warranty whether expressed or implied, for the
accuracy of this publication.
Table of Contents

PRE Preface vii


i Revision History .............................................................................. vii

1 Deploying Documentum Platform and Platform


Extensions applications on Docker environment .................. 9
1.1 Introduction ....................................................................................... 9
1.2 Supported applications and versions .................................................. 9
1.3 Installing Docker ............................................................................... 9
1.4 Deploying and configuring Documentum Server on Docker
environment .................................................................................... 10
1.4.1 Prerequisites .................................................................................. 10
1.4.2 Common notes ............................................................................... 10
1.4.3 Creating the Documentum Server Red Hat Enterprise Linux/Oracle
Docker image ................................................................................. 12
1.4.3.1 Prerequisites .................................................................................. 12
1.4.3.1.1 Hardware requirements (Machine 1 – Container for Documentum
Server) ........................................................................................... 12
1.4.3.1.2 Hardware requirements (Machine 2 – Container for Oracle server) ..... 12
1.4.3.1.3 Software requirements .................................................................... 12
1.4.3.2 Configuring the Red Hat Enterprise Linux base image ....................... 13
1.4.3.2.1 Installing Oracle client ..................................................................... 14
1.4.3.3 Configuring to create the Documentum Server Red Hat Enterprise
Linux/Oracle Docker image .............................................................. 16
1.4.4 Exporting environment variables for storing passwords to Docker
environment .................................................................................... 16
1.4.5 Deploying and configuring Documentum Server on Stateless
images ........................................................................................... 17
1.4.6 Deploying and configuring of Documentum Server HA on Docker
environment .................................................................................... 18
1.5 Deploying and configuring Independent Java Method Server on
Docker environment ........................................................................ 19
1.5.1 Prerequisites .................................................................................. 19
1.5.2 Deploying IJMS on Docker environment ........................................... 19
1.5.2.1 Port details ..................................................................................... 21
1.5.2.2 Volume details ................................................................................ 21
1.6 Deploying and configuring Documentum Foundation Classes on
Docker environment ........................................................................ 21
1.7 Deploying and configuring Documentum Administrator on Docker
environment .................................................................................... 22

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide iii
EDCSYCD160700-IGD-EN-02
Table of Contents

1.7.1 Prerequisites .................................................................................. 22


1.7.2 Deploying Documentum Administrator on Docker environment .......... 22
1.8 Deploying and configuring BOCS on Docker environment .................. 24
1.9 Deploying and configuring Documentum Foundation Services on
Docker environment ........................................................................ 25
1.10 Deploying and configuring Content Intelligence Services on Docker
environment .................................................................................... 25
1.10.1 Prerequisites .................................................................................. 25
1.10.2 Common notes ............................................................................... 26
1.10.3 Deploying Content Intelligence Services on Docker environment ........ 27
1.10.4 Configuring Content Intelligent Services on Docker environment ........ 27
1.10.4.1 Sample silent.ini for deploying CIS ................................................... 29
1.10.5 Verifying the deployment ................................................................. 29
1.10.5.1 Verifying the deployment of CIS artifacts (DAR file) ........................... 29
1.10.5.2 Verifying that the repository is enabled for CIS .................................. 29
1.10.5.3 Verifying that the tables are created ................................................. 30
1.10.5.4 Verifying the configuration of the entity detection server ..................... 31
1.10.5.5 Verifying that all services are started ................................................ 31
1.11 Deploying and configuring Federated Search Services on Docker
environment .................................................................................... 32
1.11.1 Prerequisites .................................................................................. 32
1.11.2 Common notes ............................................................................... 32
1.11.3 Deploying Federated Search Services on Docker container ............... 33
1.11.4 Configuring Federated Search Services on Docker container ............. 33
1.12 Deploying and configuring REST Services on Docker environment .... 34
1.13 Deploying and configuring Thumbnail Server on Docker
environment .................................................................................... 34

2 Deploying Documentum Platform and Platform


Extensions applications on Private Cloud ............................ 37
2.1 Overview ........................................................................................ 37
2.2 Supported applications and versions ................................................ 37
2.3 Deploying and configuring Documentum Server on private cloud ....... 37
2.3.1 Prerequisites .................................................................................. 37
2.3.2 Deploying Documentum Server on Kubernetes environment .............. 39
2.3.3 Upgrading Documentum Server on Kubernetes environment ............. 56
2.3.3.1 Upgrading from 16.4 patch version to 16.7 ........................................ 56
2.3.3.2 Upgrading from one patch version to another patch version ............... 57
2.3.3.3 Rolling back the upgrade process .................................................... 59
2.3.4 Limitations ...................................................................................... 59
2.3.5 Troubleshooting .............................................................................. 59
2.4 Deploying and configuring Independent Java Method Server on
private cloud ................................................................................... 60

iv OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
Table of Contents

2.4.1 Prerequisites .................................................................................. 61


2.4.2 Deploying Independent Java Method Server on Kubernetes
environment .................................................................................... 61
2.4.3 Limitations ...................................................................................... 65
2.4.4 Troubleshooting .............................................................................. 65
2.5 Deploying and configuring Documentum Administrator on private
cloud .............................................................................................. 65
2.5.1 Prerequisites .................................................................................. 65
2.5.2 Deploying Documentum Administrator on Kubernetes environment .... 65
2.5.3 Limitations ...................................................................................... 72
2.5.4 Troubleshooting .............................................................................. 72
2.6 Deploying and configuring Documentum Foundation Services on
private cloud ................................................................................... 73
2.6.1 Prerequisites .................................................................................. 73
2.6.2 Deploying Documentum Foundation Services on Kubernetes
environment .................................................................................... 73
2.6.3 Limitations ...................................................................................... 76
2.6.4 Troubleshooting .............................................................................. 76
2.7 Deploying and configuring Documentum REST Services on private
cloud .............................................................................................. 77
2.7.1 Prerequisites .................................................................................. 77
2.7.2 Deploying Documentum REST Services on Kubernetes
environment .................................................................................... 77
2.7.2.1 Configuring SSL .............................................................................. 81
2.7.2.2 Integrating Graylog .......................................................................... 82
2.7.3 Upgrading Documentum REST Services on Kubernetes
environment .................................................................................... 83
2.7.4 Rolling back the upgrade process .................................................... 83
2.7.5 Extensibility .................................................................................... 83
2.7.6 Limitations ...................................................................................... 84
2.7.7 Troubleshooting .............................................................................. 84

3 Deploying Documentum Platform and Platform


Extensions applications on Microsoft Azure cloud
platform .................................................................................... 85
3.1 Supported applications and versions ................................................ 85
3.2 Deploying and configuring Documentum Server on Microsoft Azure
cloud platform ................................................................................. 85
3.2.1 Prerequisites .................................................................................. 85
3.2.2 Deploying Documentum Server on Microsoft Azure cloud platform ..... 95
3.2.3 Configuring external IP address ....................................................... 97
3.2.4 Limitations ...................................................................................... 98
3.2.5 Troubleshooting .............................................................................. 98

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide v


EDCSYCD160700-IGD-EN-02
Table of Contents

3.3 Deploying and configuring Documentum Administrator on Microsoft


Azure cloud platform ....................................................................... 99
3.3.1 Prerequisites .................................................................................. 99
3.3.2 Deploying Documentum Administrator on Microsoft Azure cloud
platform .......................................................................................... 99
3.3.3 Limitations .................................................................................... 100
3.3.4 Troubleshooting ............................................................................ 100
3.4 Deploying and configuring Documentum REST Services on
Microsoft Azure cloud platform ....................................................... 100
3.4.1 Prerequisites ................................................................................ 100
3.4.2 Deploying Documentum REST Services on Microsoft Azure cloud
platform ........................................................................................ 100
3.4.3 Configuring external IP address ..................................................... 100
3.4.4 Limitations .................................................................................... 100
3.4.5 Troubleshooting ............................................................................ 100

4 Deploying Documentum Platform and Platform


Extensions applications on Google Cloud Platform .......... 101
4.1 Supported applications versions ..................................................... 101
4.2 Deploying and configuring Documentum Server on Google Cloud
Platform ........................................................................................ 101
4.2.1 Prerequisites ................................................................................ 101
4.2.2 Deploying Documentum Server on Google Cloud Platform .............. 106
4.2.3 Limitations .................................................................................... 112
4.2.4 Troubleshooting ............................................................................ 113
4.3 Deploying and configuring Documentum Administrator on Google
Cloud Platform .............................................................................. 113
4.3.1 Prerequisites ................................................................................ 113
4.3.2 Deploying Documentum Administrator on Google Cloud Platform ..... 113
4.3.3 Limitations .................................................................................... 114
4.3.4 Troubleshooting ............................................................................ 114
4.4 Deploying and configuring Documentum REST Services on Google
Cloud Platform .............................................................................. 114
4.4.1 Prerequisites ................................................................................ 114
4.4.2 Deploying Documentum REST Services on Google Cloud Platform .. 114
4.4.3 Limitations .................................................................................... 115
4.4.4 Troubleshooting ............................................................................ 115

vi OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
Preface
Preface
This guide contains information about deploying and configuring cloud-native
Documentum Platform and Platform Extensions products on different Cloud
environments.

As OpenText Documentum advances towards the cloud world, it is also designed to


guide you to advance your journey towards the cloud world by providing you with
roadmaps to adopt new cloud deployments, while continuing to support legacy
environments and have hybrid implementations. The move to the cloud world is
driven by the following key capabilities for you to:

• reduce the high operating costs to develop, manage and maintain on-premises
applications
• avoid end user adoption issues caused by slow performance and lengthy
deployment timelines
• gain access to extensive resources to support EIM applications
• deploy EIM applications and grow as needed to scale to your business needs

With evidence that the cloud is the future for data, and that it is imminent that
enterprise workloads will run in the cloud, OpenText encourages you to choose the
cloud over an on-premise solution.

IMPORTANT

Documentum Content Server is now OpenText Documentum Server. OpenText


Documentum Server will be called Documentum Server throughout this guide.

i Revision History
Revision Date Description
October 2019 Initial publication.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide vii
EDCSYCD160700-IGD-EN-02
Chapter 1
Deploying Documentum Platform and Platform
Extensions applications on Docker environment

1.1 Introduction
You can deploy and configure Documentum Platform and Platform Extensions
applications on the supported Docker containers.

Docker is an open-source project that automates the deployment of applications


inside software containers, by providing an additional layer of abstraction and
automation of Operating System level Virtualization. Docker uses resource isolation
features of the Linux kernel such as cgroups and kernel namespaces to allow
independent containers to run within a single Linux instance, avoiding the overhead
of starting and maintaining virtual machines. Docker is a tool that can package an
application and its dependencies in a virtual container that can run on any Linux
server.

1.2 Supported applications and versions


The Release Notes document contains the information about the list of applications
and its supported versions.

Note: Docker images for Documentum Server with the following configuration
are provided: Ubuntu/PostgreSQL and CentOS/PostgreSQL.

1.3 Installing Docker


1. Log in with root account and install the Docker Engine.

2. Start the Docker daemon service.

Docker Documentation contains more information.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 9


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

1.4 Deploying and configuring Documentum Server


on Docker environment
1.4.1 Prerequisites
• Check your kernel version. You must have the supported version of Red Hat
Enterprise Linux for the Docker support. It requires a 64-bit installation
regardless of your Linux version and you should have the supported version of
kernel. To check your current kernel version, open a terminal and run the
following command:

uname -r

• (Only for CentOS) Check the file system type. If the Docker mount point is an xfs
file system, then set d_type to true. Docker Documentation contains more
information.
• For Docker Documentum Server image, the location of INSTALL_HOME is /opt for
CentOS and Ubuntu images. Ensure that in the Docker Compose file, you must
use /opt as your Documentum home directory.

1.4.2 Common notes


• For internal applications, use the internal connection broker (for example,
running on 1489). Do not have any translations. Point dfc.properties of
internal clients to use internal Docker IP. For external applications, use the
external connection broker (for example, running on 1689). Translations are done
by the Docker scripts automatically. The translation is from internal Docker IP to
external IP. Point dfc.properties to external IP of the connection broker.
• If you use remote file system with netshare plugin, then ensure to install the
respective NFS or CIFS RPMs in Docker host machine. For example: yum install
nfs* (for NFS) and yum install cifs* (for CIFS).

• For stateless configuration on CIFS, you must create the volumes manually and
then use the GID and UID identifiers for netshare plugin. Docker Documentation
contains the workaround details.
• UID should be synchronized or same when deploying Documentum Server
between different host systems for seamless upgrade or sharing of data between
two systems.
• If you use netshare plugin for remote data and for any reason if the service is
restarted, you must run the following command:

docker-compose -f <compose file name> up -d

You can use the configured YML file names in your up command to start the
container.
For example, Documentum provides the following compose YML files:

10 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.4. Deploying and configuring Documentum Server on Docker environment

– CS-Docker-Compose_Stateless.yml
– CS-Docker-Compose_Ha.yml
– CS-Docker-Compose_Seamless.yml
• If the image is a TAR file, then load the image into the local registry using the
following command and update the Documentum Server image name:

#docker load -i <file name of TAR image>


• In stateless and HA configurations, to ensure that the Docker volumes are
synchronized, you must use the project name or place the configuration files in
the same location. For example, you can use the following command:

docker_compose -f CS-Docker-Compose_Stateless.yml -p <project


name> up -d
• If your database is PostgreSQL, perform the following:

– Linux: Log in as a postgres user and create a folder called


db_<RepositoryName>_dat.dat in /var/lib/pgsql/<supported
PostgreSQL version number>/data/.

– Windows: Log in as a postgres user and create a folder called


db_<RepositoryName>_dat.dat in C:\Program Files\PostgreSQL
\<supported PostgreSQL version number>\data\.

Note: During the deployment, you can create a folder called


db_<RepositoryName>_dat.dat in /var/lib/pgsql/<supported
PostgreSQL version number>/data/ and then select the Use Particular
tablespace option. Also, you can proceed with the deployment without
creating a folder in /var/lib/pgsql/<supported PostgreSQL version
number>/data/ and then select the Use default Tablespace option.

• For asynchronous write and precaching operations in a Docker environment,


perform the following:

– Create the DMS configuration having message_post_url,


message_consume_url with the internal IP (for example, http://
172.17.0.1:8489/).
– Change the following in dms.properties:

○ Provide the external IP for dms.webservice.update.url (for example,


dms.webservice.update.url = http://10.31.86.166:8489).
○ Provide the internal IP for dms.jmx.host (for example, dms.jmx.host =
172.17.0.1).

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 11


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

1.4.3 Creating the Documentum Server Red Hat Enterprise


Linux/Oracle Docker image
1.4.3.1 Prerequisites
You must have working knowledge of Docker, Red Hat Enterprise Linux and
Oracle. In addition, you must have administrative privileges on the machine where
you are deploying Documentum Server and also have database administrator
account for the Oracle server. You need two machines with the following
configuration.

1.4.3.1.1 Hardware requirements (Machine 1 – Container for Documentum Server)

Item Requirement
Operating system Red Hat Enterprise Linux 6.7 or 7.0 (64-bit)
Free disk space 80 GB
RAM 8 GB
Swap space 8 GB
Free space in temporary directory 2 GB

1.4.3.1.2 Hardware requirements (Machine 2 – Container for Oracle server)

Item Requirement
Operating system Red Hat Enterprise Linux 7.0 (64-bit) or
higher
Database Oracle server 12c

Note: Oracle server can be on any supported operating system. However, for
illustrative purposes, all information in this document are provided
considering Oracle server is installed on a Linux platform. Oracle
Documentation contains more details on hardware and software requirements
on this machine.

1.4.3.1.3 Software requirements

The Release Notes document contains the software requirements information for your
product.

12 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.4. Deploying and configuring Documentum Server on Docker environment

1.4.3.2 Configuring the Red Hat Enterprise Linux base image


1. Download or pull the Docker image. For example:

$docker pull rhel7

2. Create a container to install minimum RPMs and Oracle client. For example:

$docker run -ti --name rhel7ora rhel7 /bin/bash

3. Copy all the packages or RPMs to the Docker container to install all the required
RPMs. First, copy the packages from CD/ISO to your host Docker Machine.
After that, copy the packages folder from the Docker Machine to the Docker
container. For example:

$docker cp Packages rhel7ora:/

4. Log in to the Docker container and install the createrepo package. For
example:

$ cd /Packages && rpm -ivh libxml2-python*


deltarpm* python-deltarpm* createrepo*

5. Build the local repository in the Docker container. For example:

$ createrepo -v /Packages

6. Create the repository file in the Docker container. For example:

$ vi /etc/yum.repos.d/rhel7.repo

Add the following lines in the repository file:

[rhel7]
name=RHEL 7
baseurl=file:///Packages
gpgcheck=0
enabled=1

7. Install gnome-packagekit and xeyes RPMs to support GUI installation of


Documentum Server in the container. For example:

$ yum install gnome-packagekit*


$ yum install xeyes*

8. Install rng-tools to support random number generation on Linux. For


example:

$ yum install rng-tools

9. Install all the required RPMs. For example, run the following commands in the
given sequence:

$ yum install ksh


$ yum install binutils*
$ yum install elfutils-libelf-0.*
$ yum install glibc-2.*

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 13


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

$ yum install glibc-common-2.*


$ yum install libaio-0.*
$ yum install libgcc-4.*
$ yum install libstdc++-4.*
$ yum install make-3.*
$ yum install compat-libcap1*
$ yum install gcc-4.*
$ yum install gcc-c++-4.*
$ yum install libaio-devel-0.*
$ yum install libstdc++-devel-4.*
$ yum install unixODBC-2.*
$ yum install unixODBC-devel-2.*
$ yum install libXtst
$ yum install sysstat*
$ yum install csh*
$ yum install hostname wget iputils
$ yum install -y expect && \
$ yum install -y tcl && \
$ yum install -y unzip && \

Note: Ensure that you also install all the dependent RPMs.

10. To ensure that dmdbtest does not fail during the loading of the shared libraries
of libsasl2.so.2, while configuring the repository, perform the following steps in
RHEL Docker container:

root:~ # cd /usr/lib64
root :/usr/lib64# ln -s libsasl2.so.3 libsasl2.so.2

11. After installing all the required RPM Package Managers (RPMs), remove the /
Packages folder in the container.

1.4.3.2.1 Installing Oracle client

Install the Oracle client on the Docker container to connect the Oracle database
which is outside of the container (in a different machine).

1. Create Oracle user and groups for Oracle client.

a. Log in to the Docker container with root account and create groups. For
example:

$groupadd oinstall
$groupadd dba
b. Create an Oracle user with the initial login group of oinstall, secondary
to dba. For example:

$useradd -g oinstall -G dba -s /bin/bash -d /home/oracle -m


oracle
c. Set the password for the Oracle user. For example:

$passwd oracle

14 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.4. Deploying and configuring Documentum Server on Docker environment

2. Create directories for Oracle client in the Docker container. For example:

$mkdir -p /u01/app/oracle

3. Change the ownership and permissions for the directories. For example:

$chown -R oracle:oinstall /u01/app/oracle


$chmod -R 775 /u01

4. Copy the Oracle client installer from Docker to the Docker container. For
example:

$docker cp ora_client rhel7ora:/u01/app

5. Log in to the Docker container with root account and change the permissions
for the ora_client folder. For example:

$chmod -R 777 /u01/app/ora_client

6. Set the DISPLAY environment variable to install the Oracle client in GUI mode.
For example:

$export DISPLAY=10.30.87.106:0.0

7. Navigate to the /u01/app/ora_client/ folder and run the Oracle client


installer. For example:

$./runInstaller

8. After the installation, set the Oracle and path environment variables. For
example:

$export ORACLE_HOME=/u01/app/oracle/product/12.1.0/client_1
$export PATH=$ORACLE_HOME/bin:$PATH
$export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH

Run netca to configure the Local Net Service Name. Also, provide the Oracle
service name and database hostname details. Use 10.31.71.131 as Oracle
hostname in the $TNS_ADMIN/tnsnames.ora. The value (10.31.71.131) is
automatically replaced by Documentum Docker scripts with the original Oracle
hostname in the configuration file.

9. After configuring the Oracle client, remove the client installer /u01/app/
ora_client and save the changes to the image. For example:

$docker commit -m "Base configuration of RHEL with Oracle client"


rhel7ora documentumserver/rhelora/stateless/cs:base

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 15


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

1.4.3.3 Configuring to create the Documentum Server Red Hat Enterprise


Linux/Oracle Docker image
1. Download the Documentum Server Docker related binaries from the FTP server
and place them in a temporary local file system.
Example for FTP server details:
wget -nd -r --ftp-user=<user name> --ftp-password=<password>
ftp://<IP address of the FTP server>/Builds/Documentum_Server/
${PRODUCT_MAJOR_VERSION}/${BUILD_NUMBER}
/Server/linux_ora/*

Note: Contact OpenText Global Technical Services to obtain the FTP


server details.
2. Download the Documentum Docker scripts including the Dockerfile-
RhelOra_Statelesscs Docker file.

3. Modify the Dockerfile-RhelOra_Statelesscs template file with proper


entries.
4. Run the following command to create the Documentum Server Red Hat
Enterprise Linux/Oracle Docker base image. For example:
$docker build --build-arg PRODUCT_MAJAR_VERSION=
<Documentum Server release version number>
--build-arg BUILD_NUMBER=<Build number>
--build-arg INSTALL_OWNER_USER=dmadmin
-f Dockerfile-RhelOraCS_Statelesscs
-t documentumserver/rhelora/stateless/cs:<base image name>

1.4.4 Exporting environment variables for storing passwords


to Docker environment
Passwords are provided as environment variables. Ensure that you provide valid
password set on the environment variables before creating or restarting the
containers. Otherwise, the deployment may fail.

Export the following environment variables on the shell manually before running
the following Docker Compose command while creating or recreating the container:
docker-compose -f <compose file name> up -d

export APP_SERVER_PASSWORD=<web application server administrator


password>
export INSTALL_OWNER_PASSWORD=<installation owner password>
export ROOT_PASSWORD=<root user password>
export DOCBASE_PASSWORD=<repository password> (only for stateless
configuration)
export DATABASE_PASSWORD=<external database server administrator
password>
export GLOBAL_REGISTRY_PASSWORD=<global registry password>
export AEK_PASSPHRASE=<aek passphrase>

16 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.4. Deploying and configuring Documentum Server on Docker environment

Note: Repository passwords must not contain special characters other than the
following characters:. (period),_ (underscore),- (hyphen)

1.4.5 Deploying and configuring Documentum Server on


Stateless images
1. Perform the following steps on the Docker base machine containing either
CentOS or Ubuntu operating system:

a. Docker requires a 64-bit installation regardless of your Linux version and


you should have the supported version of kernel. For example:

$uname -r
b. Install the Docker engine.
c. Start the Docker daemon service.

2. Download and copy the Documentum Server Docker image zip file to the
Docker base machine. The Docker image contains the PostgreSQL client,
Documentum Server, two connection brokers, and a repository in a single
container.

3. Extract the zip file. Load the Documentum Server Docker image into the Docker
base machine. For example:

$ docker load -i <name of TAR file>

4. Verify that the Documentum Server Docker image is loaded and listed in the
Docker base machine. For example:

$ docker images

5. Provide all the required details in the CS-Docker-Compose_Stateless.yml


compose file. Read the Readme.txt file in the directory of the compose file for
description of fields and provide valid values for each parameter.

6. Export the environment variables as described in “Exporting environment


variables for storing passwords to Docker environment” on page 16.

7. Log in as a PostgreSQL user and start the PostgreSQL server.


Use the following command for Red Hat Enterprise Linux:

bash:#/usr/pgsql-<supported PostgreSQL version number>


/bin/pg_ctl -D /var/lib/pgsql/<supported PostgreSQL version
number>
/data/ start

Use the following command for CentOS:

/usr/pgsql-<supported PostgreSQL version number>


/bin/pg_ctl -D /var/lib/pgsql/<supported PostgreSQL version
number>
/data/ start

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 17


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

Use the following command for Ubuntu:

/usr/lib/postgresql/<supported PostgreSQL version number>


/bin/pg_ctl -D /var/lib/postgresql/<supported PostgreSQL version
number>
/data/ start

8. Create the Documentum Server Docker container. For example:

docker-compose -f <compose file name> up -d

9. To support random number generator and to avoid issues while renaming the
log files, run the following command with the root account in the container:

root:#rngd -b -r /dev/urandom -o /dev/random

10. To verify the deployment, check the logs at /opt/dctm_docker/logs/


hostname.log inside the container.

1.4.6 Deploying and configuring of Documentum Server HA


on Docker environment
1. Install the supported version of Docker, Docker Compose file, and netshare
plugin in your host machine.

2. Start the Docker process from the service.

3. Start the Docker netshare plugin if data or share are in external file system. For
example:

./docker-volume-netshare --basedir=/var/lib/docker/volumes --
verbose=true nfs

4. Share the $DOCUMENTUM/data and $DOCUMENTUM/share if the existing


Documentum Server does not use the remote file system for data.

5. Provide all the required details in the CS-Docker-Compose_Ha.yml compose


file. Read the Readme.txt file in the directory of the compose file for description
of fields and provide valid values for each parameter.

6. Export the environment variables as described in “Exporting environment


variables for storing passwords to Docker environment” on page 16.

7. Create the Documentum Server HA Docker container. For example:

Docker-compose -f <HA compose file name> up -d

8. To verify the deployment, check the logs at /opt/dctm_Docker/logs/


hostname.log inside the container.

18 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.5. Deploying and configuring Independent Java Method Server on Docker environment

1.5 Deploying and configuring Independent Java


Method Server on Docker environment
1.5.1 Prerequisites
1. Ensure that the Centos Docker mount on the xfs file system is ftype=1.

2. Install the Docker Engine and Docker Compose file on your host machine.
Docker Documentation contains more information.

3. Download the packaged TAR file to your host machine.

4. Extract the packaged TAR file using the following command format:

tar -xvf IJMS_<version>.tar

This extracts the Docker Compose (Docker-compose.yml) and Independent


Java Method Server (IJMS) Docker image files.

5. Load the Docker image using the following command format:

Docker load -i IJMS_<version>.tar

6. Run the Docker images command to verify if the Docker image is loaded
successfully and listed.

1.5.2 Deploying IJMS on Docker environment


You can run the Docker-compose -f Docker-compose.yml up & command to start
the container. Before running the Docker-compose command, you must provide the
details (IP address of the connection broker and other mandatory details) in Docker-
compose.yml. Check the Example 1-1, “docker-compose.yml to create container and
volumes” on page 20 example.

1. Navigate to the location of the extracted Docker-compose.yml file. For


example, /root/ijms.

2. Run the vi Docker-compose.yml command to open the Docker-compose.yml


file in the edit mode and review all the entries are correct as mentioned in the
Example 1-2, “statelessda_compose.yml to create container and volumes”
on page 23 example.

3. Run the Docker-compose -f Docker-compose.yml up command to start the


container and create volumes.

Note: You must provide the correct location of the Docker-compose.yml


file in the Docker-compose -f <location of the Docker-compose.yml
file> up command. For example, the location specified in the command
in Step 3 assumes that the Docker-compose.yml file is available in the
current working directory.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 19


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

4. Run the Docker volume ls command to list the Docker volumes.

5. Run the Docker ps command to view all the active Docker containers.

6. To verify the deployment, access the URL of IJMS container. For example,
http://<Docker_host>:<JMS_PORT>/DmMethods/servlet/DoMethod.

7. Verify the logs inside the container at /opt/dctm_Docker/logs/


<hostname>.log for the deployment details.

8. Restart the repositories.

Example 1-1: docker-compose.yml to create container and volumes


version: '2'
services:
ijms:
image: <ijms_image_name>:<tag>
environment:
- GLOBAL_REGISTRY_DOCBASE=<Global repository name as in
dfc.globalregistry.repository>
- GLOBAL_REGISTRY_USER==<Global repository user name as in
dfc.globalregistry.username>
- GLOBAL_REGISTRY_PASSWORD==<Global repository password as in
dfc.globalregistry.password>
- DOCBROKER_HOST=<IP address of the Documentum Server
connection broker>
- DOCBROKER_PORT=<Port number of the connection broker>
- INSTALL_OWNER_USER=<Repository installation owner username
to which this IJMS is configured>
- INSTALL_OWNER_PASSWORD=<Repository installation owner
password to which this IJMS is configured>
- APP_SERVER_PASSWORD=<JBoss application server password>
- DOCKER_HOST= <IP address of the base machine or IP address
of Docker host>
- DOCBASE_NAME=<Name of the repository to which this IJMS is
configured>
- PRIMARY_LOG_LOCATION=<Repository result of file_system_path
from dm_location where object_name="log" query>
- JMS_PORT=<Port number on which this IJMS instance JBoss
runs on>
hostname:
"<Unique host name
(for example, ijms<JMS_PORT> ex ijms9180")>
container_name:
"<Unique container name
for example, ijmscontainer<JMS_PORT> ex ijmscontainer9180)>"
ports: (refer the Port details section)
- "<JMS_PORT>:9180"
- “<APP_SERVER_MGMNT_PORT>=9184”
- “<APP_SERVER_MGMNT_CONSOLE_PORT>=9185”
volumes: (refer the Volume details section)
-<container_name>_log:/opt/dctm_Docker/jms/
wildfly9.0.1/server/DctmServer_MethodServerHA1/log
-<container_name>_mdserver_conf:/opt/dctm_Docker/mdserver_conf

20 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.6. Deploying and configuring Documentum Foundation Classes on Docker environment

volumes:
<container_name>_log:
<container_name>_mdserver_conf:

1.5.2.1 Port details


The IJMS instance is accessed or available through the JMS_PORT and you must
provide an unique port number for each deployment. For example, if a repository
(for example, docbase1) is already configured with IJMS (for example, IJMS1) on
default port 9180, then the next IJMS configuration (for example, IJMS2) must not
use the same port. You must change the JMS_PORT value to any other available port
other than the default port 9180.

If you have given an unique port number for JMS_PORT as 9280 in the Example 1-2,
“statelessda_compose.yml to create container and volumes” on page 23 example,
then it is resolved as 9280:9180 meaning that the container is running with port
number 9180 is externally exposed as 9280. You can use Docker-compose.yml as a
template to expose the port, as needed.

For example, xCP requires APP_SERVER_MGMNT_PORT and so it is exposed as


“<APP_SERVER_MGMNT_PORT>=9184” in the Example 1-2, “statelessda_compose.yml
to create container and volumes” on page 23 example.

Docker Documentation contains more information.

1.5.2.2 Volume details


Mount host paths or named volumes are specified as sub-options to a service. In the
Example 1-2, “statelessda_compose.yml to create container and volumes”
on page 23 example, the <container_name>_log volume is available at /opt/
dctm_Docker/jms/wildfly9.0.1/server/DctmServer_MethodServerHA1/log.
Similarly, <container_name>_mdserver_conf is available at /opt/dctm_Docker/
mdserver_conf.

1.6 Deploying and configuring Documentum


Foundation Classes on Docker environment
1. Install the supported version of Docker and Docker Compose file in your host
machine.

2. Set up the external database server and remote file system.

3. Provide all the required details in the dfc_conf.conf file. Read the description
of every field and provide valid values for each parameter.

4. Run the dfc.sh script.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 21


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

5. To verify the deployment, ensure that the dfc.properties file at


$DOCUMENTUM/config is updated with the correct repository details.

1.7 Deploying and configuring Documentum


Administrator on Docker environment
1.7.1 Prerequisites
1. Install the Docker Engine and Docker Compose file on your host machine.
Docker Documentation contains more information.
2. Download the packaged TAR file to your host machine.
3. Run the tar -xvf <packaged TAR file> command to extract the packaged
TAR file. For example:

tar -xvf Documentum_Administrator_<version>.tar

This extracts the Docker Compose (statelessda_compose.yml) and


Documentum Administrator Docker image files.
4. Run the Docker load -i <extracted Docker image TAR file> command to
load the Docker image. For example:

Docker load -i Documentum_Administrator_<version>.tar

Note: Ensure that the docker daemon is running. If it is not running, run
the dockerd command.
5. Run the docker images command to verify if the Docker image is loaded
successfully and listed.

1.7.2 Deploying Documentum Administrator on Docker


environment
You can run the docker-compose -f ./statelessda_compose.yml up command
to start the container. Before running the docker-compose command, you must
provide the details (IP address of the connection broker and other mandatory
details) in statelessda_compose.yml. Check the Example 1-2,
“statelessda_compose.yml to create container and volumes” on page 23 example.

1. Navigate to the location of the extracted statelessda_compose.yml file. For


example, /home/da.
2. Run the vi statelessda_compose.yml command to open the
statelessda_compose.yml file in the edit mode.
In the following example, the dalogs volume is available in /opt/tomcat/
logs. Similarly, dacustom volume is available in /opt/tomcat/webapps/da/
custom. The docker images command lists the repository and tag along with
other details. For example, image is da_centos:<version>.

22 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.7. Deploying and configuring Documentum Administrator on Docker environment

Example 1-2: statelessda_compose.yml to create container and


volumes
version: '2'
services:
da:
image: <repository>:<tag>
environment:
- DA_EXT_CONF=/opt/tomcat/webapps/da/external-
configurations
- PREFERPASS=<Preset_Password>
- PRESETPASS=<Preference_Password>
- OTDS_PROPERTIES=otds_url=<OTDS_APP_URL>::
client_id=<OTDS_CLIENT_ID>::
client_secret=<OTDS_CLIENT_SECRET>::
redirect_uri=<DA_APP_URI>
-
APP_PROPERTIES=application.authentication.otds_sso.enabled=
false::
application.authentication.otds_sso.repo_selection_page_req
uired=false::
application.authentication.otds_sso.dm_login_ticket_timeout
=250
- DFC_PROPERTIES=dfc.data.dir=<DFC_DATA_DIRECTORY>::
dfc.tokenstorage.dir=<DFC_TOKENSTORAGE_DIRECTORY>::
dfc.tokenstorage.enable=false::
dfc.docbroker.host[0]=<DFC_DOCBROKER_HOST>::
dfc.docbroker.port[0]=<DFC_DOCBROKER_PORT>::
dfc.globalregistry.repository=<DFC_GLOBALREGISTRY_REPOSITOR
Y>::
dfc.globalregistry.username=<DFC_GLOBALREGISTRY_USERNAME>::
dfc.globalregistry.password=<DFC_GLOBALREGISTRY_PASSWORD>
container_name:
"dastatelesscontainer"
ports:
- "APPSERVER_PORT:8080"
volumes:
- ext-conf:/opt/tomcat/webapps/da/external-configurations
- dalogs:/opt/tomcat/logs
- dacustom:/opt/tomcat/webapps/da/custom
privileged: true
volumes:
ext-conf:
dalogs:
dacustom:

3. Run the docker-compose -f ./statelessda_compose.yml up command to


start the container and create volumes.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 23


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

Note: You must provide the correct location of the


statelessda_compose.yml file in the docker-compose -f <location of
the statelessda_compose.yml file> up command. For example, the
location specified in the command in Step 3 assumes that the
statelessda_compose.yml file is available in the current working
directory.

4. Run the docker volume ls command to list Docker volumes.


Example output:

[root@centos71 ~]# docker volume ls


DRIVER VOLUME NAME
local dalogs
local dacustom

5. Run the docker ps command to view all the active Docker containers.

6. To verify the deployment, access the URL of Documentum Administrator


container. For example, http://<HostIP>:8080/da.

1.8 Deploying and configuring BOCS on Docker


environment
1. Install the supported version of Docker and Docker Compose file in your host
machine.

2. Provide all the required details in the bocs_compose.yml file. Read the
description of every field and provide valid values for each parameter.

3. Run the Docker Compose command. For example:

docker-compose -f bocs_compose.yml up -d

4. To verify the installation, check http://<dockerbaseip>:8086/bocs/


servlet/ACS. Also, check the web application server log files. For example, the
logs at /opt/tomcat/logs/<container_name>.log or the WildFly application
server log files or the Docker log files.

Note: Ignore the Protocol family unavailable error in the install.log file
located at /opt/bocs-docker/logs.

24 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.9. Deploying and configuring Documentum Foundation Services on Docker environment

1.9 Deploying and configuring Documentum


Foundation Services on Docker environment
1. Install the supported version of Docker and Docker Compose file in your host
machine.

2. Set up the external database server and remote file system.

3. Provide all the required details in the dfs_conf.conf file. Read the description
of every field and provide valid values for each parameter.

4. Run the dfs.sh script.

5. To verify the deployment, check http://<dockerbaseip>:8080/services/


core/SchemaService. Also, check the web application server logs. For
example, the logs at /opt/tomcat/logs.

1.10 Deploying and configuring Content Intelligence


Services on Docker environment
1.10.1 Prerequisites
1. Install the Docker engine.
For example, take CentOS users. Run the following command to install the
Docker engine:

$ yum install docker-engine

Note: The system must have 64-bit architecture and have the supported
version of kernel.
Start the Docker engine service if it is not running.

$ service docker start

Docker Documentation contains more information.

2. Pull the Docker image.

$ docker pull ubuntu

3. Run the container and modify the ports as per your requirement.

$ docker run -it -h HOSTNAME -p 8061:8061 -p 8079:8079 -name


cis ubuntu

Docker Documentation contains more information.

4. Install the dependency packages.

a. Inside the container, run the following command:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 25


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

docker$ apt-get update && apt-get install -y libc6-i386


lib32gcc1 lib32stdc++6

This command installs three dependencies for Luxid on the container.


b. To support UTF-8, run the following command inside the Docker container:
docker$ export LANG=en_US.UTF-8
docker$ locale-gen en_US.UTF-8
c. Install the VIM tools using the following command:
docker$ apt-get install -y vim

5. Copy installer packages.


Use the following command to copy the CIS binaries into a directory (for
example, /home) in a Docker container:
$ docker cp <path to build CIS> <container name>:/home

1.10.2 Common notes


• It is recommended to externalize the configuration files from the CIS container to
the host machine, to ensure the configuration files are persisted.
Following is a sample command that enables you to run the Docker container
and mount volumes that contain necessary files:
$ docker run -it -h cis -p 8061:8061 -p 8079:8079 \
-v /home/cisStorage/config:/root/dctm/CIS/config \
-v /home/cisStorage/logs:/root/dctm/CIS/logs \
-v /home/cisStorage/docexclusion:/root/dctm/CIS/repodata/
docexclusion \
--name cis ubuntu

This command mounts three directories on the host machine to the new created
Docker container.

– /root/dctm/CIS/config contains the required configuration files


– /root/dctm/CIS/logs contains the logs
– /root/dctm/CIS/repodata/docexclusion contains the excluded documents
• The CIS server information on Documentum Administrator may not be updated
while redeploying CIS on a specific repository. On Documentum Administrator,
navigate to the Administration > System Information page, click Configure. The CIS
server information is displayed on a page as Production Server and Test Server.
Make sure the hostname or the IP addresses are correct.
If the hostname of the container is set in the fields, add an entry in the hosts file
(for example,./etc/hosts) on the system where Documentum Administrator is
deployed.
For example:
<IP-address-of-host-of-docker-engine> <hostname-of-the-CIS-
container>

26 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.10. Deploying and configuring Content Intelligence Services on Docker environment

Otherwise, the IP addresses of the Docker-engine host should be set in the fields.
• Verify the deployment. “Verifying the deployment” on page 29 section
describes the steps to verify the deployment.

1.10.3 Deploying Content Intelligence Services on Docker


environment
1. Start the silent installation.
Assume the CIS binaries are in /home/cisInstaller/. Change the permissions for the
cisSetup.bin:

docker$ chmod 755 /home/cisInstaller/cisSetup.bin

Access the directory that contains the CIS binaries, and execute the cisSetup.bin
with silent.ini:

docker$ cd /home/cisInstaller
docker$ ./cisSetup.bin -f silent.ini
2. Start and stop the services.
The services automatically starts after the installation is completed.
To stop the CIS service manually, execute the following script file:

docker$ cd $DOCUMENTUM/CIS/service
docker$ ./stopCIS

To start CIS services manually, run the following script file in the same
directory:

docker$ ./startCIS

1.10.4 Configuring Content Intelligent Services on Docker


environment
1. Set the environment variable for DOCUMENTUM inside the container:

docker$ export DOCUMENTUM=/root/dctm

2. Modify the random number generator.

docker$ ln -sf urandom /dev/random

3. Create the silent install configuration file.


CIS is installed in the Docker container in the silent installation mode.
Use the silent.ini file with the following details of all fields to perform the
silent installation:

• INSTALLER_UI: Set it to silent.


• CIS.SKIP_DEPLOYING_DAR: Set to true if it needs to skip creating objects
on Documentum Server. Otherwise, set it to false.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 27


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

• CIS_SECTION.CIS_REPOSITORY_NAME: The name of the repository that


CIS uses.
• CIS_SECTION.CIS_REPOSITORY_USER: Specify the username for the
repository.
• CIS_SECTION.SECURE.CIS_REPOSITORY_PASSWORD: Specify the
password for the repository.
• CIS_SECTION.CIS_REPOSITORY_DOMAIN: Specify the user domain for
the repository. You can keep this field as empty if no domain is available.
• CIS_SECTION.CIS_HOST: The hostname of this Docker container, or theIP
addressof the Docker-engine host.
• CIS_SECTION.CIS_PORT: Set it to 8079.
• CIS_SECTION.CIS_JMX_AGENT_PORT: Set it to 8061.
• CIS_SECTION.LUXID_PORT: Set it to 55550.
• DFC.DOCBROKER_HOST: Specify the hostname or IP address for the broker
host.
• DFC.DOCBROKER_PORT: Specify the port for the broker.
• DFC.DFC_BOF_GLOBAL_REGISTRY_REPOSITORY: The name of the
repository to be used as the global registry.
• DFC.DFC_BOF_GLOBAL_REGISTRY_USERNAME: The username for the
global registry repository.
• DFC.SECURE.DFC_BOF_GLOBAL_REGISTRY_PASSWORD: The password
for the global registry repository.
• USE_CERTIFICATES: Set to false if you do not want to use the user
certificates. Otherwise, set it to true.
• DFC_SSL_TRUSTSTORE: Specify a path to the trust store if
USE_CERTIFICATES is set to true.
• DFC_SSL_TRUSTSTORE_PASSWORD: Specify the password for the trust
store if USE_CERTIFICATES is set to true.
• DFC_SSL_USE_EXISTING_TRUSTSTORE: Set to true to use Java Key Store
instead of user-defined trust store. Otherwise, set it to false. The default
value is false.

28 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.10. Deploying and configuring Content Intelligence Services on Docker environment

1.10.4.1 Sample silent.ini for deploying CIS


Assume that the container hostname is cis. In this scenario, a complete silent.ini file
must contain the following fields:

INSTALLER_UI=silent
CIS.SKIP_DEPLOYING_DAR=false
CIS_SECTION.CIS_REPOSITORY_NAME=sampleRepository
CIS_SECTION.CIS_REPOSITORY_USER=Administrator
CIS_SECTION.SECURE.CIS_REPOSITORY_PASSWORD=password
CIS_SECTION.CIS_REPOSITORY_DOMAIN=
CIS_SECTION.CIS_HOST=cis
CIS_SECTION.CIS_PORT=8079
CIS_SECTION.CIS_JMX_AGENT_PORT=8061
CIS_SECTION.LUXID_PORT=55550
DFC.DOCBROKER_HOST=192.168.10.20
DFC.DOCBROKER_PORT=1489
DFC.DFC_BOF_GLOBAL_REGISTRY_REPOSITORY=sampleRepository
DFC.DFC_BOF_GLOBAL_REGISTRY_USERNAME=dm_bof_registry
DFC.SECURE.DFC_BOF_GLOBAL_REGISTRY_PASSWORD=password
USE_CERTIFICATES=false
DFC_SSL_TRUSTSTORE=
DFC_SSL_TRUSTSTORE_PASSWORD=
DFC_SSL_USE_EXISTING_TRUSTSTORE=false

1.10.5 Verifying the deployment


1.10.5.1 Verifying the deployment of CIS artifacts (DAR file)
After you deploy the CIS DAR file (cis_artifacts.dar), check that the modules are
created in Documentum Administrator.

1. Log in to Documentum Administrator.

2. Navigate to Cabinets > System > Modules > Aspect and check that the module
cis_annotation_aspect is present.

3. Verify that the tables dm_annotation and dm_object_annotations have been


created, as described in “Verifying that the tables are created” on page 30.

1.10.5.2 Verifying that the repository is enabled for CIS


When you enable a repository for CIS, a number of sections and folders are created.
You can check their existence to make sure that the repository is enabled
successfully.

To check the existence of CIS sections and folders in the repository:

1. Log in to Documentum Administrator.

2. Navigate to the Content Intelligence node and verify that the following sections
are present:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 29


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

• Taxonomies
• Category Class
• Document Set
• My Categories

3. Navigate to Cabinets > System > Applications > CI and verify that the
following folders are present:

• AttributeProcessing
• Classes
• Configuration
• DocsetConfiguration
• DocumentSets
• MetadataExtrationRules
• Runs
• TaxonomySnapshots
• XMLTaxonomies

1.10.5.3 Verifying that the tables are created


The following tables are created in the repository for CIS:

• When you enable the repository, it creates the table dm_docstatus.


• When you deploy the CIS DAR file (cis_artifacts.dar), it creates the tables
dm_annotation and dm_object_annotations.

To check the existence of the tables:

1. Log in to Documentum Administrator.

2. Select Tools > DQL Editor.

3. Run the query to check the existence of the dm_docstatus table:

Select * from dm_docstatus

The result structure must be:

st_object_id st_docset_id st_mode st_last_modified st_date

4. Run the query to check the existence of the dm_annotation table:

Select * from dm_annotation

The result structure must be:

ann_id ann_type ann_value

30 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.10. Deploying and configuring Content Intelligence Services on Docker environment

5. Run the query to check the existence of the dm_object_annotations table:

Select * from dm_object_annotations

The result structure must be:

ann_object_id ann_index ann_chronicle_id ann_confidence ann_id

1.10.5.4 Verifying the configuration of the entity detection server


CIS server needs to communicate with the entity detection server to start the
detection process, and retrieve the entities.

1. On CIS host, open the configuration file <CIS installation directory>/config/


cis.properties.

2. Check that the property cis.entity.luxid.annotation_server.host indicates the IP


address of the entity detection server.

1.10.5.5 Verifying that all services are started


You can verify that all services for the entity detection server have started.

On Windows hosts, the CIS services are installed in the automatic startup mode. You
can make sure that all services are started correctly, and, if not, start them manually
or reboot to start them automatically.

1. Select My Computer > Manage > Services and Applications > Services.

2. Make sure the service Documentum Content Intelligence Services is started. If


not, start it.

3. For the entity detection analysis, make sure that the following services are
started:

• Documentum CIS Luxid Admin Server

• Documentum CIS Luxid Xelda MI Server

• Documentum CIS Luxid IDE Server

• Documentum CIS Luxid Annotation Server

• Documentum CIS Luxid Annotation Node


• Documentum CIS Luxid Tomcat Server

• Documentum CIS Luxid Starter (optional)

If you want to start them manually, start the Documentum CIS Luxid Starter
service first. This service starts the other services in the correct order.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 31


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

1.11 Deploying and configuring Federated Search


Services on Docker environment
1.11.1 Prerequisites
• Install the Docker engine.
Docker Documentation contains more information.
• Pull the Docker image.

$ docker pull ubuntu


• Run the container and modify the ports as per your requirement.

$ docker run -it -h HOSTNAME -p 3000-3005:3000-3005 --name fs2


ubuntu

Docker Documentation contains more information.


• Copy the deployment packages.
Use the following command to copy the FS2 binaries into a directory (e.g. /home)
in a Docker container:

$ docker cp <path-to-build-FS2> <container-name>:/home

1.11.2 Common notes


1. It is important that any other program that needs to connect to FS2 must be set
up inside the same Docker network with FS2. For example, if Documentum
Administrator needs to connect with FS2, it must be set up as a Docker image
and start in a same Docker network with FS2.
Assume the internal IP address of Documentum Administrator is 172.17.0.2, the
internal IP address of FS2 is 172.17.0.3, and users need to configure the
dfc.properties file in Documentum Administrator with this internal IP address as
follows:

dfc.search.external_sources.enable=true
dfc.search.external_sources.host=172.17.0.3
dfc.search.external_sources.port=3005
2. The configuration files of FS2 can be externalized outside the container on the
host machine.
To do this, use “-v” option at run time.
For example:

$ docker run -it -h HOSTNAME -p 3000-3005:3000-3005 \


-v /home/fs2Storage/admin:/root/dctm/fs2/admin \
-v /home/fs2Storage/www:/root/dctm/fs2/www \
-v /home/fs2Storage/docs:/root/dctm/fs2/docs \
-v /home/fs2Storage/jars:/root/dctm/fs2/lib/jars \

32 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.11. Deploying and configuring Federated Search Services on Docker environment

-v /home/fs2Storage/wrapper:/root/dctm/fs2/lib/wrapper \
--name fs2 ubuntu

In the example, the five directories containing the configuration files are stored
in the /home/fs2Storage/ folder.

1.11.3 Deploying Federated Search Services on Docker


container
1. Start the silent installation.
Assume that the FS2 binaries are in the /home/fs2Installer folder. Change the
permissions for the setup file as follows:

docker$ chmod 755 /home/fs2Installer/fs2Setup.bin

Access the directory that contains the FS2 binaries, and execute fs2Setup.bin with
silent.ini:

docker$ cd /home/fs2Installer
docker$ ./fs2Setup.bin -f silent.ini

2. Start and stop the services.


To start FS2 services, execute the following script files:

docker$ cd $DOCUMENTUM/fs2/bin
docker$ ./aOServer -nogui
docker$ ./aOAdmin

To stop FS2 services, run the scripts with following options:

docker$ ./aOAdmin -stop


docker$ ./aOServer -stop

1.11.4 Configuring Federated Search Services on Docker


container
1. Set the environment variable for DOCUMENTUM inside the container:

docker$ export DOCUMENTUM=/root/dctm

2. Set the system locale to support UTF-8:

docker$ export LANG=en_US.UTF-8


docker$ locale-gen en_US.UTF-8

3. Modify the random number generator.

docker$ ln -sf urandom /dev/random

4. Create the silent install configuration file.


It is recommended to install FS2 in the silent mode.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 33


EDCSYCD160700-IGD-EN-02
Chapter 1 Deploying Documentum Platform and Platform Extensions applications on
Docker environment

1.12 Deploying and configuring REST Services on


Docker environment
1. Install the supported version of Docker on your host machine.

2. Prepare your configuration files (dfc.properties and rest-api-runtime.


properties) and put them, as needed, in one or both of the following file
locations:

• The dfc.properties File


<Current_Directory>/rest/config/dfc.properties

• The rest-api-runtime.properties File


<Current_Directory>/rest/config/rest-api-runtime.properties

3. Run the following command in the current directory:

docker run --name rest -p 8080:8080 -d -v


`pwd`/config:/root/rest/config -v `pwd`/logs:/root/rest/logs
<Rest_Image_Name>

4. To verify the deployment, access the URL of REST services container. For
example, http://localhost:8080/dctm-rest/services.

1.13 Deploying and configuring Thumbnail Server on


Docker environment
1. Install the supported version of Docker and Docker Compose file in your host
machine.

2. Set up the external database server and remote file system.

3. Installation and configuration of Thumbnail Server is bundled with


Documentum Server image. So, Thumbnail Server configuration settings needs
to be done along with Documentum Server configuration. By default,
Thumbnail Server configuration is set to NO with default port numbers. Change
the value to YES to enable the Thumbnail Server configuration. For example:

CONFIGURE_THUMBNAIL_SERVER = YES
THUMBNAIL_SERVER_PORT = 8081
THUMBNAIL_SERVER_SSL_PORT = 8443

4. To verify the configuration, perform the following:

• Check the Thumbnail Server startup log at $DOCUMENTUM/product/


<product_version_folder>/thumbsrv/container/logs/catalina.out
inside the container.
• Check the Thumbnail Server URL (http://:8081/thumbsrv/
getThumbnail?) availability from any browser.

34 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
1.13. Deploying and configuring Thumbnail Server on Docker environment

By default, Thumbnail Server runs in HTTP mode on port 8081.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 35


EDCSYCD160700-IGD-EN-02
Chapter 2
Deploying Documentum Platform and Platform
Extensions applications on Private Cloud

2.1 Overview
Kubernetes is a portable, extensible open-source platform orchestration engine for
automating deployment, scaling, and management of containerized applications.
Kubernetes can be considered as a container platform, microservices platform, and
portable cloud platform. It provides a container-centric management environment.

You can use the containerized deployment using the Docker images and Helm
Charts that are packaged with the release.

2.2 Supported applications and versions


The Release Notes document contains the information about the list of applications
and its supported versions.

2.3 Deploying and configuring Documentum Server


on private cloud
2.3.1 Prerequisites
Ensure that you complete the following activities before you deploy Documentum
Server on Kubernetes environment:

1. Download and configure the Docker application from the Docker website.
Docker Documentation contains more information.

2. Download and configure the Helm (client) and Tiller (server) application from
the Helm website.
For Tiller and Role-based Access Control:

a. Load the image into the local Docker registry using the following command
format:

docker load -i <image name of Tiller>


b. Create a service account using the following command format:

kubectl create serviceaccount <name of the service account>


--namespace <name of namespace>
c. Apply the roles using the following command format:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 37


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

kubectl apply -f <location of role YAML file>


d. Bind the role with the service account using the following command format:

apply -f <location of role binding YAML file>


e. Initialize the Tiller in your namespace using the following command format:

helm init --service-account <name of the service account> --


tiller-image <path of the Tiller image> --tiller-namespace
<name of namespace>
f. Verify the status of the deployed Tiller pod using the following command
format:

kubectl get pods

Helm Documentation contains more information.

3. Deploy a Docker registry using the following command format:

docker run -d -p 5000:5000 --name <name of the registry>


registry:2

Docker Documentation contains more information.


4. Download and configure the Kubernetes application from the Kubernetes
website.
Kubernetes Documentation contains more information.

5. Download and configure the PostgreSQL database (server) from the


PostgreSQL website.

Note: The PostgreSQL database client is packaged with Documentum


Server Image.

PostgreSQL Documentation contains more information.

6. Download the sample values.yaml file for PostgreSQL from the GitHub
website. Open and provide the appropriate values for all the required variables.

7. Download the Documentum Server Image (CentOS only) and Helm Chart TAR
files from OpenText My Support.

38 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

2.3.2 Deploying Documentum Server on Kubernetes


environment
1. Install the Documentum Server Image (CentOS only) in the same namespace
where the PostgreSQL database is installed.
Load the Documentum Server Image into the Docker registry using the
following command and update the exact Documentum Server Image name:

docker load -i <TAR file name of Documentum Server image>

2. Extract the Helm Charts TAR file to a temporary location.


3. Download the Graylog Docker Image from the Docker Hub website.
Graylog Docker Documentation contains more information.

4. Load the Graylog Docker image using the following command format:

docker load -i <name of downloaded graylog docker image>

Upload the Graylog Docker image to your local repository and configure, as
appropriate.

5. Open the cs-secrets/values.yaml file and provide the appropriate values for
the variables depending on your environment to pass them to your templates as
described in the following table:

Category Name Description


secret name Specifies the name of the
secret configuration file. For
example, cs-secret-
config.
docbase password Specifies the password to
connect to the repository.
The default value is
password.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 39


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


licenses Specifies the license details
for the following optional
modules:
• Records Manager
• Physical Records
Manager
• Federation Records
Services
• Retention Policy
Services
• Content Services for
SnapLock
• XML Store
• Storage aware devices
• Trusted Content
Services
• High-Volume Server
contentserver installOwner • userName: Specifies the
user name of the
installation owner. The
default value is
dmadmin.
Do NOT change this
value.
• password: Specifies the
password of the
installation owner. The
default value is
password.
globalRegistry • password: Specifies the
password of the global
registry. The default
value is password.
aek • algorithm: Specifies
the encryption
algorithm. The default
value is AES_256_CBC.
• passphrase: Specifies
the passphrase to
protect the AEK file. The
default value is
Password@123.

40 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

Category Name Description


lockbox • passphrase: Specifies
the passphrase to
protect the lockbox file.
The default value is
Password@123.
install • appserver/admin/
password: Specifies the
administrator password
of the application
server. The default
value is password.
• root/password:
Specifies the password
of the installation root
directory. The default
value is password.
database userName Specifies the name of the
database. The default value
is postgres.
Do NOT change this value.
password Specifies the password to
access the database. The
default value is password.
certificate Specifies the information of
certificate.
thumbnailServer appServerPassword Specifies the password to
access the Thumbnail
Server. The default value is
password@123.
s3Store s3StoreBaseUrl Specifies the URL that
Documentum Server uses
to communicate with the
Amazon S3 store. The URL
format is http://X.X.X.
X/<BUCKET>.
Documentum Server
Administration and
Configuration Guide contains
more information.
s3StoreCredentialID Specifies the name of the
user accessing the S3 store.
Use the S3 Tenant Owner.
Documentum Server
Administration and
Configuration Guide contains
more information.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 41


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


s3StoreCredentialKEY Specifies the password of
the user accessing the S3
store. Use the Object Access
Key.
Documentum Server
Administration and
Configuration Guide contains
more information.

6. Store the secret values in your Kubernetes environment using the following
command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/cs-secrets --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name cs-secrets /opt/temp/Helm-charts/cs-secrets


--tiller-namespace docu --namespace docu

7. Verify the status of the stored secret values file using the following command
format:

helm status <release name> --tiller-namespace <name of namespace>

8. Open the docbroker/values.yaml file and provide the appropriate values for
the variables depending on your environment to pass them to your templates as
described in the following table:

Category Name Description


User Name serviceName Specifies an unique name
for sname. For example,
dbrforcluster1dbr.
images repository Specifies the path of the
repository. The format is
<IP address>:<port>.
contentserver • name: Specifies the
name of the
Documentum Server
image. For example,
kube/
contentserver/
centos/cs.
• tag: Specifies the tag as
a version-specific
number.
secret name Specifies the same secret
name as provided in Step 5.

42 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

Category Name Description


docbroker replicaCount Specifies the number of
replica pods to be spawned
for Documentum Server
image. The default value is
2. The maximum value is
10.
IMPORTANT: OpenText
recommends 2 replica pods.
port Specifies the available port
reserved for the connection
broker. The default value is
1489.
installerUI Specifies the type of
installation mode. The
default value is silent.
Do NOT change this value.
ExtDocbroker enable Specifies if the external
connection broker is
enabled for use. The default
value is false.
Do NOT change this value.
nativeExtPort Ensure that there is no
value specified for this
variable.
sslExtPort Ensure that there is no
value specified for this
variable.
graylog enable Specifies if the graylog is
enabled for use.
image Specifies the image details
per your Graylog server
configuration.
server Specifies the server details
per your Graylog server
configuration.
port Specifies the port details
per your Graylog server
configuration.
ports docbrokerPort Specifies the available port
reserved for the connection
broker. The default value is
1489.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 43


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


docbrokerSSLport Specifies the available port
reserved for the encrypted
connection broker. The
default value is 1490.
persistentVolume vctName Specifies the name of the
volume claim template. For
example, dbr-vct.
accessModes Specifies the access modes.
The default value is
ReadWriteOnce.
Do NOT change this value.
size Specifies the size of the
volume claim template. The
default value is 1Gi.
storageClass Specifies the storage class
of the volume claim
template. The default value
is bp-pass-nfs.
logVctAccessModes Specifies the access modes
of log of the volume claim
template. The default value
is ReadWriteOnce.
logVctSize Specifies the size of log of
the volume claim template.
The default value is 2Gi.
logVctStorageClass Specifies the storage class
of log of the volume claim
template. The default value
is bp-paas-nfs.
resources limits • cpu: Specifies the
maximum number of
allocated CPUs.
• memory: Specifies the
maximum usage of
allocated memory.
requests • cpu: Specifies the
maximum number of
CPUs for transaction.
• memory: Specifies the
maximum usage of
memory for transaction.

9. Deploy the connection broker Helm in your Kubernetes environment using the
following command format:

44 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name docbroker /opt/temp/Helm-charts/docbroker --


tiller-namespace docu --namespace docu

10. Verify the status of the connection broker Helm deployment using the following
command format:

helm status <release name> --tiller-namespace <name of namespace>

11. Verify the status of the deployment of connection broker pod using the
following command format:

kubectl describe pods <name of the pod>

12. Open the content-server/values.yaml file and provide the appropriate


values for the variables depending on your environment to pass them to your
templates as described in the following table:

Category Name Description


User Name serviceName Specifies an unique name.
For example,
csforcluster1dcs-pg.
Service Account Name serviceAccountName Specifies the name of the
service account. The default
value is null.
images repository Specifies the same details
provided in the
contentserver
docbroker/
values.yaml file for the
repository and
contentserver variables
in Step 8.
secret name Specifies the same name
provided in the cs-
secrets/values.yaml
file for the name variable in
Step 5.
docbroker serviceName Specifies the same name
provided in the
docbroker/
values.yaml file for the
sname variable in Step 8.
For example,
dbrforcluster1dbr.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 45


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


port Specifies the same port
provided in the
docbroker/
values.yaml file for the
port variable in Step 8. For
example, 1489.
clusterSpace Specifies the name of the
cluster space.
The format is <name of
namespace>.svc.
cluster.local.
For example, docu.
svc.cluster.local.
docbase name Specifies the name of the
repository.
id Specifies the unique id of
the repository. The unique
id should be a 6-digit
number.
owner Specifies the name of the
repository owner.
existing Specifies to use an existing
repository. The default
value is false.
index Specifies the table indexing.
The default value is TS_2.
Do NOT change this value.
contentserver replicaCount Specifies the number of
replica pods to be spawned
for Documentum Server
image. The default value is
2. The maximum value is
10.
IMPORTANT: OpenText
recommends 2 replica pods.
docbrokersCount Specifies the number of
connection brokers
deployed or as provided in
the docbroker/
values.yaml file. The
default value is 2.
port Specifies the available port
reserved for Documentum
Server. The default value is
50000.

46 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

Category Name Description


sslport Specifies the available port
reserved for encryption of
Documentum Server. The
default value is 50001.
useDefaultSpace Specifies to use the default
table space of the database.
The default value is true.
Do NOT change this value.
aek name: Specifies the name of
the AEK file. The default
value is aek_name.
lockbox • enable: Specifies the
value to use the lockbox
file. The default value is
true.
• useExisting
AekLockbox: Specifies
the value to use existing
AEK lockbox files. The
default value is false.
• lockbox: Specifies the
name of the lockbox file.
max_replica Specifies the number of
replica pods to be spawned
for Documentum Server
image. The default value is
10.
jmsProtocol Specifies the protocol to
connect to JMS. Only HTTP
protocol is supported.
Do NOT change this value.
jmsVersion Specifies the supported
WildFly version.
csVersion Specifies the version of
Documentum Server. The
default value is 16.4.
configureOpenJDK Specifies to use OpenJDK.
The default value is true.
readinessScript Specifies the path of the
script used for readiness
probe. The default path is /
opt/dctm_docker/
scripts/
cs_readiness.sh.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 47


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


jmshost Specifies the JMS host
details as:
<sname>dcs.<domain
name>.
tnshost Specifies the TNS host
details as:
<sname>.dcs.<domain
name>.
globalRepository globalRepositoryName Specifies the name of the
global repository which has
to be used as the global
repository for the current
repository. If it is set with
some value then that is
used as the global
repository for this
repository, otherwise the
current repository is
configured as the global
repository. The default
value is null.
globalRepository Specifies the connection
DocbrokerHost broker host. If not set, the
current connection broker
host is used. The default
value is null.
globalRepository Specifies the connection
DocbrokerPort broker port. If not set, the
current connection broker
port is used. The default
value is null.
ExtCS enable Specifies if the external
Documentum Server is
available. The default value
is false.
tcp_route Ensure that there is no
value specified for this
variable.
nativeExtPort Ensure that there is no
value specified for this
variable.
sslExtPort Ensure that there is no
value specified for this
variable.
database host Specifies the information
you provided while
databaseServiceName configuring the database.

48 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

Category Name Description


port See Step 6 in
“Prerequisites” on page 37.
sslEnabled Specifies to enable SSL. The
default value is false.
sslCertPath Specifies the path of SSL
certificate. The default
value is .postgresql/
root.crt
sslMode Specifies the mode of SSL.
The default value is
verify-ca.
thumbnailServer configure Specifies if Thumbnail
Server is configured. The
default value is true.
Do NOT change this value.
serverPort Specifies the available port
reserved for Thumbnail
Server. The default value is
8081.
sslPort Specifies the available port
reserved for encryption of
Thumbnail Server. The
default value is 8443.
userMemArgs Specifies the user memory
arguments. The default
value is null.
installerUi Specifies the type of
installation mode. The
default value is silent.
Do NOT change this value.
keepTempFile Specifies if the temporary
file is required. The default
value is true.
Do NOT change this value.
installerDebugLog Specifies if the installation
debug log file is required.
The default value is true.
Do NOT change this value.
indexspaceName Specifies the name of the
index space. The default
value is
DM_XCHIVE_DOCBASE.
Do NOT change this value.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 49


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


tnsProtocol Specifies the protocol to
connect to Thumbnail
Server. Only HTTP protocol
is supported.
Do NOT change this value.
otds configNameOption Specifies the type of
configuration. The default
value is HA.
Do NOT change this value.
configureOTDS Specifies the configuration
of OTDS. The default value
is true.
Do NOT change this value.
otdsAPIsvc Specifies the location where
OTDS APIs are deployed.
The default value is
otdsapi-highland.
dev.bp-paas.
otxlab.net.
clientCapability Specifies the expertise level
of the user. The default
value is 0.
userPrivileges Specifies the privileges
assigned to the user. The
default value is 0.
userXPrivileges Specifies the extended
privileges assigned to the
user. The default value is 0.
ports docbaseport Specifies the same port
provided in the content-
server/values.yaml
file for the port variable
under the contentserver
category.
docbasesslport Specifies the same port
provided in the content-
server/values.yaml
file for the sslport
variable under the
contentserver category.
jmsport Specifies the available port
reserved for Java Method
Server. The default value is
9080.

50 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

Category Name Description


tnsport Specifies the same port
provided in the content-
server/values.yaml
file for the serverPort
variable under the
contentserver category.
tnssslport Specifies the same port
provided in the content-
server/values.yaml
file for the sslport
variable under the
contentserver category.
qaTest launchCSregr Specifies if regression is
required for Documentum
Server. The default value is
false.
Do NOT change this value.
graylog enabled Specifies to use graylog.
The default value is true.
image Specifies the image details
per your Graylog server
configuration.
imagePullPolicy Specifies to pull the image.
The default value is
Always.
server Specifies the server details
per your Graylog server
configuration.
port Specifies the port details
per your Graylog server
configuration.
persistentVolume csdataPVCName Specifies the name of the
persistent volume claim.
For example, dcs-data-
pvc.
pvcAccessModes Specifies the access modes
of persistent volume claim.
The default value is
ReadWriteMany.
Do NOT change this value.
size Specifies the storage size of
the persistent volume.
storageClass Specifies the storage class
for the persistent volume.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 51


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


volumeClaimTemplate vctName Specifies the name of the
volume claim template. For
example, dcs-vct.
vctAccessModes Specifies the access modes
of the volume claim
template. The default value
is ReadWriteOnce.
size Specifies the size of the
volume claim template. The
default value is 1Gi.
storageClass Specifies the storage class
of the volume claim
template. The default value
is bp-pass-nfs.
logVctAccessModes Specifies the access modes
of log of the volume claim
template. The default value
is ReadWriteOnce.
logVctSize Specifies the size of log of
the volume claim template.
The default value is 2Gi.
logVctStorageClass Specifies the storage class
of log of the volume claim
template. The default value
is bp-paas-nfs.
s3Store enable Specifies if Amazon S3
store is enabled. The
name
default value is false. To
proxyHost enable the S3 store, set the
proxyPort value to true and provide
the appropriate values for
proxyProtocol the other variables.
noProxy
Note: Only HTTP
protocol is supported
for the
proxyProtocol
variable. Do NOT
change this value.

52 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

Category Name Description


custom scriptExecute Specifies if custom scripts
to be executed. The default
value is false.
Enable the value to TRUE to
install the DAR files or
custom scripts. In addition,
if you build as a compose
image on Documentum
Server image to install DAR
files, custom scripts, and so
on, then place the script as
script_from_external
.sh under $
{DM_DOCKER_HOME}/
custom_script/ and
bring up the composite
image. During the
installation process,
script_from_external
.sh is called and executed.
scriptinPVC Specifies the custom scripts
in PVC. The default value is
false.
enableBPMPVC Specifies to use BPM PVC.
The default value is true.
scriptPVCname Specifies to name of the
custom script in PVC. The
default value is null.
PVCSubPath Specifies to path of PVC.
The default value is null.
versions Specifies the versions. The
default value is null.
resources limits • cpu: Specifies the
maximum number of
allocated CPUs.
• memory: Specifies the
maximum usage of
allocated memory.
requests • cpu: Specifies the
maximum number of
CPUs for transaction.
• memory: Specifies the
maximum usage of
memory for transaction.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 53


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


extra Environment extraEnv Specifies the details of
Variables additional environment
variables. The default value
is null.
extra Volumes extraVolumes Specifies the details of
additional volumes. The
default value is null.
extra Volume Mounts extraVolumeMounts Specifies the details of
additional volume mounts.
The default value is null.

13. Deploy the Documentum Server Helm in your Kubernetes environment using
the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/content-server --tiller-namespace <name
of namespace> --namespace <name of namespace>

For example:

helm install --name content-server /opt/temp/Helm-charts/content-


server --tiller-namespace docu --namespace docu

14. Verify the status of the deployment of Documentum Server Helm using the
following command format:

helm status <release name> --tiller-namespace <name of namespace>

15. Verify the status of the deployment of Documentum Server pod using the
following command format:

kubectl describe pods <name of the pod>

16. Open the cs-dfc-properties/values.yaml file and provide the appropriate


values for the variables depending on your environment to pass them to your
templates as described in the following table:

Category Name Description


cs-dfc-properties replicaCount Specifies the number of
replica pods to be spawned
for Documentum Server
image. The default value is
1. The maximum value is
10.
IMPORTANT: OpenText
recommends 2 replica pods.

54 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

Category Name Description


env domain Specifies the domain name
of the environment. The
format is
<namespace>.svc.
cluster.local. For
example, docu.
svc.cluster.local.
User Name serviceName Specifies an unique name
for sname. For example,
dbrforcluster1dbr.
configMap namespace Specifies the domain name
of the environment. The
format is
<namespace>.svc.
cluster.local. For
example, docu.
svc.cluster.local.
docbroker port Specifies the same port
provided in the
docbroker/
values.yaml file for the
port variable in Step 8. For
example, 1489.
globalregistry repository Specifies the repository
defined as a global registry.
The default value is
docbase1.
username username Specifies the user name of
the global registry. The
default value is
dm_bof_registry.
Do NOT change this value.

17. Deploy the Documentum Server DFC properties Helm in your Kubernetes
environment using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/cs-dfc-properties --tiller-namespace
<name of namespace> --namespace <name of namespace>

For example:

helm install --name cs-dfc-properties /opt/temp/Helm-charts/cs-


dfc-properties --tiller-namespace docu --namespace docu

18. Verify the status of the deployment of Documentum Server DFC properties
Helm using the following command format:

helm status <release name> --tiller-namespace <name of namespace>

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 55


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

2.3.3 Upgrading Documentum Server on Kubernetes


environment
2.3.3.1 Upgrading from 16.4 patch version to 16.7
1. Before upgrading the Documentum Server pod in Kubernetes environment,
ensure that you have a minimum of two replicas.

2. Upgrade the connection broker pod.


Update the majorUpgrade to true and also update the new image details in
docbroker/values.yaml for the connection broker Helm Chart and upgrade
using the following command format:

helm upgrade <release_name> ./docbroker --tiller-namespace <name


of namespace>

Notes

• Upgrade of image is supported. You must update the upgrade and


image-related values in docbroker/values.yaml only. All other values
must not be changed.
• Upgrade process is in descending order. The upgrade process starts
from the second connection broker (for example, docbroker2) followed
by the first connection broker (for example, docbroker1).
• If you encounter any problems during the upgrade process with the
new image, then the upgrade process stops automatically. Also, you can
roll back to the previous image. “Rolling back the upgrade process”
on page 59 contains the instructions.
• Upgrade process takes approximately five minutes for each pod.

3. Run the following command inside all Documentum Server 16.4 pods to extract
the AEK from lockbox:

/opt/dctm/product/16.4/bin/dm_crypto_create -lockbox
lockbox.lb -lockboxpassphrase Password@123 -keyname aek_name -
removelockbox -output aek_name

4. Upgrade the Documentum Server pod.

a. Run the following command inside all Documentum Server 16.4 pods to
extract the AEK from lockbox:

/opt/dctm/product/16.4/bin/dm_crypto_create -lockbox
lockbox.lb -lockboxpassphrase Password@123 -keyname aek_name
-removelockbox -output aek_name
b. Set the value of majorUpgrade to true in content-server/values.yaml.
c. Update new image details in content-server/values.yaml for the
Documentum Server Helm Chart.
d. Upgrade using the following command format:

56 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

helm upgrade <release name> ./content-server --tiller-


namespace <name of namespace>

Notes

• Upgrade of both image and replicas are supported. You must


update the upgrade (majorUpgrade entry), image-related, and
replica values in content-server/values.yaml only. All other
values must not be changed.

• Upgrade process is in descending order. The upgrade process starts


from the second Documentum Server (for example,
documentumserver2) followed by the first Documentum Server (for
example, documentumserver1).

• If you encounter any problems during the upgrade process with the
new image, then the upgrade process stops automatically. Also,
you can roll back to the previous image. “Rolling back the upgrade
process” on page 59 contains the instructions.

• While upgrading the Documentum Server pod, the existing


Documentum Server pod is deleted and new Documentum Server
pod is created. Volume Claim Templates and Persistent Volume
Claims remain as is and the new pods continue to mount the old
VCTs and PVCs.

• Upgrade process takes approximately five minutes for each pod.

5. Verify the status of the successful upgrade using the following steps:

a. Check the installation log files. If the upgrade is successful, no errors are
reported in the log files.

b. Check the Documentum Server version. Log in to the pod and run the IAPI
command to verify the version. If the upgrade is successful, then the new
Documentum Server version is displayed.

c. Check the status of the pod. If the upgrade is successful, the status of the
pod is active.

2.3.3.2 Upgrading from one patch version to another patch version


1. Before upgrading the Documentum Server pod in Kubernetes environment,
ensure that you have a minimum of two replicas.

2. Upgrade the connection broker pod.


Update the new image details in docbroker/values.yaml for the connection
broker Helm Chart and upgrade using the following command format:

helm upgrade <release_name> ./docbroker --tiller-namespace <name


of namespace>

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 57


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Notes

• Upgrade of image is supported. You must update the image-related


values in docbroker/values.yaml only. All other values must not be
changed.
• Upgrade process is in descending order. The upgrade process starts
from the second connection broker (for example, docbroker2) followed
by the first connection broker (for example, docbroker1).
• If you encounter any problems during the upgrade process with the
new image, then the upgrade process stops automatically. Also, you can
roll back to the previous image. “Rolling back the upgrade process”
on page 59 contains the instructions.
• Upgrade process takes approximately five minutes for each pod.

3. Upgrade the Documentum Server pod.


Update the new image details in content-server/values.yaml for the
Documentum Server Helm Chart and upgrade using the following command
format:

helm upgrade <release name> ./content-server --tiller-namespace


<name of namespace>

Notes

• Upgrade of both image and replicas are supported. You must update
the image-related and replica values in content-server/values.yaml
only. All other values must not be changed.
• Upgrade process is in descending order. The upgrade process starts
from the second Documentum Server (for example,
documentumserver2) followed by the first Documentum Server (for
example, documentumserver1).
• If you encounter any problems during the upgrade process with the
new image, then the upgrade process stops automatically. Also, you can
roll back to the previous image. “Rolling back the upgrade process”
on page 59 contains the instructions.
• While upgrading the Documentum Server pod, the existing
Documentum Server pod is deleted and new Documentum Server pod
is created. Volume Claim Templates and Persistent Volume Claims
remain as is and the new pods continue to mount the old VCTs and
PVCs.
• Upgrade process takes approximately five minutes for each pod.

4. Verify the status of the successful upgrade using the following steps:

a. Check the installation log files. If the upgrade is successful, no errors are
reported in the log files.

58 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.3. Deploying and configuring Documentum Server on private cloud

b. Check the Documentum Server version. Log in to the pod and run the IAPI
command to verify the version. If the upgrade is successful, then the new
Documentum Server version is displayed.
c. Check the status of the pod. If the upgrade is successful, the status of the
pod is active.

2.3.3.3 Rolling back the upgrade process


Rolling back the upgrade process (rolling back to the previous image) is
recommended when the upgrade process fails or when you encounter errors using
the new image.

Perform the following steps:

1. Fetch the details of history using the following command format:

helm history <release name> --tiller-namespace <name of


namespace>

2. Roll back to the previous image using the following command format:

helm rollback <release name> <revision> --tiller-namespace <name


of namespace>

2.3.4 Limitations
• Installation owner is predefined and cannot be changed. The value is dmadmin.
• Installation path is predefined and cannot be changed. The value is /opt/dctm/
product/<product version>.

• Upgrading of schema is not supported.

2.3.5 Troubleshooting
Symptom Cause Fix
When you check the status of One of the two containers in Delete the pod using the
available pods using the the specified pod(s) is down kubectl delete pods
kubectl get pods or unavailable. <name of the pod>
command, the READY value command. The pod is
of one or more pod(s) reads recreated automatically.
as 1/2.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 59


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Symptom Cause Fix


When you check the status of Incorrect Helm deployment. Delete the Helm deployment
available deployed image, it using the following
results in the Error: command:
ImagePullBackOff error.
helm delete <release
name> --purge <name
of the pod> --tiller-
namespace <name of
tiller namespace> --
namespace <name of
namespace>

Then, provide the correct


image path and redeploy the
Helm Chart.
When you check the status of Unsuccessful upgrade. Use the describe command
the upgrade process, it to find the cause.
results in an error.
For example:

kubectl describe pod


<name of the pod>

Or

kubectl describe
statefulset <name of
the statefulset>

If any pod is down or not


available, then the upgrade
or rollback is not started at
the pod level. Recreate the
pod for the upgrade or
rollback to start.

2.4 Deploying and configuring Independent Java


Method Server on private cloud

60 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.4. Deploying and configuring Independent Java Method Server on private cloud

2.4.1 Prerequisites
1. Perform the steps from Step 1 to Step 4 in “Deploying and configuring
Documentum Server on private cloud” on page 37.

2. Ensure that the Documentum Server pod is deployed.

3. Download the IJMS Image (CentOS only) and Helm Chart TAR files from
OpenText My Support.

2.4.2 Deploying Independent Java Method Server on


Kubernetes environment
1. Install the IJMS Image (CentOS only) in the same namespace.
Load the IJMS Image into the Docker registry using the following command
and update the exact IJMS Image name:

docker load -i <TAR file name of the IJMS image>

2. Extract the Helm Charts TAR file to a temporary location.

3. Update the ijms/values.yaml file and provide the appropriate values for the
variables depending on your environment to pass them to your templates as
described in the following table:

Category Name Description


User Name serviceName Specifies an unique name.
ijms replicaCount Specifies the number of
replica pods to be spawned
for IJMS image. The default
value is 2. The maximum
value is 10.
IMPORTANT: OpenText
recommends 2 replica pods.
host Specifies the host of the
IJMS. The format is
<sname>ijms.<ingress
domain name>. For
example, test1ijms.
docu.cfcr-lab.bp-
paas.otxlab.net.
ijmsConfiguring Specifies the name of a
specific IJMS configuring
ContentServer
Documentum Server or
ALL to configure all
Documentum Servers.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 61


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


images repository Specifies the registry host
and port details of Docker
images.
ijms • name: Specifies the
name of the IJMS image.
For example, ijms/
centos/stateless/
ijms.
• tag: Specifies the tag as
a version-specific
number.
docbase name Specifies the name of the
repository.
secret name Specifies the same name
provided in the cs-
secrets/values.yaml
file for the name variable in
Step 5.
docbroker serviceName Specifies the same name
provided in the
docbroker/
values.yaml file for the
sname variable in Step 8.
For example,
splitdbr-0.
splitdbr.docu.
svc.cluster.local.
port Specifies the same port
provided in the
docbroker/
values.yaml file for the
port variable in Step 8. For
example, 1489.
clusterSpace Specifies the name of the
cluster space.
The format is <name of
namespace>.svc.
cluster.local.
For example, docu.
svc.cluster.local.
docbrokersCount Specifies the number of
connection brokers
deployed.

Note: Only one


connection broker is
supported.

62 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.4. Deploying and configuring Independent Java Method Server on private cloud

Category Name Description


globalRepository globalRepositoryName Specifies the name of the
global repository which has
to be used as the global
repository for the current
repository. If it is set with
some value then that is
used as the global
repository for this
repository, otherwise the
current repository is
configured as the global
repository.
globalRepositoryUser Specifies the user of the
global repository. The
default value is
dm_bof_registry.
jmsport Specifies the available port
reserved for Java Method
Server. The default value is
9180.
ingress enabled Specifies if ingress is
enabled. The default value
is true.
persistentVolume ijmsdataPVCName Specifies the name of the
persistent volume claim.
For example, ijms-data-
pvc.
pvcAccessModes Specifies the access modes
of persistent volume claim.
The default value is
ReadWriteMany.
Do NOT change this value.
size Specifies the storage size of
the persistent volume. The
default value is 1Gi
storageClass Specifies the storage class
for the persistent volume.
The default value is bp-
pass-nfs.
volumeClaimTemplate vctName Specifies the name of the
volume claim template. For
example, ijms-vct.
vctAccessModes Specifies the access modes
of the volume claim
template. The default value
is ReadWriteOnce.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 63


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


size Specifies the size of the
volume claim template. The
default value is 1Gi.
storageClass Specifies the storage class
of the volume claim
template. The default value
is bp-pass-nfs.
logVctAccessModes Specifies the access modes
of log of the volume claim
template. The default value
is ReadWriteOnce.
logVctSize Specifies the size of log of
the volume claim template.
The default value is 2Gi.
logVctStorageClass Specifies the storage class
of log of the volume claim
template. The default value
is bp-paas-nfs.
service service • type: ClusterIP
• port: 80

4. Deploy the IJMS Helm in your Kubernetes environment using the following
command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/ijms --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name ijms /opt/temp/Helm-charts/ijms --tiller-


namespace docu --namespace docu

5. Verify the status of the deployment of IJMS Helm using the following command
format:

helm status <release name> --tiller-namespace <name of namespace>

6. Verify the status of the deployment of IJMS pod using the following command
format:

kubectl describe pods <name of the pod>

64 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.5. Deploying and configuring Documentum Administrator on private cloud

2.4.3 Limitations
• Installer updates the IJMS config objects only in the primary Documentum
Server. You must manually update the IJMS config objects in all other
Documentum Server (replicas) config objects.

2.4.4 Troubleshooting
There are no troubleshooting information for this release.

2.5 Deploying and configuring Documentum


Administrator on private cloud
2.5.1 Prerequisites
1. Perform the steps from Step 1 to Step 4 in “Deploying and configuring
Documentum Server on private cloud” on page 37.

2. Download the Documentum Administrator Image (CentOS only) and Helm


Chart TAR files from OpenText My Support.

2.5.2 Deploying Documentum Administrator on Kubernetes


environment
1. Install the Documentum Administrator Image (CentOS only) Load the
Documentum Administrator Image into the Docker registry using the following
command and update the exact Documentum Administrator Image name:

docker load -i <TAR file name of Documentum Administrator image>

2. Extract the Helm Charts TAR file to a temporary location.

3. Download the Graylog Docker Image from the Docker Hub website. Graylog
Docker Documentation contains more information about Administrator
configuration.

4. Load the Graylog Docker image using the following command format:

docker load -i <name of downloaded graylog docker image>

Upload the Graylog Docker image to your local repository and configure, as
appropriate.

5. Open the da/values.yaml file and provide the appropriate values for the
variables depending on your environment to pass them to your templates as
described in the following table:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 65


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


namespace namespace Specifies the name of the
namespace.
hostName hostName Specifies an unique name
for <Uname>. For example,
da164.
env domain Specifies the name of
domain.
userName userName Specifies the name as
described in values.yaml
file of Documentum Server.
replicaCount replicaCount Specifies the number of
replica pods to be spawned
for Documentum
Administrator image. The
default value is 1. The
maximum value is 10.

Note: OpenText
recommends 2 replica
pods.
buildNo buildNo Specifies the build number
of the current deployment.
appName appName Specifies the application
name for Documentum
Administrator. The format
is da-app-<build_no>.
images da • repository: Specifies
the path of the
repository. The format is
<IP
Address>:<Port>.
• name: Specifies the
name of the
Documentum
Administrator image.
For example, /da/
centos/stateless/
dastateless.
• tag: Specifies the tag as
a version-specific
number.
• pullPolicy: Specifies
to pull the image. For
example,
IfNotPresent.

66 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.5. Deploying and configuring Documentum Administrator on private cloud

Category Name Description


grayLogSideCar • repository
• name
• tag
• pullPolicy
ingress ingressHostName Specifies the ingress host
name. For example, da-
ingress-54.
clusterDomainName Specifies the domain name
of the cluster.
annotations • nginx.
ingress.kubernetes
.io/proxy-body-
size:5g
• nginx.
ingress.kubernetes
.io/proxy-connect-
timeout:30m
path Specifies the path. For
example, /.
hosts Specifies the details of
hosts. For example,
chart-example.local.
service service • name: Specifies the
service name. For
example, da-54.
• type: Specifies the type
of service. For example,
ClusterIP.
• port: Specifies the port
used for service. For
example, 8080.
ingressController name Specifies the name of the
ingress controller.
type Specifies the type of the
port. For example,
NodePort.
port Specifies the port used for
the ingress controller.
targetPort Specifies the target port
used for the ingress
controller.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 67


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


protocol Specifies the protocol used
for the ingress controller.
The default value is TCP.
provider Specifies the provider for
the ingress controller. For
example, ingress-nginx.

68 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.5. Deploying and configuring Documentum Administrator on private cloud

Category Name Description


containers da • name: Specifies the
name. For example, da.
• kubernetes: Specifies
if Kubernetes is enabled.
For example, true.
• externalFolderPath
: Specifies the external
folder path. For
example, /opt/
tomcat/webapps/da/
external-
configurations .
• otdsproperties:
Specifies the URL of
OTDS (otds_url). For
example, https://
otdsauth-highland.
dev.bp-paas.
otxlab.net::client
_id=da.
• appproperties:
Specifies the properties
of the application.
• dfcProperties: If
Config Map of
Documentum Server is
not used then update
the dfc.properties
values accordingly.
• containerPort:
Specifies the port used
within the container to
access the application.
• readinessProbe:
– healthPath:
Specifies the path
used for checking
the health of the
Documentum
Administrator pod.
– healthPort:
Specifies the port
used for the
Documentum
Administrator pod.
– initial
DelaySeconds:
Specifies the number
of seconds after the

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 69


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


Documentum
Administrator pod
has started before
the readiness probe
is initiated. The
default value is 180
seconds.
– periodSeconds:
Specifies the
frequency to perform
the probe. The
default value is 300
seconds.
– failureThreshold
: Specifies the time
when a pod starts
and the probe fails,
Kubernetes attempts
based on the failure
threshold time
before stopping. The
default value is 2
seconds.
– successThreshold
: Specifies the
minimum
consecutive
successes for the
probe to be
considered
successful after
having failed. The
default value is 1
second.
– timeoutSeconds:
Specifies the number
of seconds after
which the probe
times out. The
default value is 120
seconds.

70 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.5. Deploying and configuring Documentum Administrator on private cloud

Category Name Description


grayLogSideCar • containerName:
Specifies the name of
the container. For
example, graylog-
sidecar-app.
• server: Specifies the
Graylog server details.
For example, 10.9.57.
15.
• port: Specifies the port
used for the Graylog
server. For example,
9000.
• tags: Specifies the
details of tags. For
example, [\"linux\",
\"apache\"].
persistentVolumeClaim accessMode Specifies the access modes
of persistent volume claim.
For example,
ReadWriteMany.
size Specifies the storage size of
the persistent volume. For
example, 1Gi.
storageClass Specifies the storage class
for the persistent volume.
For example, bp-pass-
nfs.
cs configMap name: Config map name
used in Documentum
Server. The format is
<name>.configmap
where <name> is the same
provided in the values.
yaml of Documentum
Server.
supportConfigMap Specifies to use DFC
properties from Config
map. The default value is
true.
csSecretConfig Specifies the name of the
secret configuration file. For
example, cs-secret-
config.
globalRegistry Specifies the password of
the global registry.
Password

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 71


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


resources limits • cpu: Specifies the
maximum number of
allocated CPUs.
• memory: Specifies the
maximum usage of
allocated memory.
requests • cpu: Specifies the
maximum number of
CPUs for transaction.
• memory: Specifies the
maximum usage of
memory for transaction.

6. Deploy the Documentum Administrator Helm in your Kubernetes environment


using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/da --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name da /opt/temp/Helm-charts/da --tiller-


namespace docu --namespace docu

7. Verify the status of the Documentum Administrator Helm deployment.

helm status <release name> --tiller-namespace <name of namespace>

2.5.3 Limitations
Installation path is predefined and cannot be changed. The value is /opt/tomcat/
webapps/da.

2.5.4 Troubleshooting
Symptom Cause Fix
When you check the status of One of the two containers in Delete the pod using the
available pods using the the specified pod(s) is down following command:
kubectl get pods or unavailable.
command, the READY value kubectl delete pods
of one or more pod(s) reads <name of the pod
as 1/2. command>.

After you delete, the pod is


recreated automatically.

72 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.6. Deploying and configuring Documentum Foundation Services on private cloud

Symptom Cause Fix


When you check the status of Incorrect Helm deployment. Delete the Helm deployment
available deployed image, it using the following
results in the Error: command:
ImagePullBackOff error.
helm delete <release
name> --purge <name
of the pod> --tiller-
namespace <name of
tiller namespace> --
namespace <name of
namespace>

Then, provide the correct


image path and redeploy the
Helm Chart.

2.6 Deploying and configuring Documentum


Foundation Services on private cloud
2.6.1 Prerequisites
1. Perform the steps from Step 1 to Step 4 in “Deploying and configuring
Documentum Server on private cloud” on page 37.

2. Ensure that the Documentum Server pod is deployed.

3. Download the Documentum Foundation Services Image (CentOS only) and


Helm Chart TAR files from OpenText My Support.

2.6.2 Deploying Documentum Foundation Services on


Kubernetes environment
1. Install the Documentum Foundation Services Image (CentOS only) in the same
namespace.
Load the Documentum Foundation Services Image into the Docker registry
using the following command and update the exact Documentum Foundation
Services Image name:

docker load -i <TAR file name of Documentum Foundation Services


image>

2. Extract the Helm Charts TAR file to a temporary location.

3. Update the dfs/values.yaml file and provide the appropriate values for the
variables depending on your environment to pass them to your templates as
described in the following table:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 73


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


User Name serviceName Specifies an unique name.
image path Specifies the path of the
image. The format is <IP
address of
image>:<Port>/dfs/
centos/stateless/dfs.
tag Specifies the tag as a
version-specific number.
pullPolicy Specifies to pull the image.
For example,
IfNotPresent.
replicaCount replicaCount Specifies the number of
replica pods to be spawned
for Documentum
Foundation Services image.
The default value is 1. The
maximum value is 10.
IMPORTANT: OpenText
recommends 1 replica pod.
namespace namespace Specifies the name of the
Kubernetes namespace
where Documentum
Foundation Services chart
is deployed.
volumeClaimTemplate storageClass Specifies the storage class
of the volume claim
template. The default value
is bp-pass-nfs.
size Specifies the size of the
volume claim template. The
default value is 200Mi. The
size that you specify must
accommodate all the log
files.
tomcat username Specifies the manager name
of Tomcat. The default
value is admin.
password Specifies the password of
the manager of Tomcat. The
default value is password.
tomcatClusterEnabled Specifies if the cluster of
Tomcat is enabled. The
default value is true.

74 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.6. Deploying and configuring Documentum Foundation Services on private cloud

Category Name Description


docbaseconnection docbroker Specifies the same name
provided in the
docbroker/
values.yaml file for the
sname variable in Step 8.
For example,
servicenamedbr.
port Specifies the same port
provided in the
docbroker/
values.yaml file for the
port variable in Step 8. For
example, 1489.
domain Specifies the name of the
domain. This is an optional
variable and can be blank.
globalRegistry Specifies the repository
Repository defined as a global registry.
The default value is
docbase1.
globalRegistry Specifies the user name of
Username the global registry. The
default value is
dm_bof_registry.
globalRegistry Specifies the password of
Password the global registry. The
default value is password.
connectionMode Specifies the connection
mode. The default value is
try_native_first.
log4j logLevel Specifies the log level for
the Documentum
Foundation Services
packages. The default value
is WARN.
dfc dataDir Specifies the data directory
path of Documentum
Foundation Classes. The
default value is /var/
documentum.

Note: The data


directory path need
not be changed.

4. Deploy the Documentum Foundation Services Helm in your Kubernetes


environment using the following command format:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 75


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/dfs --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name dfs /opt/temp/Helm-charts/dfs --tiller-


namespace docu --namespace docu

5. Verify the status of the deployment of Documentum Foundation Services Helm


using the following command format:

helm status <release name> --tiller-namespace <name of namespace>

6. Verify the status of the deployment of Documentum Foundation Services pod


using the following command format:

kubectl describe pods <name of the pod>

2.6.3 Limitations
Installation path is predefined and cannot be changed. The value is /opt/tomcat/
webapps/dfs.

2.6.4 Troubleshooting
Symptom Cause Fix
When you check the status of Incorrect Helm deployment. Delete the Helm deployment
available deployed image, it using the following
results in the Error: command:
ImagePullBackOff error.
helm delete <release
name> --purge <name
of the pod> --tiller-
namespace <name of
tiller namespace> --
namespace <name of
namespace>

Then, provide the correct


image path and redeploy the
Helm Chart.

76 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.7. Deploying and configuring Documentum REST Services on private cloud

2.7 Deploying and configuring Documentum REST


Services on private cloud
2.7.1 Prerequisites
Ensure that you complete the following tasks before you deploy Documentum REST
Services in the Kubernetes environment. The Kubernetes operations are performed
using kubectl and Helm.

The following items form a checklist that you can use to prepare to deploy
Documentum REST Services in the Kubernetes environment:

• Ensure that you have (or create) a Kubernetes cluster.


• Install kubectl on the client machine and configure it to access the Kubernetes
cluster.
• Deploy the Helm server (Tiller) in the cluster.
• Install the Helm client (helm) on the client machine.
• Ensure that the Documentum Server, repositories, and connection brokers are
ready in the cluster.
• When full-text search and CTS are required, ensure that xPlore and CTS are
deployed in the cluster.
• Get the Documentum REST Docker archive (CentOS only) from OpenText My
Support.
• Ensure that you have a Docker registry to push the REST Docker image (for
example, <DOCKER-REGISTRY>).
• If you want to enable SSL, prepare Persistent Volume (PV) or Persistent Volume
Claim (PVC) for REST Services to load a keystore file.
Kubernetes Documentation provides more information.

2.7.2 Deploying Documentum REST Services on Kubernetes


environment
To deploy REST Services Helm, perform the following:

1. Download the REST Docker TAR file from OpenText My Support.

2. Extract the contents of the TAR file using the following command format:

tar -xzvf RESTAPI_VERSION_Docker_Centos.tar

3. Load the REST image, tag it, and load it to the registry.

docker load -i restapi_centos_<version>.tar

4. Download the Helm Charts TAR file from OpenText My Support.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 77


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

5. Extract the Helm Charts TAR file to a temporary location.

6. Prepare the following configuration files: dfc.properties, rest-api-


runtime.properties, and log4j.properties within dctm-rest. It is
mandatory to prepare the dfc.properties file.

7. If you want to enable SSL, prepare the certificate and keystore.

8. Edit the values.yaml file and provide the appropriate values for the variables
depending on your environment to pass them to your templates as described in
the following table:

Category Name Description


metadata customLabels Specifies the labels for the
deployment.
For example, app:
backend.
containerName Specifies the name of the
container.
deployment replicaCount Specifies the number of
pods to be spawned for
Documentum REST
Services.
strategyType Specifies the strategy for
the deployment.
For example,
RollingUpdate,
Recreate, and so on.
image image Specifies the image name of
Documentum REST
Services.
imageTag Specifies the image tag of
Documentum REST
Services.
imagePullPolicy Specifies the pull policy for
the Documentum REST
Services image.
For example,
IfNotPresent, Always,
and so on.
service serviceType Specifies the service type.
For example, NodePort,
ClusterIP, and so on.
httpPort Specifies the service HTTP
port for Documentum REST
Services.

78 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.7. Deploying and configuring Documentum REST Services on private cloud

Category Name Description


httpsPort Specifies the service HTTPS
port for Documentum REST
Services.
persistence persistence.enabled If you want to enable SSL
for Documentum REST
Services, keystore file is
required. Enable
persistence to true and
save the keystore file on the
mounted volume.
persistence. Specifies an existing
persistent volume claim to
existingPVC
mount. If the value is not
specified, installing REST
Helm Chart creates a new
PVC and is bound to PV. If
there is no existing PVC,
then you must bind the
existing PVC to PV.
persistence.subPath Specifies the path of the
subfolder in the volume to
use.
persistence. Specifies the access mode.
accessMode For example,
ReadWriteMany,
ReadWriteOnce, so on.
persistence. Specifies the storage class
name according to the
storageClass
environment, which
depends on underlying
storage provider.
persistence.size Specifies the size of the
storage to use.
For example, 10Mi.
securityVolume Specifies the volume mount
path of the REST container.
MountPath
After keystore file is in the
volume, REST uses file
from this path.
SSL ssl.keystoreFile Specifies the full path of the
keystore file.
You must manually
generate the keystore and
key then save it in the
mounted volume.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 79


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

Category Name Description


ssl.keystorePwd Specifies the password of
the keystore.
ssl.keyAlias Specifies the key alias.
ssl.keyPwd Specifies the key password.
ssl.keystoreType Specifies the keystore type,
such as, JKS.
ConfigMap existingConfigMap Specifies the name of the
existing ConfigMap.
If it is not specified,
installing REST Helm Chart
creates a new ConfigMap
with configuration files
specified by
configurationFiles.
You can use an existing
ConfigMap.
configurationFiles Specifies the configuration
files,
configurationFiles:
- rest-api-runtime.
properties
- dfc.properties
- log4j.properties
The files should be in the
root directory of the Helm
Chart.
graylog graylog.enabled Specifies to use the Graylog
sidecar. To use, set the
value to true.
graylog.image Specifies the image name of
Graylog sidecar.
graylog. Specifies the strategy for
the deployment.
imagePullPolicy
graylog.server Specifies the server details
per your Graylog server
configuration.
graylog.port Specifies the port of
Graylog server.
graylog.serviceToken Specifies the service token
of Graylog sidecar.

80 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.7. Deploying and configuring Documentum REST Services on private cloud

Category Name Description


graylog.logsDir Specifies the logs directory
of Documentum REST
Services. A shared volume
is mounted to both this
directory of REST container
and a specific folder of
Graylog sidecar container.
Therefore, REST log file is
shared with the sidecar
container.

9. Deploy the REST Helm in your Kubernetes environment.

helm install -n <release_name> ./dctm-rest

10. Use the helm or kubectl command to verify the status of REST Helm
deployment.

2.7.2.1 Configuring SSL


Generate the certificate or keystore and save it in the mounted volume with the
Values.persistence.subPath path, so that REST loads from the path specified by
Values.ssl.keystoreFile.

For example, {{.Values.persistence.subPath}}=security and {{.Values.


securityVolumeMountPath}}=/root/rest/persistence.

The keystore file is located at /.../security/foobar/keystore.jks on the


storage. In the REST container, the keystore file is located in /root/rest/
persistence/foobar/keystore.jks. Therefore, {{.Values.ssl.keystoreFile}}
should be /root/rest/persistence/foobar/keystore.jks.

You can only modify the values.yaml or set the variables in command.

...

#ssl
ssl:
keystoreFile: /root/rest/persistence/foobar/ks.jks
keystorePwd: passw0rd
keyAlias: tomcat
keyPwd: passw0rd
keystoreType: JKS
...

#volume
securityVolumeMountPath: /root/rest/persistence
...

#persistence
persistence:
enabled: true

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 81


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

subPath: security
...

2.7.2.2 Integrating Graylog


Documentum REST Services Helm Chart supports the integration with Graylog via
sidecar. When you set the value of graylog.enabled to true, a sidecar container is
created in the Documentum REST Services pod.

Example for Graylog integration:

graylog:
enabled:true
image: gcr.io/documentum-search-product/graylog-sidecar
imagePullPolicy: Always
server: rest-graylog-headless.dctm-rest.svc.cluster.local
port: 9000
serviceToken: 87ckh5e9aammi6rd6g75ceuibce4ot8icb3itpeq4bibea25ge0
logsDir: /root/rest/logs

By default, the value of graylog.logsDir is /root/rest/logs. If the logs directory


is specified by log4j.appender.R.File in log4j.properties, ensure that the
value of graylog.logsDir aligns with the path defined in log4j.properties.

Sample Graylog sidecar configuration that needs to be configured in Graylog server


to be pushed to sidecar:

#required for Graylog


fields_under_root: true
fields.collector_node_id: ${sidecar.nodeName}
fields.gl2_source_collector : ${sidecar.nodeId}
fields.source: ${sidecar.nodeName}

filebeat.inputs:
- input_type: log
paths:
- /pod-data*.log
type: log
output.logstash:
hosts: ["rest-graylog-headless.dctm-rest.svc.cluster.local:5044"]
path:
data: /var/lib/graylog-sidecar/collectors/filebeat/data
logs: /var/lib/graylog-sidecar/collectors/filebeat/log

82 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
2.7. Deploying and configuring Documentum REST Services on private cloud

2.7.3 Upgrading Documentum REST Services on Kubernetes


environment
Helm has built-in upgrade support. Modify the variables in values.yaml, including
configuration and image version.

helm upgrade <release_name> ./dctm-rest

When ConfigMap is updated, an additional argument, the --recreate-pods


argument, is required for the upgrade command as shown in the following code
sample:

helm upgrade --recreate-pods <release_name> ./dctm-rest

You can roll back the upgrade using the following command format:

helm rollback <release_name> <revision>

2.7.4 Rolling back the upgrade process


Rolling back the upgrade process (rolling back to the previous image) is
recommended when the upgrade process fails or when you encounter errors using
the new image.

helm rollback <release name> <revision> --tiller-namespace <name of


namespace>

2.7.5 Extensibility
Documentum REST Services supports extensibility for you to customize the
resources.

If you want to deploy extended Documentum REST Services in Kubernetes, perform


the following:

• Build the dctm-rest.war file.


• Construct the Docker file. Documentum Platform REST Services Development Guide
provides more details.
• If you have additional preparation work for extended Documentum REST
Services before launching Tomcat, update entrypoint.sh.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 83


EDCSYCD160700-IGD-EN-02
Chapter 2 Deploying Documentum Platform and Platform Extensions applications on
Private Cloud

2.7.6 Limitations
There are no limitations for this release.

2.7.7 Troubleshooting
There are no troubleshooting information for this release.

84 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
Chapter 3
Deploying Documentum Platform and Platform
Extensions applications on Microsoft Azure cloud
platform

3.1 Supported applications and versions


The Release Notes document contains the information about the list of applications
and its supported versions.

3.2 Deploying and configuring Documentum Server


on Microsoft Azure cloud platform
3.2.1 Prerequisites
Ensure that you complete the following activities before you deploy Documentum
Server on Azure environment:

1. Download and configure the Docker application from the Docker website.
Docker Documentation contains more information.
2. Download and configure the Helm (client) and Tiller (server) application from
the Helm website.
Helm Documentation contains more information.
3. Download and configure the Kubernetes application from the Kubernetes
website.
Kubernetes Documentation contains more information.
4. Download and configure the PostgreSQL database (server) from the
PostgreSQL website.

Note: The PostgreSQL database client is packaged with Documentum


Server Image.

PostgreSQL Documentation contains more information.


5. Set up Azure.

a. Create a resource group. A resource group in Azure is a folder to keep your


collection. It does not serve any other purpose.
Navigate to Home > Resource groups > Resource group and provide the
following information:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 85


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

• Resource group name


• Subscription
• Resource group location

Click Create.
b. Create a container registry. Container registry is used to store the Docker
images in Azure. A standard container registry can store up to 100 GB of
images.
Navigate to Home > Container registries > Create container registry and
provide the following information:

• Registry name
• Subscription
• Resource group
• Location
• Admin user
• SKU

Click Create.
c. Create an Azure Kubernetes Service (AKS). AKS is a managed container
orchestration service, based on the open source Kubernetes system, which
is available on the Azure public cloud.
Navigate to Home > Kubernetes services > Create Kubernetes cluster and
provide the information in the following tabs:

• Basics: Provide valid values for all the mandatory fields such as
PROJECT DETAILS, CLUSTER DETAILS, and so on. Select the
E4s_V3 with the family as Memory Optimized for the virtual machine
size.
Click Next: Authentication >.
• Authentication: Provide valid values for all the mandatory fields such
as CLUSTER INFRASTRUCTURE and KUBERNETES
AUTHENTICATION AND AUTHORIZATION. Enable Role-based
access control (RBAC).
Click Next: Networking >.
• Networking: Disable HTTP application routing and set the proper
ingress controller. Also, select Basic for Network configuration.
Click Next: Monitoring >.
• Monitoring: Enable the container monitoring. Also, select the log
analytics workspace.
Click Next: Tags >.

86 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
3.2. Deploying and configuring Documentum Server on Microsoft Azure cloud platform

• Tags: (Optional) Name or value pairs that enable you to categorize


resources.
Click Next: Review + create >.
• Review + create: Review the summary of information and click Create
to create an AKS.
d. Create an Azure database for the PostgreSQL server to enable Postgres as a
service.
Navigate to Home > Azure Database for PostgreSQL servers >
PostgreSQL server > Pricing tier. Provide valid values for all the
mandatory fields.
Click Create.

6. Configure Azure on Linux VM using the following commands:

az aks install-cli
sudo yum update azure-cli
sudo sh -c 'echo -e "[azure-cli]\nname=Azure
CLI\nbaseurl=https://packages.microsoft.com/yumrepos/azure-
azurecli\nenabled=1\ngpgcheck=1\
ngpgkey=https://packages.microsoft.com/keys/microsoft.asc">
/etc/yum.repos.d/azure-cli.repo'
sudo yum install azure-cli
az aks install-cli
az aks get-credentials --resource-group dctm --name dctmaks
az login
az login -u <id>@opentext.com

After the configuration, view the configuration of Azure using the following
command format:

kubectl config view

Example output:

[root@skvcentos ~]# kubectl config view


apiVersion: v1
clusters:
- cluster:
certificate-authority-data: DATA+OMITTED
server: https://dctmaks-382bfe75.hcp.eastus.azmk8s.io:443
name: dctmaks
contexts:
- context:
cluster: dctmaks
user: clusterUser_dctm_dctmaks
name: dctmaks
current-context: dctmaks
kind: Config
preferences: {}
users:
- name: clusterUser_dctm_dctmaks
user:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 87


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

client-certificate-data: REDACTED
client-key-data: REDACTED
token: 0506b0a1bd38280fc155a15ae2641eb8

7. Install Helm on Linux VM.

a. Download the Helm release from the GitHub website.


b. Extract the Helm release TAR file to a temporary location using the
following command format:

tar -zxvf helm-xxxx-amd64.tgz

Example output:

[root@skvcentos ~]# tar -zxvf helm-v2.11.0-rc.3-


linux-386.tar.gz

linux-386/
linux-386/README.md
linux-386/tiller
linux-386/helm
linux-386/LICENSE
[root@skvcentos ~]#
c. Find the Helm binary and move it to the /usr/local/bin/helm folder
using the following command format:

mv linux-amd64/helm /usr/local/bin/helm

8. Create a service account in the respective namespace using the following


command format:

kubectl create serviceaccount <name of the service account> --


namespace <name of namespace>

Example output:

[root@skvcentos linux-386]# kubectl create serviceaccount


--namespace default tiller
serviceaccount/tiller created

9. Create a cluster role binding for a particular cluster role using the following
command format:

kubectl create clusterrolebinding <name of the cluster role>


--clusterrole=cluster-admin
-- serviceaccount=<name of namespace>:<name of the cluster role>

Example output:

[root@skvcentos linux-386]# kubectl create clusterrolebinding


tillercluster-rule
--clusterrole=cluster-admin
--serviceaccount=default:tiller
clusterrolebinding.rbac.authorization.k8s.io/

88 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
3.2. Deploying and configuring Documentum Server on Microsoft Azure cloud platform

tiller-cluster-rule created
[root@skvcentos linux-386]#

10. Install Tiller (server) in your Kubernetes Cluster and set up the local
configuration in $HELM_HOME (default is ~/.helm/). Use the following command
to read $KUBECONFIG (default is ~/.kube/config) and identify the Kubernetes
clusters:
helm init

Initialize the Tiller in your namespace using the following command format:
helm init --service-account <name of the service account> --
tiller-namespace <name of namespace>

Example output:
[root@skvcentos ~]# helm init --service-account tiller
--tillernamespace default $HELM_HOME has been configured at /
root/.helm.

Tiller (the Helm server-side component) has been installed into


your
Kubernetes Cluster.

Please note: by default, Tiller is deployed with an insecure


'allow
unauthenticated users' policy.
To prevent this, run `helm init` with the --tiller-tls-verify
flag.
[root@skvcentos ~]#

Helm Documentation contains more information.


11. Update the field(s) of a resource using the following command format:
kubectl patch deploy --namespace <name of namespace>
tiller-deploy -p
'{"spec":{"template":{"spec":{"serviceAccount":"tiller"}}}}'

Example output:
[root@skvcentos ~]# kubectl patch deploy --namespace default
tillerdeploy -p
'{"spec":{"template":{"spec":{"serviceAccount":"tiller"}}}}'
deployment.extensions/tiller-deploy patched (no change)

12. Fetch the details of the resource using the following command format:
az aks show --resource-group <resource group name>
--name <name of the cluster>
--querynodeResourceGroup -o tsv

Example output:
[root@skvcentos ~]# az aks show --resource-group dctm
--name dctmaks

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 89


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

--query nodeResourceGroup -o tsv


MC_dctm_dctmaks_eastus
[root@skvcentos ~]#

13. Create a storage account using the following command format:

az storage account create --resource-group <name of the resource


group>
--name <name of the storage account>
--sku <SKU of the storage account>

Example output:

[root@skvcentos ~]# az storage account create


--resource-group MC_dctm_dctmaks_eastus
name dctmstorageacc --sku Standard_LRS
{
"accessTier": null,
"creationTime": "2018-11-26T06:11:58.380457+00:00",
"customDomain": null,
"enableHttpsTrafficOnly": false,
"encryption": {
"keySource": "Microsoft.Storage",
"keyVaultProperties": null,
"services": {
"blob": {
...
...
[root@skvcentos ~]#

14. Create a storage class, a YAML file (for example, azstorageclass.yaml with
appropriate values for the parameters), and apply the configuration.
A storage class is used to define how an Azure file share is created. A storage
account can be specified in the class.
Different types of storage are:

• Locally-redundant storage (LRS): A simple, low-cost replication strategy.


Data is replicated within a single storage scale unit.
• Zone-redundant storage (ZRS): Replication for high availability and
durability. Data is replicated synchronously across three availability zones.
• Geo-redundant storage (GRS): Cross-regional replication to protect against
region-wide unavailability.
• Read-access geo-redundant storage (RA-GRS): Cross-regional replication
with read access to the replica.

a. Create a storage class using the following command format:

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: azurefile
provisioner: kubernetes.io/azure-file

90 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
3.2. Deploying and configuring Documentum Server on Microsoft Azure cloud platform

mountOptions:
- dir_mode=0777 (refers to permission mode)
- file_mode=0777
- uid=1000 (refers to the user id of the Documentum
installation owner)
- gid=1000
parameters:
skuName: Standard_LRS
storageAccount: <name of the created storage account>
b. Apply the configuration to a resource using the name of the YAML file
using the following command format:
kubectl apply -f <name of the YAML file>.yaml

Example output:
[root@skvcentos ~]# kubectl apply -f azstorageclass.yaml
storageclass.storage.k8s.io/azurefile created

Resource is created if it does not exist yet. Ensure that you specify the
resource name.
15. Create the cluster role, cluster binding, a YAML file (for example, azure-pvc-
roles.yaml with appropriate values for the parameters), and apply the
configuration.
AKS clusters use Kubernetes RBAC to limit actions that can be performed. Roles
define the permissions to grant and bindings apply them to the desired users.

a. Create the cluster role using the following command format:


apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRole
metadata:
name: system:azure-cloud-provider
rules:
- apiGroups: ['']
resources: ['secrets']
verbs: ['get','create']
b. Create the cluster binding using the following command format:
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
name: system:azure-cloud-provider
roleRef:
kind: ClusterRole
apiGroup: rbac.authorization.k8s.io
name: system:azure-cloud-provider
subjects:
- kind: ServiceAccount
namespace: kube-system
name: persistent-volume-binder
c. Apply the configuration to a resource using the name of the YAML file
using the following command format:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 91


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

kubectl apply -f <name of the YAML file>.yaml

Example output:

[root@skvcentos ~]# kubectl apply -f azure-pvc-roles.yaml


clusterrole.rbac.authorization.k8s.io/system:azure-cloud-
provider
created
clusterrolebinding.rbac.authorization.k8s.io/system:azure-
cloud-provider
created
[root@skvcentos ~]#

Resource is created if it does not exist yet. Ensure that you specify the
resource name.

16. Create a persistent volume claim, a YAML file (for example, azure-pvc-roles.
yaml with appropriate values for the parameters), and apply the configuration.
A persistent volume claim (PVC) uses the storage class object to dynamically
provision an Azure file share.
Create a persistent volume claim using the following command format:

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: nfs-volume-claim (refers to volume claim)
spec:
accessModes:
- ReadWriteMany
storageClassName: azurefile
resources:
requests:
storage: 100Gi

Example output:

[root@skvcentos ~]# kubectl apply -f azure-file-pvc.yaml


persistentvolumeclaim/nfs-volume-claim created

[root@skvcentos ~]# kubectl get pvc


NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE
nfs-volume-claim Pending azurefile 5s

[root@skvcentos ~]# kubectl get pvc


NAME STATUS VOLUME CAPACITY
ACCESS MODES STORAGECLASS AGE
nfs-volume-claim Bound pvc-2b17c86b-f144-11e8-a3d7-828b27cd3822
100Gi
RWX azurefile 10s
[root@skvcentos ~]#

17. Create new role assignment for a user, group, or service principal using the
following command format:

92 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
3.2. Deploying and configuring Documentum Server on Microsoft Azure cloud platform

az role assignment create


--assignee $CLIENT_ID
--role Reader
--scope $ACR_ID

Example output:

az role assignment create


--assignee 24a416a4-2312-47af-ab54-ccfaa333b688
--role Reader
--scope /subscriptions/c0b06162-314b-449a-9c97-
c7f8645e8cc0/resourceGroups/dctm/providers/
Microsoft.ContainerRegistry/registries/dctmcr

18. Load the image into Azure.

a. Verify if Docker daemon or server is running on the local system or server


using the following command format:

sudo /usr/bin/dockerd --insecure-registry


<registry_ip : registry_port>
--insecure-registry <registry_ip : registry_port>
-H unix:///var/run/docker.sock --init 2>&1 &

Example output:

sudo /usr/bin/dockerd --insecure-registry 10.194.42.173:5000


--insecure-registry 10.8.176.180:5000
--insecure-registry 10.8.146.181:80
--insecure-registry 10.8.176.180:5000
--insecureregistry 10.9.56.50:80
--insecure-registry dctmcr.azurecr.io
--insecure-registry 10.9.57.7 -H unix:///var/run/docker.sock
--init 2>&1 &
b. Download or pull the image into the local registry using the following
command format:

docker pull
<10.8.176.180:5000/contentserver/centos/stateless/
cs:16.4.0100.0150>

Example output:

[root@csazure ~]# docker pull


16.4.0100.0150: Pulling from contentserver/centos/
stateless/cs
256b176beaff: Pull complete
fff58857e6a6: Pull complete
8180823e9cbd: Pull complete
b0b2b563b195: Pull complete
26aa433e4325: Pull complete
22d5939fd717: Pull complete
4cc820e77a67: Pull complete
fbf522c2ac97: Pull complete
0e3bfa118948: Pull complete

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 93


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

ad0a41aa39d0: Pull complete


c6256484ce4f: Downloading [===>
112.1MB/1.482GB
1bbeba7bc6bb: Download complete
c. Tag the image to the Azure registry specific image using the following
command format:

docker tag <source image> <destination image>

Example output:

[root@csazure ~]# docker pull


10.8.176.180:5000/contentserver/centos/stateless/
cs:16.4.0100.0150
dctmcr.azurecr.io/contentserver/centos/stateless/
cs:16.4.0100.0150
d. Log in the Azure container registries if not already logged in using the
following command format:

az acr login --name <azure container registry>

Example output:

[root@csazure ~]# az acr login --name dctmcr


Login Succeeded
WARNING! Your password will be stored unencrypted in
/root/.docker/config.json.
Configure a credential helper to remove this warning.
[root@csazure ~]#
e. Push the image to the Azure Container Registry (ACR) using the following
command format:

docker push <image>

Example output:

[root@csazure ~]# docker push


dctmcr.azurecr.io/contentserver/centos/stateless/
cs:16.4.0100.0150
The push refers to repository
[dctmcr.azurecr.io/contentserver/centos/stateless/cs]
55d9a89a5421: Pushed
2dea5cbbbcc2: Pushing [===>]
1.002GB/2.062GB
6bd9de9900c6: Pushed
d67c7dc8673c: Pushed
255f0292e611: Pushed
fa7f7298db17: Pushed
05e72c68ac14: Layer already exists
e448fb1da7d5: Layer already exists
5c1bb4d51f07: Layer already exists
730720397169: Layer already exists
0bf1949d4323: Layer already exists
1d31b5806ba4: Layer already exists

94 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
3.2. Deploying and configuring Documentum Server on Microsoft Azure cloud platform

19. Download the Documentum Server Image (CentOS only) and Helm Chart TAR
files from OpenText My Support.

3.2.2 Deploying Documentum Server on Microsoft Azure


cloud platform
1. Install the Documentum Server Image (CentOS only) in the same namespace
where the PostgreSQL database is installed.
Load the Documentum Server Image into the Docker registry using the
following command format and update the exact Documentum Server Image
name:

docker load -i <TAR file name of Documentum Server image>

2. Extract the Helm Charts TAR file to a temporary location.

3. Open the cs-secrets/values.yaml file and provide the appropriate values for
the variables depending on your environment to pass them to your templates.

4. Store the secret values using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name cs-secrets /opt/temp/Helm-charts/cs-secrets


--tiller-namespace docu --namespace docu

5. Verify the status of the stored secret values file using the following command
format:

helm status <release name> --tiller-namespace <name of namespace>

6. Open the db/values.yaml file and provide the appropriate values for the
variables depending on your environment to pass them to your templates.

7. Deploy the database Helm using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name db /opt/temp/Helm-charts/db --tiller-


namespace docu --namespace docu

8. Verify the status of the database Helm deployment using the following
command format:

helm status <release name> --tiller-namespace <name of namespace>

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 95


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

9. Verify the status of the deployment of database pod using the following
command format:

kubectl describe pods <name of the pod>

10. Open the docbroker/values.yaml file and provide the appropriate values for
the variables depending on your environment to pass them to your templates.

11. Deploy the connection broker Helm using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name docbroker /opt/temp/Helm-charts/docbroker --


tiller-namespace docu --namespace docu

12. Verify the status of the connection broker Helm deployment using the following
command format:

helm status <release name> --tiller-namespace <name of namespace>

13. Verify the status of the deployment of connection broker pod using the
following command format:

kubectl describe pods <name of the pod>

14. Open the content-server/values.yaml file and provide the appropriate


values for the variables depending on your environment to pass them to your
templates.

15. Deploy the Documentum Server Helm in your Kubernetes environment using
the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name content-server /opt/temp/Helm-charts/content-


server --tiller-namespace docu --namespace docu

16. Verify the status of the deployment of Documentum Server Helm using the
following command format:

helm status <release name> --tiller-namespace <name of namespace>

17. Verify the status of the deployment of Documentum Server pod using the
following command format:

kubectl describe pods <name of the pod>

96 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
3.2. Deploying and configuring Documentum Server on Microsoft Azure cloud platform

18. Open the cs-dfc-properties/values.yaml file and provide the appropriate


values for the variables depending on your environment to pass them to your
templates.

19. Deploy the Documentum Server DFC properties Helm in your Kubernetes
environment using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name cs-dfc-properties /opt/temp/Helm-charts/cs-


dfc-properties --tiller-namespace docu --namespace docu

20. Verify the status of the deployment of Documentum Server DFC properties
Helm using the following command format:

helm status <release name> --tiller-namespace <name of namespace>

3.2.3 Configuring external IP address


1. Install the ingress controller that uses ConfigMap to store the nginx
configuration using the following command format:

helm install stable/nginx-ingress --namespace <name of namespace>

Ingress controller is an assembly of a configuration file (nginx.conf). The main


requirement is the need to reload nginx after you make any changes to the
configuration file. For example:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: nginx-d2
annotations:
nginx.ingress.kubernetes.io/affinity: "cookie"
nginx.ingress.kubernetes.io/session-cookie-hash: "sha1"
spec:
rules:
- host: d2-aks-ingress.eastus.cloudapp.azure.com
<dns name generated with external IP address>
http:
paths:
- backend:
serviceName: d2csd2config
servicePort: 8080
path: /D2-Config
- backend:
serviceName: d2csd2client
servicePort: 8080
path: /D2

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 97


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

2. Configure an FQDN for the public IP address of your ingress controller. Map
the external IP address to the DNS name using the Bash script. Use the
following command format:

#!/bin/bash

# Public IP address of your ingress controller


IP="<IP address>"

# Name to associate with public IP address


DNSNAME="<dns name>"

# Get the resource-id of the public ip


PUBLICIPID=$(az network public-ip list
--query "[?ipAddress!=null]|[?contains(ipAddress, '$IP')].[id]"
--output tsv)

# Update public ip address with DNS name


az network public-ip update --ids $PUBLICIPID --dns-name $DNSNAME

3.2.4 Limitations
• Host name must have the fully qualified domain name (FQDN) and must not be
greater than 59.
• You must change the storage class as per the Azure Kubernetes service offering.
The default storage class provisions a standard Azure disk while the managed-
premium storage class provisions a premium Azure disk.
• To use Postgres as service, you must create the database used for the installing
the repository. Update the fields as follows:

docbase:
name: <docbase owner>
id: <docbase id>
existing: true
index:
<respective index value>
• Only HTTP configuration is supported for jmsProtocol and tnsProtocol.

3.2.5 Troubleshooting

98 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide


EDCSYCD160700-IGD-EN-02
3.3. Deploying and configuring Documentum Administrator on Microsoft Azure cloud platform

Symptom Cause Fix


When you configure Azure Failure to connect to the Use the export command as
on a Linux VM, it results in server. follows:
the [root@skvcentos ~]#
az aks browse export
--resource-group dctm https_proxy=<proxy_va
--name dctmaks Merged lue>:<port>
"dctmaks" as current
context in /tmp/
tmpdr1aC2 Unable to
connect to the server:
proxyconnect tcp: tls:
oversized record
received with length
20527 error.

3.3 Deploying and configuring Documentum


Administrator on Microsoft Azure cloud platform
3.3.1 Prerequisites
1. Perform all the steps as described in “Deploying and configuring Documentum
Server on Microsoft Azure cloud platform” on page 85 except for those steps
related to the PostgreSQL database.

2. Download the Documentum Administrator Image (CentOS only) and Helm


Chart TAR files from OpenText My Support.

3.3.2 Deploying Documentum Administrator on Microsoft


Azure cloud platform
The information for deploying and configuring Documentum Administrator on
Microsoft Azure is same as described in “Deploying Documentum Server on
Microsoft Azure cloud platform” on page 95 except for those steps related to the
PostgreSQL database. Ensure that you install the Documentum Administrator Image
(CentOS only) and Helm Chart TAR files.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 99


EDCSYCD160700-IGD-EN-02
Chapter 3 Deploying Documentum Platform and Platform Extensions applications on
Microsoft Azure cloud platform

3.3.3 Limitations
There are no limitations for this release.

3.3.4 Troubleshooting
There are no troubleshooting information for this release.

3.4 Deploying and configuring Documentum REST


Services on Microsoft Azure cloud platform
3.4.1 Prerequisites
The prerequisites information for deploying and configuring Documentum REST
Services on Microsoft Azure is same as described in “Prerequisites” on page 85 of
“Deploying and configuring Documentum Server on Microsoft Azure cloud
platform” on page 85.

3.4.2 Deploying Documentum REST Services on Microsoft


Azure cloud platform
The information for deploying and configuring Documentum REST Services on
Microsoft Azure is same as described in “Deploying and configuring Documentum
REST Services on private cloud” on page 77.

3.4.3 Configuring external IP address


The information for configuring external IP address on Microsoft Azure is same as
described in “Configuring external IP address” on page 97.

3.4.4 Limitations
There are no limitations for this release.

3.4.5 Troubleshooting
There are no troubleshooting information for this release.

100 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
Chapter 4
Deploying Documentum Platform and Platform
Extensions applications on Google Cloud Platform

4.1 Supported applications versions


The Release Notes document contains the information about the list of applications
and its supported versions.

4.2 Deploying and configuring Documentum Server


on Google Cloud Platform
4.2.1 Prerequisites
Ensure that you complete the following activities before you deploy Documentum
Server on Google Cloud Platform (GCP) environment:

1. Download and configure the Docker application from the Docker website.
Docker Documentation contains detailed information.
2. Download and configure the Helm (client) and Tiller (server) application from
the Helm website in the cluster namespace (your Cloud Shell machine).
Helm Documentation contains detailed information.
3. Download and configure the Kubernetes application from the Kubernetes
website.
Kubernetes Documentation contains detailed information.
4. Download and configure the PostgreSQL database (server) from the
PostgreSQL website.

Note: The PostgreSQL database client is packaged with Documentum


Server Image.

PostgreSQL Documentation contains more information.


5. Download the install the latest version of Google Cloud SDK from GCP website
on your machine which includes gcloud command line utility.
6. Create a Google Kubernetes Engine (GKE) and a namespace within the cluster.

a. From the GCP website, select the GCP project linked with your corporate
billing account.
b. Create a cluster. Navigate to Kubernetes Engine > Clusters, click CREATE
CLUSTER, and perform the following:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 101
EDCSYCD160700-IGD-EN-02
Chapter 4 Deploying Documentum Platform and Platform Extensions applications on
Google Cloud Platform

• Select a standard cluster template.


• Provide a name to your cluster. For example, demo-cluster.
• Select Zonal for the location type. You can use Regional for production
grade - high available clusters.
• Select a Zone closer to your location. The Google Cloud Platform
website contains the list of zones.
• Review the number of nodes for your cluster and the machine type for
each of your nodes. For example, three nodes with 2vCPUs/7.5 GB
memory for each node.

Click Create.
c. Click Connect next to the cluster you created and then click Run in Cloud
Shell.
A Google Cloud shell (a VM created by Google with pre-installed Kubectl
and gcloud SDK) is created.
d. Press Enter at the command that shows up.
Cluster credentials are fetched and creates a kubeconfig entry (the
kubectl configuration file).
e. Create a Kubernetes cluster namespace on the Cloud shell using the
following command format:

kubectl create namespace <name of namespace>


f. Verify if the namespace is created using the following command format:

kubectl get namespace

7. Upload the Docker images to Google Container Registry (GCR).

a. Configure Docker to use gcloud as a credential helper using the following


command format:

gcloud auth configure-docker


b. Tag your Docker images using the following command format:

[HOSTNAME]/[PROJECT-ID]/[IMAGE]

For example:

gcr.io/documentum-d2-product/contentserver/
centos/stateless/cs:16.4.0120
c. Load the tagged image to GCR. For example:

docker push gcr.io/documentum-d2-product/contentserver/


centos/stateless/cs:16.4.0120

8. Create Role-based access control (RBAC) configurations for Helm and Tiller.

a. Create a service account for Tiller in the namespace using the following
command format:

102 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
4.2. Deploying and configuring Documentum Server on Google Cloud Platform

kubectl create serviceaccount tiller --namespace demo


b. Provide the cluster-admin privileges to the Tiller service account using a
clusterrolebinding so that Tiller can deploy the resources onto the cluster
using the following command format:
kubectl create clusterrolebinding tiller-admin-binding --
clusterrole=cluster-admin --serviceaccount=demo:tiller

Notes

• Your email account (for example, abc@xyz.com) may additional


permissions to create the clusterrolebinding object. For example,
you must have the Owner role in the Identify & Access Management
(IAM) and Admin sections in Google Cloud Console.
• The Tiller service account must have permissions only in the
namespace in which it is deployed. However, to use this Tiller to
deploy the nfs-client-provisioned Helm Chart later, which
creates cluster-scoped resources like clusterroles,
clusterrolebindings and storageclasses, you must provide the
cluster-admin privilege to the Tiller service account.
c. After downloading and installing Helm (client) and Tiller (server), perform
the following:

i. Initialize Helm and Tiller using the following command format:


./helm init --service-account tiller --tiller-namespace
demo
ii. Verify if Tiller is deployed in the namespace using the following
command format:
<user id>@cloudshell:~ (dctm-d2)$ kubectl get pods -n
<name of namespace>
iii. Verify the version of Helm and Tiller using the following command
format:
abc@cloudshell:~ (dctm-d2)$ ./helm version --tiller-
namespace <name of namespace>

Example output:
Client: &{SemVer:"v2.11.0",
GitCommit:"2e55dbe1fdb5fdb96b75ff144a339489417b146b",
GitTreeState:"clean"}

Server:
&{SemVer:"v2.11.0",
GitCommit:"2e55dbe1fdb5fdb96b75ff144a339489417b146b",
GitTreeState:"clean"}

9. Create a Google Cloud Filestore instance.


In Filestore of Google Cloud Platform dashboard, click CREATE INSTANCE,
and perform the following:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 103
EDCSYCD160700-IGD-EN-02
Chapter 4 Deploying Documentum Platform and Platform Extensions applications on
Google Cloud Platform

• Provide a name to the Google Cloud Filestore instance. For example, demo-
gcfss.
• Select a standard cluster template.
• Select the default authorized network.
• Select your region and zone for the Location type for better performance.
• Select the NFS mount point for the Fileshare name. For example, demogcfs.
• Provide a minimum of 1 TB for Fileshare Capacity.

Google Cloud Filestore need not be created every time. The Google Cloud
Filestore instance can be shared by multiple clusters.
Once the Google Cloud Filestore instance is created, click the instance and note
the IP address and path of the instance.

Note: The instance tier of the Google Cloud Filestore instance cannot be
modified once it is created. However, the Fileshare Capacity can be
modified.

10. Deploy an external storage provisioner (nfs-client-provisioner) for dynamic


provisioning of ReadWriteMany (RWX) Persistent Volumes (PVs) on Google
Cloud Filestore instance.

a. Download the external nfs-client-provisioner Helm Chart from the Github


website to your Cloud Shell machine.
b. Install the nfs-client-provisioner Helm Chart by passing the nfs.server
value as the IP address of the Google Cloud Filestore instance, the
nfs.path value as the path given in the Google Cloud Filestore instance
and storageClass.name value. For example, gcp-rwx.ReadWriteMany
Persistent Volume Claims should be created with this storageClassName
for ReadWriteMany Persistent Volumes.
Example output:

abc@cloudshell:~ (dctm-d2)$ ./helm install


--name demo-nfs-client-provisioner ./nfs-client-provisioner/
--namespace demo
--tiller-namespace demo
--set nfs.server="10.91.118.66"
--set nfs.path=/demogcfs
--set storageClass.name=gcp-rwx
NAME: demo-nfs-client-provisioner
LAST DEPLOYED: Sun Jun 9 11:52:05 2019
NAMESPACE: demo
STATUS: DEPLOYED

RESOURCES:
==> v1/Deployment
NAME AGE
demo-nfs-client-provisioner 1s

104 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
4.2. Deploying and configuring Documentum Server on Google Cloud Platform

==> v1/Pod(related)
NAME READY...
demo-nfs-client-provisioner-76986844 0/1...

==> v1/StorageClass

NAME AGE
gcp-rwx 1s

==> v1/ServiceAccount
demo-nfs-client-provisioner 1s

==> v1/ClusterRole
demo-nfs-client-provisioner-runner 1s

==> v1/ClusterRoleBinding
run-demo-nfs-client-provisioner 1s

==> v1/Role
leader-locking-demo-nfs-client-provisioner 1s

==> v1/RoleBinding
leader-locking-demo-nfs-client-provisioner 1s

11. Create a sample PVC (for example, testPVC.yaml) to test the dynamic
provisioning of ReadWriteMany (RWX) PVs using the following command
format:

kind: PersistentVolumeClaim
apiversion: v1
metadata:
name: test-claim
spec:
accessModes:
- ReadWriteMany
storageClassName: gcp-rwx
resources:
requests:
storage: 1Mi

12. Verify if the corresponding Persistent Volume is created using the following
command format:

$ kubectl get pv

Ensure the status of PV is Bound.

13. Delete the PVC and check if the PV is also deleted.

14. Download the Documentum Server Image (CentOS only) and Helm Chart TAR
files from OpenText My Support.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 105
EDCSYCD160700-IGD-EN-02
Chapter 4 Deploying Documentum Platform and Platform Extensions applications on
Google Cloud Platform

4.2.2 Deploying Documentum Server on Google Cloud


Platform
1. Install the Documentum Server Image (CentOS only) in the same namespace
where the PostgreSQL database is installed.
Load the Documentum Server Image to Google Container Registry and update
the exact Documentum Server Image name.

2. Upload the Documentum Server Image to Google Container Registry.

3. Update the image and tag fields in the values.yaml files of your Helm Charts
to point to the GCR images. For example:

images:
repository: gcr.io
contentserver:
name: <name of Documentum product>/contentserver/centos/
stateless/cs
tag: <build number/version of Documentum product>

4. Update the storageClass fields in the values.yaml files of Persistent Volume


with ReadWriteMany access mode and Volume Claim Template with
ReadWriteOnce access mode using the following command format:

persistentVolume:
csdataPVCName: documentum-data-pvc
pvcAccessModes: ReadWriteMany
size: 3 Gi

volumeClaimTemplate:
vctName: documentum-vct
vctAccessModes: ReadWriteOnce
size: 1 Gi
storageclass: standard

5. Open the cs-secrets/values.yaml file and provide the appropriate values for
the variables depending on your environment to pass them to your templates.

6. Store the secret values using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name cs-secrets /opt/temp/Helm-charts/cs-secrets


--tiller-namespace docu --namespace docu

7. Verify the status of the stored secret values file using the following command
format:

helm status <release name> --tiller-namespace <name of namespace>

106 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
4.2. Deploying and configuring Documentum Server on Google Cloud Platform

8. Open the db/values.yaml file and provide the appropriate values for the
variables depending on your environment to pass them to your templates.

9. Deploy the database Helm using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name db /opt/temp/Helm-charts/db --tiller-


namespace docu --namespace docu

10. Verify the status of the database Helm deployment using the following
command format:

helm status <release name> --tiller-namespace <name of namespace>

11. Verify the status of the deployment of database pod using the following
command format:

kubectl describe pods <name of the pod>

12. Open the docbroker/values.yaml file and provide the appropriate values for
the variables depending on your environment to pass them to your templates.

13. Deploy the connection broker Helm using the following command format:

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name docbroker /opt/temp/Helm-charts/docbroker --


tiller-namespace docu --namespace docu

14. Verify the status of the connection broker Helm deployment using the following
command format:

helm status <release name> --tiller-namespace <name of namespace>

15. Verify the status of the deployment of connection broker pod using the
following command format:

kubectl describe pods <name of the pod>

16. Open the content-server/values.yaml file and provide the appropriate


values for the variables depending on your environment to pass them to your
templates.

17. Deploy the Documentum Server Helm in your Kubernetes environment using
the following command format:

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 107
EDCSYCD160700-IGD-EN-02
Chapter 4 Deploying Documentum Platform and Platform Extensions applications on
Google Cloud Platform

helm install --name <release name> <location where Helm Chart


TAR files are extracted>/docbroker --tiller-namespace <name of
namespace> --namespace <name of namespace>

For example:

helm install --name content-server /opt/temp/Helm-charts/content-


server --tiller-namespace docu --namespace docu

18. Verify the status of the deployment of Documentum Server Helm using the
following command format:

helm status <release name> --tiller-namespace <name of namespace>

19. Verify the status of the deployment of Documentum Server pod using the
following command format:

kubectl describe pods <name of the pod>

20. Download the NGINX (Ingress Controller) Helm from the Github website.
Ingress consists of two components:

• Ingress Resource: Collection of rules for the inbound traffic to reach Services.
These are Layer 7 (L7) rules that allow hostnames (and optionally paths) to
be directed to specific Services in Kubernetes.
• Ingress Controller: Acts upon the rules set by the Ingress Resource, typically
via an HTTP or L7 load balancer.

21. Deploy the NGINX Ingress Controller Helm using the following command
format:

helm install --name <name of namespace>-nginx-ingress


<location where Helm Chart TAR files are extracted>
--set rbac.create=true --tiller-namespace <name of namespace>
--namespace <name of namespace>

For example:

helm install --name demo-nginx-ingress stable/nginx-ingress


--set rbac.create=true --tiller-namespace demo --namespace demo

NAME: demo-nginx-ingress
LAST DEPLOYED: Sun Jun 9 15:48:55 2019
NAMESPACE: demo
STATUS: DEPLOYED

RESOURCES:
==> v1beta1/ClusterRoleBinding
NAME AGE
demo-nginx-ingress 0s

==> v1beta1/Role
demo-nginx-ingress 0s

108 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
4.2. Deploying and configuring Documentum Server on Google Cloud Platform

==> v1/Service
demo-nginx-ingress-controller 0s
demo-nginx-ingress-default-backend 0s

==> v1/ConfigMap
demo-nginx-ingress-controller 0s

==> v1/ServiceAccount
demo-nginx-ingress 0s

==> v1beta1/ClusterRole
demo-nginx-ingress 0s

==> v1beta1/RoleBinding
demo-nginx-ingress 0s

==> v1beta1/Deployment
demo-nginx-ingress-controller 0s
demo-nginx-ingress-default-backend 0s

==> v1/Pod(related)
...
NAME READY...
demo-nginx-ingress-controller-78cd47cf46-cw9q2 0/1...
demo-nginx-ingress-default-backend-5d47879fb7-5lptf 0/1...

The nginx-ingress controller is installed. It may take a few minutes for the
LoadBalancer IP to be available.

22. Verify the status of the NGINX Ingress Controller Helm deployment using the
following command format:

kubectl --namespace <name of namespace> get services -o wide -w


demo-nginx-ingress-controller

Example ingress that takes control of the controller:

apiVersion: extensions/vibeta1
kind: Ingress
metadata:
annotations:
kubernetes.io/ingress.class: nginx
name: example
namespace: test
spec:
rules:
- host: www.example.com
http:
paths:
- backend:
serviceName: exampleService
serviceport: 80
path: /

The following code is required only if TLS is enabled for the

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 109
EDCSYCD160700-IGD-EN-02
Chapter 4 Deploying Documentum Platform and Platform Extensions applications on
Google Cloud Platform

Ingress:
tls:
- hosts:
- www.example.com
secretName: example-tls

23. (Optional) If TLS is enabled for the Ingress, you must provide a Secret
containing the certificate and key using the following command format:

apiversion: v1
kind: Secret
metadata:
name: example-tls
namespace: test
data:
tls.cert: <base64 encoded certificate>
tls.key: <base64 encoded key>
type: kubernetes.io/tls

24. Install a single host simple fan-out Ingress resource Helm to route the traffic to
the cluster-internal services using the following command format:

helm install --name <name of Ingress resource> ./helm-charts-


demo/documentum-ingress --tiller-namespace <name of namespace> --
namespace <name of namespace>

For example:

NAME: dctm-common-ingress
LAST DEPLOYED: Sun Jun 9 15:55:47 2019
NAMESPACE: demo
STATUS: DEPLOYED

RESOURCES:
==> v1beta1/Ingress
NAME AGE
dctm-common-ingress 0s

25. The Ingress Resource determines the controller that is utilized to serve traffic.
Set the Ingress annotation to select the NGINX ingress controller. This is set
with an annotation, kubernetes.io/ingress.class, in the metadata section of
the Ingress Resource.
For example:

annotations:
kubernetes.io/ingress.class nginx

26. Update the documentum-ingress/templates/ingress.yaml file.


Sample ingress.yaml file with example values:

#Source: documentum-ingress/templates/ingress.yaml
#Single Host path based fan-out Ingress

apiVersion: extensions/v1beta1
kind: Ingress

110 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
4.2. Deploying and configuring Documentum Server on Google Cloud Platform

metadata:
name: dctm-common-ingress
annotations:
kubernetes.io/ingress.class: nginx
nginx.ingress.kubernetes.io/affinity: cookie
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-connect-timeout: "1200"
nginx.ingress.kubernetes.io/proxy-read-timeout: "1200"
nginx.ingress.kubernetes.io/proxy-send-timeout: "1200"
nginx.ingress.kubernetes.io/session-cookie-hash: sha1
nginx.ingress.kubernetes.io/ssl-redirect: "false"

spec:
rules:

# -host: <ingress-host>
- http:
paths:

- backend:
serviceName: documentum-apphost-cip-service
servicePort: 8080
path: /

- backend:
serviceName: documentum-xda
servicePort: 7000
path: /xda

- backend:
serviceName: documentum-da
servicePort: 8080
path: /da

- backend:
serviceName: documentum-webtop
servicePort: 9000
path: /webtop

- backend:
serviceName: documentum-server-jms-service
servicePort: 9080
path: /DmMethods

- backend:
serviceName: documentum-server-jms-services
servicePort: 9080
path: /bpm

- backend:
serviceName: documentum-server-jms-service
servicePort: 9080
path: /dmotdsrest

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 111
EDCSYCD160700-IGD-EN-02
Chapter 4 Deploying Documentum Platform and Platform Extensions applications on
Google Cloud Platform

27. Perform the following to access the Documentum applications deployed inside
the Kubernetes environment from outside:

a. Obtain the external IP address of the load balancer service of the NGINX
Ingress controller using the following command format:

kubectl get svc | grep <name of the ingress controller>


b. Access the Documentum application using the external IP address of the
NGINX Ingress controller load balancer service in a browser using the
following URL format:

http://<external IP address of NGINX Ingress controller load


balancer service>/<documentum application>

If you are trying to access the Documentum Webtop application in a browser,


use the following URL format:

1 http://<external IP address of NGINX Ingress controller load


balancer service>/webtop

Depending on the Ingress resource rule you have set in Step 26 for accessing
Documentum Webtop, the URL redirects you to the Documentum Webtop login
page.

4.2.3 Limitations
• External storage provisioners limitation. For deploying Documentum products,
you need the capability to dynamically provision both ReadWriteOnce (RWO)
Persistent Volumes (PVs) and ReadWriteMany (RWX) Persistent Volumes (PVs).
Cloud providers provide the built-in provisioner to dynamically provision the
ReadWriteOnce Persistent Volumes. For example, in Google Cloud Platform, if
you specify the storageclass as standard in the Persistent volume Claim (PVC),
then Google Cloud Platform automatically creates a Persistent Volume of
requested size using Google Compute Engine Persistent Disk. However, the
Google Compute Engine Persistent Disk does not support ReadWriteMany
operation, and hence you have to provision a Google Cloud Filestore instance
and external provisioner to dynamically manage the Persistent Volumes for
ReadWriteMany Persistent Volume Claims.
• In order to achieve ingress in Google Cloud Platform or GKE Kubernetes cluster,
Google Cloud Platform Google Cloud Load Balancer (GCLB) L7 Load balancer is
not used as this Google Cloud Platform GCBL L7 load balancer does not
communicate to services of the ClusterIP type on the backend. Use NGINX
Ingress controller to achieve Ingress in a GKE cluster. Google Documentation
contains more information about Ingress with NGINX controller on GKE.

112 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
4.3. Deploying and configuring Documentum Administrator on Google Cloud Platform

4.2.4 Troubleshooting
There are no troubleshooting information for this release.

4.3 Deploying and configuring Documentum


Administrator on Google Cloud Platform
4.3.1 Prerequisites
Perform all the steps as described in “Prerequisites” on page 101 in “Deploying and
configuring Documentum Server on Google Cloud Platform” on page 101 except for
those steps related to the PostgreSQL database. Ensure that you download and
install the Documentum Administrator Image (CentOS only) and Helm Chart TAR
files from OpenText My Support.

4.3.2 Deploying Documentum Administrator on Google Cloud


Platform
1. Deploy and configure Documentum Administrator on Google Cloud Platform
using the same steps as described in “Deploying Documentum Server on
Google Cloud Platform” on page 106.

2. Update the ingress resource rule for Documentum Administrator as described


in the sample ingress.yaml file in Step 26 in “Deploying Documentum Server
on Google Cloud Platform” on page 106 with the correct port details.

3. Enable the ingress resource rule for Documentum Administrator using the
following command format:

kubectl apply -f ingress.yaml

4. Obtain the external IP address of the load balancer service of the NGINX
Ingress controller using the following command format:

kubectl get svc | grep <name of the ingress controller>

5. Access the Documentum Administrator application using the external IP


address of the NGINX Ingress controller load balancer service in a browser
using the following URL format:

http://<external IP address of NGINX Ingress controller load


balancer service>/da

The URL redirects you to the Documentum Administrator login page.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 113
EDCSYCD160700-IGD-EN-02
Chapter 4 Deploying Documentum Platform and Platform Extensions applications on
Google Cloud Platform

4.3.3 Limitations
There are no limitations for this release.

4.3.4 Troubleshooting
There are no troubleshooting information for this release.

4.4 Deploying and configuring Documentum REST


Services on Google Cloud Platform
4.4.1 Prerequisites
Perform the same steps as described in “Prerequisites” on page 101 in “Deploying
and configuring Documentum Server on Google Cloud Platform” on page 101.

4.4.2 Deploying Documentum REST Services on Google


Cloud Platform
1. Deploy and configure Documentum REST Services on Google Cloud Platform
using the same steps as described in “Deploying Documentum Server on
Google Cloud Platform” on page 106.
2. Update the rest-ingress.yaml file.
Sample rest-ingress.yaml file with example values:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: dctm-common-ingress
annotations:
kubernetes.io/ingress.class: nginx
nginx.ingress.kubernetes.io/affinity: cookie
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-connect-timeout: "1200"
nginx.ingress.kubernetes.io/proxy-read-timeout: "1200"
nginx.ingress.kubernetes.io/proxy-send-timeout: "1200"
nginx.ingress.kubernetes.io/session-cookie-hash: sha1
nginx.ingress.kubernetes.io/ssl-redirect: "false"

spec:
rules:

- http:

paths:

- backend:
serviceName: <Documentum REST Services service name>
servicePort: 8080
path: /dctm-rest

114 OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide
EDCSYCD160700-IGD-EN-02
4.4. Deploying and configuring Documentum REST Services on Google Cloud Platform

3. Enable the ingress resource rule for Documentum REST Services using the
following command format:

kubectl apply -f rest-ingress.yaml

4. Obtain the external IP address of the load balancer service of the NGINX
Ingress controller using the following command format:

kubectl get svc | grep <name of the ingress controller>

5. Access the Documentum REST Services application using the external IP


address of the NGINX Ingress controller load balancer service in a browser
using the following URL format:

http://<external IP address of NGINX Ingress controller load


balancer service>/dctm-rest

4.4.3 Limitations
There are no limitations for this release.

4.4.4 Troubleshooting
There are no troubleshooting information for this release.

OpenText Documentum Platform and Platform Extensions – Cloud Deployment Guide 115
EDCSYCD160700-IGD-EN-02

You might also like