Learn about container deployment options for Oracle Globally Distributed Database in Linux Containers.
Oracle Globally Distributed Database is a scalability and availability feature for custom-designed OLTP applications that enables the distribution and replication of data across a pool of Oracle Databases that do not share hardware or software. The pool of databases is presented to the application as a single logical database.
This project provides sample container files to facilitate installation, configuration, and environment setup for DevOps users. For more information about Oracle Database, see: Oracle Globally Distributed Database Management Documentation.
Review each of the sections of this README in the order given. After reviewing each section of the README, you can skip the image or container creation sections that do not apply to you.
This project offers example container files for the following:
- Oracle Global Service Manager (GSM/GDS) for Oracle Database 23ai FREE for Linux x86-64
- Oracle Global Service Manager (GSM/GDS) for Oracle 21c (21.3) for Linux x86-64
- Oracle Global Service Manager (GSM/GDS) for Oracle 19c (19.3) for Linux x86-64
To create an Oracle Globally Distributed Database Container environment, follow these steps:
- Oracle Globally Distributed Database in Linux Containers
- Overview of Oracle Globally Distributed Database in Linux Containers
- Using this Documentation
- Preparation Steps for running Oracle Globally Distributed Database in Linux Containers
- QuickStart
- Building Oracle Globally Distributed Database Container Images
- Getting Oracle Global Service Manager Image from Oracle Container Registry
- Building Oracle Global Service Manager Image
- Building Oracle Single Instance Database Image
- Building Extended Oracle Single Instance Database Image with Oracle Globally Distributed Database Feature
- Building Oracle RAC Database Container Image
- Building Extended Oracle RAC Database Container Image with Oracle Globally Distributed Database Feature
- Oracle Globally Distributed Database in Containers Deployment Scenarios
- Deploy Oracle Globally Distributed Database Containers
- Deploy Oracle Globally Distributed Database Containers on Podman using Oracle 23ai FREE Images
- Deploy Oracle Globally Distributed Database using Single Instance Database in Podman Containers
- Deploy Oracle Globally Distributed Database using Oracle Restart in Podman Containers
- Deploy Oracle Globally Distributed Database using Oracle RAC Database in Podman Containers
- Deploy Oracle Globally Distributed Database Containers on earlier OS Release
- Deploy Oracle Globally Distributed Database Containers
- Oracle Globally Distributed Database in Containers Deployment using podman-compose
- Oracle Globally Distributed Database in Containers Deployment using docker-compose
- Oracle Container Registry Images for Oracle Globally Distributed Database Deployment
- Support
- License
- Copyright
Note : All Steps or Commands in this guide must be run as root
or with a sudo
user.
- Before you proceed, complete the following prerequisites for your platform:
- If you are using Oracle Linux 8 or higher, then Install Podman.
- You must install and configure Podman release 4.9.4 or later or later on Oracle Linux 8.10 or later to run Oracle Globally Distributed Database on Podman.
- You need to install
podman-docker
utility using dnf command.# Enable the Oracle Linux 8 AppStream repository dnf config-manager --enable ol8_appstream # Install Podman and Podman-docker dnf install -y podman podman-docker
- If SELinux is enabled on podman host, then install the following package as well:
dnf install -y selinux-policy-devel
- If you are using
Older
Oracle Linux 7, then install Docker.- If you are using an older Oracle Linux 7 system, then you must install Docker Engine.
- Install
docker-engine
anddocker-cli
using yum command.yum-config-manager --enable ol7_addons yum install docker-engine docker-cli yum start docker systemctl enable --now docker
- If you are using Oracle Linux 8 or higher, then Install Podman.
Oracle recommends that you start with the Quickstart to become familiar with Oracle Globally Distributed Database in Linux Containers. See: QuickStart documentation.
After you become familiar with Oracle Globally Distributed Database in Linux Containers, you can explore more advanced setups, deployments, features, and so on, as explained in detail in Oracle Globally Distributed Database in Containers Deployment Scenarios.
Note:
- Ensure that you have enough space in
/var/lib/containers
while building the Oracle Globally Distributed Database images. Also, if required useexport TMPDIR=</path/to/tmpdir>
for Podman to refer to any other folder as the temporary podman cache location instead of the default/tmp
location.
IMPORTANT: Oracle Global Service Manager (GDS) container is useful when you want to configure the Global Data Service Framework. A Global Data Services framework consists of at least one global service manager, a Global Data Services catalog, and the GDS configuration databases.
IMPORTANT: If you want to use the Global Service Manager image (GSM image) of Oracle 23ai FREE version, you can download that directly from container-registry.oracle.com
using the link container-registry.oracle.com/database/gsm:latest
. To use with this GSM image, you can use the link container-registry.oracle.com/database/free:latest
to download the compatible database container image for Oracle Database 23ai Free.
Example of pulling these images from the Oracle Container Registry for Oracle Database 23ai FREE:
# For Oracle Database 23ai FREE Container Image
podman pull container-registry.oracle.com/database/free:latest
# For Oracle GSM Container Image of Oracle 23ai FREE version
podman pull container-registry.oracle.com/database/gsm:latest
NOTE Currently, latest tag in Oracle Container registry represents 23.7.0.0
tag. If you are pulling any other version of container image, then retag approriately as per your environment to use in podman create
commands later.
Example of pulling these images from the Oracle Container Registry for another version:
# For Oracle Database 19.25 RU Container Image
podman pull container-registry.oracle.com/database/enterprise_ru:19.25.0.0
# For Oracle GSM Container Image of Oracle 19.25 RU version
podman pull container-registry.oracle.com/database/gsm_ru:19.25.0.0
IMPORTANT: If you want to use pre-built images available on Oracle Container Registry for Oracle Database and Oracle GSM, make sure the version of openssl
in those images is compatible with the openssl
version on the machine where you will run the openssl commands to generated the encrypted password file during the deployment. Please refer to the section Oracle Container Registry Images for Oracle Globally Distributed Database Deployment.
To create an Oracle Global Service Manager image (GSM image) of another version, you must provide the installation binaries of Oracle Global Service Manager (GSM/GDS) for Oracle Database for Linux x86-64
for that version and put them into the containerfiles/<version>
folder. You only need to provide the binaries for the edition you are going to install. The binaries can be downloaded from the Oracle Technology Network. You must ensure that you have internet connectivity for the DNF package manager.
Note: Do not uncompress the binaries.
To assist with building the images, you can use the buildContainerImage.sh script.
The buildContainerImage.sh
script is just a utility shell script that performs MD5 checks. This script provides an easy way for beginners to get started. Expert users can directly call podman build
with their preferred set of parameters. Before you build the image, ensure that you have provided the installation binaries and put them into the right folder. In the below example, GSM Image of version 21.3.0
will be built. Go into the containerfiles folder and run the buildContainerImage.sh script as root
or with sudo
privileges:
./buildContainerImage.sh -v (Software Version)
./buildContainerImage.sh -v 21.3.0
For detailed usage information for buildContainerImage.sh
, run the following command:
./buildContainerImage.sh -h
Usage: buildContainerImage.sh -v [version] -t [image_name:tag] [-e | -s] [-i] [-o] [container build option]
It builds a container image for a DNS server
Parameters:
-v: version to build
-i: ignores the MD5 checksums
-t: user defined image name and tag (e.g., image_name:ta
-o: passes on container build option (e.g., --build-arg SLIMMIMG=true for slim)
LICENSE UPL 1.0
Copyright (c) 2014,2024 Oracle and/or its affiliates.
To build Oracle Globally Distributed Database using Single Instance Database containers, download the project files and build an Oracle Single Instance Database Image. See the Oracle Database Single Instance README.MD, which is available on the Oracle GitHub repository.
Note: Use the README.MD to create the image, and do not use the container instructions. For the container, use the steps given in this document under the Oracle Globally Distributed Database in Containers Deployment Scenarios section.
Building Extended Oracle Single Instance Database Image with Oracle Globally Distributed Database Feature
IMPORTANT: If you want to use the Extended Oracle Single Instance Database Image with Oracle Globally Distributed Database Feature of Oracle 23ai FREE version, you can download that directly from container-registry.oracle.com
using the link container-registry.oracle.com/database/free:latest
After creating the base image using buildContainerImage.sh
in the previous step, use the buildExtensions.sh
script that is under the extensions
folder to build an extended image. This extended image will include the Oracle Globally Distributed Database Feature. For more information, refer to the README.MD in the extensions
folder for the Oracle Single Instance Database, which is available on the Oracle GitHub repository.
For example:
./buildExtensions.sh -x sharding -b oracle/database:21.3.0-free -t oracle/database-ext-sharding:21.3.0-free -o "--build-arg BASE_IMAGE_VERSION=21.3.0"
Where:
"-x sharding" is to specify to have sharding feature in the extended image
"-b oracle/database:21.3.0-ee" is to specify the Base image created in previous step
"oracle/database-ext-sharding:21.3.0-ee" is to specify the name:tag for the extended image with Sharding Feature
-o "--build-arg BASE_IMAGE_VERSION=21.3.0" is to specify the BASE_IMAGE_VERSION to clone from db-sharding git repo
To see more usage instructions for the buildExtensions.sh
script, run the following command:
./buildExtensions.sh -h
Usage: buildExtensions.sh -a -x [extensions] -b [base image] -t [image name] -v [version] [-o] [container build option]
Builds one of more Container Image Extensions.
Parameters:
-a: Build all extensions
-x: Space separated extensions to build. Defaults to all
Choose from : k8s patching prebuiltdb sharding truecache
-b: Base image to use
-v: Base version to extend (example 21.3.0)
-t: name:tag for the extended image
-o: passes on Container build option
LICENSE UPL 1.0
Copyright (c) 2023 Oracle and/or its affiliates. All rights reserved.
NOTE: Oracle RAC Database Container Image Feature is NOT Available for Oracle 23ai FREE.
Oracle Globally Distributed Database on a container can also be deployed using Oracle Restart and Oracle RAC. To use Oracle Restart or Oracle RAC and build Oracle Globally Distributed Database using containers, download the project files and build an Oracle RAC Database Container Image. See the Oracle Real Application Clusters in Linux Containers README.MD, which is available on the Oracle GitHub repository.
Note: Use the README.MD to create the image, and do not use the container instructions. For the container, use the steps given in this document under the Oracle Globally Distributed Database in Containers Deployment Scenarios section.
Building Extended Oracle RAC Database Container Image with Oracle Globally Distributed Database Feature
After creating the base image using buildContainerImage.sh
in the previous step, use the buildExtensions.sh
script that is under the extensions
folder to build an extended image. This extended image will include the Oracle Globally Distributed Database Feature. For more information, refer to the README.MD in the extensions
folder for the Oracle Real Application Clusters in Linux Containers, which is available on the Oracle GitHub repository.
For example:
./buildExtensions.sh -x sharding -b oracle/database-rac:21.3.0 -t oracle/database-rac-ext-sharding:21.3.0-ee -o "--build-arg BASE_IMAGE_VERSION=21.3.0"
Where:
"-x sharding" is to specify to have sharding feature in the extended image
"-b oracle/database-rac:21.3.0" is to specify the Base image created in previous step
"oracle/database-rac-ext-sharding:21.3.0-ee" is to specify the name:tag for the extended image with Oracle Globally Distributed Database Feature
-o "--build-arg BASE_IMAGE_VERSION=21.3.0" is to specify the BASE_IMAGE_VERSION to clone from db-sharding git repo
To see usage instructions for the buildExtensions.sh
script, run the following command:
./buildExtensions.sh -h
Usage: buildExtensions.sh -a -x [extensions] -b [base image] -t [image name] -v [version] [-o] [container build option]
Builds one of more Container Image Extensions.
Parameters:
-a: Build all extensions
-x: Space separated extensions to build. Defaults to all
Choose from : sharding
-b: Base image to use
-v: Base version to extend (example 21.3.0)
-t: name:tag for the extended image
-o: passes on Container build option
LICENSE UPL 1.0
Copyright (c) 2023 Oracle and/or its affiliates. All rights reserved.
If you want to manually deploy the Oracle Globally Distributed Database using Docker or Podman containers, then use the sections that follow to see the step by step procedure.
To deploy an Oracle Globally Distributed Database on Podman using Oracle 23ai FREE Images, see: Deploy Oracle Globally Distributed Database Containers on Podman using Oracle 23ai FREE Images. This document provides the commands that you need to deploy an Oracle Globally Distributed Database with Oracle 23ai FREE Images using Podman with System-Managed Sharding or with System-Managed Sharding with RAFT replication or with User Defined Sharding.
To deploy Oracle Globally Distributed Database using Single Instance Database in Podman Containers, we will use Extended Oracle Single Instance Database Image with Enterprise Edition Software, see: Deploy Oracle Globally Distributed Database using Single Instance Database in Podman Containers. The individual shards and the catalog database are deployed using Single Instance Database in Podman Containers. In this case, the Oracle Globally Distributed Database can be deployed with either System-Managed Sharding or with User Defined Sharding.
To deploy an Oracle Globally Distributed Database using Oracle Restart in Podman Containers, we will use Extended Oracle RAC Database Container Image, see: Deploy Oracle Globally Distributed Database using Oracle Restart in Podman Containers. The individual shards and the catalog database are deployed using Oracle Restart in Podman Containers. So, we have Automatic Storage Management(ASM) feature available for individual Shard and the Catalog Database. In this case, the Oracle Globally Distributed Database can be deployed with either System-Managed Sharding or System-Managed Sharding with RAFT replication or with User Defined Sharding.
NOTE: Oracle Globally Distributed Database using Oracle Restart in Podman Containers is NOT available for Oracle 23ai FREE version. You can deploy it using Oracle 21c on Oracle Linux 8 using Podman.
To deploy an Oracle Globally Distributed Database using Oracle RAC Database in Podman Containers, see: Deploy Oracle Globally Distributed Database using Oracle RAC Database in Podman Containers. The individual shards and the catalog database are deployed as Oracle RAC Databases in Podman Containers. So, we have active/active Oracle Database high availability and scalability features available for individual Shard and the Catalog Database. In this case, the Oracle Globally Distributed Database can be deployed with either System-Managed Sharding or with User Defined Sharding.
NOTE: Oracle Globally Distributed Database using Oracle RAC Database in Podman Containers is NOT available for Oracle 23ai FREE version. You can deploy it using Oracle 21c on Oracle Linux 8 using Podman.
NOTE: If you want to use Oracle Database 21c or Oracle Database 23ai FREE release based container images with Podman
, then you must deploy on an Oracle Linux 8 host.
NOTE: Podman can be used on Oracle Linux 8 onwards. If you want to use the Oracle Database 19c or Oracle Database 21c release-based container images on earlier Oracle Linux Release (Oracle Linux 7), then you use Docker.
To deploy an Oracle Globally Distributed Database Containers on earlier OS Release, see: Deploy Oracle Globally Distributed Database Containers on Docker. This document provides the commands that you need to deploy an Oracle Globally Distributed Database using Docker with either System-Managed Sharding or with User Defined Sharding.
To deploy an Oracle Globally Distributed Database in Containers using podman-compose, refer to Deploying Oracle Globally Distributed Database Containers using podman-compose
This case is applicable if you want to use an earlier OS version i.e. Oracle Linux 7 to deploy Oracle Globally Distributed Database Containers. In this case, you can not use podman-compose
and will need to use docker-compose
.
To deploy an Oracle Globally Distributed Database in Containers using docker-compose, refer to Deploying Oracle Globally Distributed Database Containers using docker-compose
If you want to use Pre-built Oracle Database and Oracle GSM Container images from Oracle Container Registry, you can refer to below set of images, their openssl version and the openssl version of the host machine on which the encrypted password file was generated before the deployment using these set of images:
- Deployment using 19.25 RU Images:
Image | Image Openssl Version | Image Id | Host Machine Openssl Version |
---|---|---|---|
container-registry.oracle.com/database/enterprise_ru:19.25.0.0 | OpenSSL 1.0.2k-fips | 8f776e5d33dc | OpenSSL 1.1.1k |
container-registry.oracle.com/database/gsm_ru:19.25.0.0 | OpenSSL 1.1.1k FIPS | 87ed4fe32b3a | OpenSSL 1.1.1k |
- Deployment using 23ai FREE Images:
Image | Image Openssl Version | Image Id | Host Machine Openssl Version |
---|---|---|---|
container-registry.oracle.com/database/free:latest | OpenSSL 1.1.1k FIPS | ac5f0e5fb443 | OpenSSL 1.1.1k |
container-registry.oracle.com/database/gsm:latest | OpenSSL 1.1.1k FIPS | 494413938105 | OpenSSL 1.1.1k |
- Deployment using 21.3 Images:
Image | Image Openssl Version | Image Id | Host Machine Openssl Version |
---|---|---|---|
container-registry.oracle.com/database/enterprise:21.3.0.0 | OpenSSL 1.0.2k-fips | 35e92315f1f8 | OpenSSL 1.1.1k |
container-registry.oracle.com/database/gsm:21.3.0.0 | OpenSSL 1.1.1k FIPS | 523f362fee17 | OpenSSL 1.1.1k |
Oracle Global Service Manager (GSM) and Oracle Globally Distributed Database on Docker is supported on Oracle Linux 7. Oracle Database 23ai GSM and Oracle Globally Distributed Database on Podman is supported on Oracle Linux 8 and onwards.
To download and run Oracle Global Service Manager (GSM) and Oracle Globally Distributed Database, either inside or outside a Container, you must download the binaries from the Oracle website and accept the license indicated at that page.
All scripts and files hosted in this project and GitHub docker-images/OracleDatabase repository required to build the Docker and Podman images are, unless otherwise noted, released under UPL 1.0 license.
Copyright (c) 2022 - 2024 Oracle and/or its affiliates. Released under the Universal Permissive License v1.0 as shown at https://oss.oracle.com/licenses/upl/