5 Creating an Order Balancer Cloud Native Image
Order Balancer cloud native image is required to create and manage Order Balancer cloud native instances. This chapter describes creating an Order Balancer cloud native image.
Order Balancer cloud native instance requires a container image and access to the database. The Order Balancer image is built on top of a Linux base image and the Order Balancer image builder script adds Java, WebLogic Server components, and Order Balancer.
The Order Balancer cloud native image is created using the Order Balancer cloud native builder toolkit. You should run the Order Balancer cloud native builder toolkit on Linux and it should have access to the local Docker daemon.
Downloading the Order Balancer Cloud Native Image Builder
To build the Order Balancer cloud native Docker image, the asap-img-builder.zip file is required. This zip file is packaged as part of the ASAP cloud native tar file. For more information about downloading the Order Balancer cloud native Image Builder, see "Downloading the ASAP Cloud Native Artifacts".
See ASAP Software Compatibility Matrix for details about the latest recommended installer versions of Order Balancer.
- The scripts to install the required packages.
- The scripts to install database client, install Java, WebLogic Server, and ASAP.
Prerequisites for Creating an Order Balancer Image
- The Docker client and daemon on the build machine.
- Approximately 2 GB of swap space on the machine where the Docker
daemon is running. By running the
free -m
command, you can verify the swap space.Note:
If the required swap space is not available, contact your administrator. - Order Balancer Installer file. For example, ASAP.R7_4_0_Px.Byy.ob.tar file. Download this file from the Oracle Software Delivery Cloud website:https://edelivery.oracle.com.
- Installers for WebLogic Server and JDK. Download these from the Oracle Software Delivery Cloud website: https://edelivery.oracle.com.
- Java, installed with JAVA_HOME set in the environment.
- TRAEFIK Ingress service node port should be ready where it is being deployed.
- Order Balancer database users should be created. For more information, see "Planning Your Installation" in ASAP System Administrator's Guide.
See ASAP Software Compatibility Matrix for details about the required and supported versions of the prerequisite software.
Creating the Order Balancer Cloud Native Image
The Order Balancer cloud native image builder tool builds the Order Balancer cloud native Docker image, which is then pushed to the Docker repository and deployed in the Kubernetes cluster. If the Docker repository is not available, you copy the image to all the worker nodes of the cluster.
The ASAP installer is packaged with the Order Balancer cloud native image builder and the cloud native toolkit.
Note:
After you download the installer, locate the Order Balancer cloud native image builder asap-img-builder.zip in the ASAP cloud native tar file. The Order Balancer Docker images are created automatically for ASAP 7.4.0.1 or later.To create the Order Balancer cloud native image:
-
Copy the asap-img-builder.zip file to the machine where the Docker daemon is running.
-
Extract the contents of the zip file by running the following command:
unzip asap-img-builder.zip
-
Copy the following installers to the $asap-img-builder/installers directory.
- Order Balancer Installer
- Installers for WebLogic Server and JDK
-
Update the following parameters in the $asap-img-builder/ob.properties file:
ob.tar.file=ASAP.R7_4_0.B196.ob.tar ob.weblogic.username=weblogic ob.weblogic.password= ob.weblogic.port=7501 ob.weblogic.domainName=ob ob.weblogic.channel.listenport=7502 ob.weblogic.channel.publicport=30301 ob.ssl.incoming=0 ob.cacheexpiry=60 #Time in seconds ob.all.servers.down.wait.interval=3600 ob.all.servers.down.retry.interval=120 ob.server.down.retry.interval=2 ob.server.poll.interval=60 ob.webservice.res.timeout=0 ob.asap.conn.timeout=10 ## Values allowed: SEVERE, WARNING, INFO , FINE , FINEST ,ALL ob.logger.info=INFO ob.db.host= ob.db.port=1521 ob.db.service.name= ob.db.user= ob.db.password= ob.jms.user= ob.jms.password=
whereob.weblogic.username
is the user name to log in to WebLogic Server.ob.weblogic.password
is the password to log in to WebLogic Server.ob.weblogic.port
is the port of the WebLogic Server.ob.weblogic.domainName
is the WebLogic Server domain.ob.weblogic.channel.listenport
is the channel listen port of the WebLogic Server.ob.weblogic.channel.publicport
is the public port of the WebLogic Server.ob.ssl.incoming
is set to enable SSL on Order Balancer WebLogic Server. The default value is 0 which specifies non-SSL.ob.cacheexpiry
specifies the duration in seconds that Order Balancer JPA shared query refreshes the cache. Cache is refreshed upon next request after the duration expires. The default value is 60.ob.all.servers.down.wait.interval
specifies the duration in seconds that Order Balancer waits before routing the request back to queue when all the ASAP instances are down. The default value is 3600.ob.all.servers.down.retry.interval
specifies the duration in seconds that Order Balancer waits before retrying to connect to fetch for an active ASAP member instance while waiting when all servers are down. The default value is 120.ob.server.down.retry.interval
specifies the duration in seconds that Order Balancer waits before reattempting to route the order to the same instance. If the re-attempt fails, the instance is marked as down. The default value is 2.ob.server.poll.interval
specifies the duration in seconds that Order Balancer waits before it retries to check the ASAP instance status. The default value is 60.ob.webservice.res.timeout
specifies the duration in seconds that Order Balancer waits for response before the read times-out. Order Balancer Web Service waits for a response from ASAP member instance after invoking the operation. A value of zero means Order Balancer will wait indefinitely until it receives a response from ASAP. The default value is 0 seconds (no read time-out).ob.asap.conn.timeout
specifies the duration in seconds that Order Balancer reattempts the connection to the ASAP instance. The default value is 10.ob.logger.info
specifies the log level for initializing the Order Balancer application root logger. The valid values are SEVERE, WARNING, INFO, FINE, FINEST, and ALL.-
ob.db.host
is the database host name or IP address. ob.db.port
is the database port.ob.db.service.name
is the database service name.ob.db.user
is the database user name.ob.db.password
is the database password.ob.jms.user
is the JMS user.ob.jms.password
is the JMS password.
Note:
Do not add an ASAP instance when you are building the Order Balancer Docker image. The wallet store is mounted dynamically in the Kubernetes cluster. The wallet files created in the Docker image are not accessible in the Kubernetes Pod.In the cloud native deployment, the WebLogic domain is non-SSL and the ingress controller is configured as SSL.
-
Update the HTTPS_PROXY and HTTP_PROXY variables in the build_ob_env.sh script:
base_image=oraclelinux:8 HTTPS_PROXY= HTTP_PROXY= # Docker details OB_IMAGE_TAG="obcn:7.4.0.0.0" OB_VOLUME=obhost_volume OB_CONTAINER="ob-c" DOCKER_HOSTNAME="obhost" # Installer filenames WEBLOGIC_DOMAIN=/u01/oracle/user_projects/domains/ JDK_FILE=jdk-8u321-linux-x64.tar.gz FMW_FILE=fmw_14.1.1.0.0_wls_lite_Disk1_1of1.zip # Installation locations JAVA_HOME=/usr/lib/jvm/java/jdk1.8.0_321 PATH=$JAVA_HOME/bin:$PATH WEBLOGIC_HOME=/home/oracle/weblogic141100
Note:
The file names of JDK_FILE and FMW_FILE variables must match with the file names in the /asap-img-builder/installers/ folder. -
Run the build-asap-images.sh script to build the Order Balancer docker images:
./build-asap-images.sh -i ob
The script creates the Order Builder Docker images by running the docker container and commits the Order Builder image.