Skip to content

Latest commit

 

History

History
220 lines (123 loc) · 8.92 KB

README.md

File metadata and controls

220 lines (123 loc) · 8.92 KB

Ansible Playbooks for SOA 12.2.1.4

This document explains how to use the set of Ansible playbooks provided in this repository to install, patch and configure an Oracle SOA domain 12.2.1.4.

Architecture implemented

The architecture tested with these playbooks is composed by the following elements.

  1. Three CentOS Linux 7 machines for application servers.

  2. A Red Hat Enterprise Linux Server 7.7 for the database.

  3. Oracle database version 12.2.0.1.0.

The Oracle Weblogic domain configured within these playbooks is described by the following picture.

A close up of text on a white background Description automatically generated

As you can see on the previous picture, we have these components.

  1. An AdminServer running on its own machine, which a good practice for performance.

  2. Two managed servers each one running on its own machine.

  3. A cluster composed by two managed servers.

  4. An Oracle database 12c used to install RCU schemas required by SOA.

  5. User: oracle

  6. Group: oinstall

  7. This is the list of machines

Machine Usage
machine01.pegasus.net AdminServer
machine02.pegasus.net Managed Server soa_server01
machine03.pegasus.net Managed Server soa_server02
A laptop with Ubuntu WSL Ansible controller

How have you configured Ansible?

As I am using Windows 10, I have configured WSL Ubuntu to access the target machines that by the way are running on Oracle Virtual Box; which means I have configured the user oracle and the group oinstall on my WSL Ubuntu, which I do not think it is a good idea. However, this is just a demo.

Why have you written this when there are plenty of playbooks for SOA on the web?

I think it is important to explain why I am doing this.

  1. In 2019 I wanted to get deep into Weblogic Deploy Tooling. However, I was missing an environment to apply introspection - What do you mean by introspection? – By introspection I mean this. Therefore, this script is going to help me to create environments to test Weblogic Deploy Tooling

  2. I wanted to try a different approach to write Ansible playbooks. Thus, I started with this project as a kind of experiment – What do you mean by different approach? – it is simple, I wanted to reduce the number of variables declared everywhere, which I think complicates many implementations with Ansible. Therefore, I decided to centralize the configuration using a YAML file (you can see it here) and then using JSON Query Filter to extract the configuration from just a file.

  3. This is the most important reason, I want to do this

Which technologies have you used here?

I have used:

  1. Documentation about Weblogic and SOA 12.2.1.4. which is available here.

  2. Ansible.

  3. Python and Weblogic Scripting Tool (WLST). You should try this book to get deeper into WLST.

  4. Jinja2 templating. The template designer documentation is useful.

  5. JSON Query Filters and JMESPath.

  6. Some theory about PKI/SSL.

Why do I need to use it?

  1. An Ansible controller, as I said before, I am using Ansible on WLS Ubuntu, which is out of the box with Windows 10.

  2. Target machines where SOA domain will be installed. In this case I am using 3 Linux Centos 7 machines.

  3. Create the oracle user on target machines and on Ansible controller machine with the same user id.

  4. Create the oninstall group on target machines and on Ansible controller machine with the same group id.

  5. Configure SSH for oracle user between Ansible controller and target machines.

  6. Configure SSH for oracle user between target machines. This is because I am using the Ansible module called synchronize.

  7. You also need a directory called /u01/software/ with the following files

    1. jdk-8u251-linux-x64.tar.gz -> JDK installer.

    2. p28186730_139422_Generic.zip -> Patch for OPatch

    3. p30729380_122140_Generic.zip -> Patch

    4. p30970477_122140_Generic.zip -> Patch

    5. p30995852_122140_Generic.zip -> Patch

    6. SOA_12.2.1.4_V983383-01.zip -> SOA 12.2.1.4 installer

    7. V983368-01.zip -> FMW 12.2.1.4 infrastructure

  8. I am using this home for oracle user /u01/oracle/

  9. An Oracle 12c database and the password for sys as these playbooks include a role to run RCU. You can install an Oracle database and configure it with this.

Wait a minute, what about passwords?

This is a hot topic and I am using vault to encrypt passwords. You can configure your own passwords here. The password used to edit, encrypt and decrypt the vault file is oracle.

How could I run this?

You should execute this

ansible-playbook --ask-vault-pass -i inventories/dev/hosts site.yml --extra-vars "environment_chosen=dev" -vvv

The previous command will ask for the vault password, which is oracle

What happen when site.yml is executed?

This is the entry point, which will execute a set of roles that are described shortly below.

os_settings

This role will modify kernel limits for processes and files. Furthermore, this also installs pip, Pexpect, cryptography and pyOpenSSL.

directories

This role creates part of the directories that are needed to install Weblogic and SOA.

installation

This role installs Java Development Kit, Oracle Weblogic 12.2.1.4 and Oracle SOA 12.2.1.4.

patching

This role patches OPatch, Oracle SOA, Oracle Weblogic and Oracle Coherence.

rcu

This role executes Repository Creation Utility (RCU) to create database schemas that are used by Oracle SOA 12.2.1.4.

createsoadomain

This role creates a SOA domain with the architecture explained at the beginning of this document.

pack

This role packs the domain to distribute it from the AdminServer machine into managed server machines.

unpack

This role unpacks the domain to distribute it from the AdminServer machine into managed server machines.

nodemanagerservice

This role configures three node managers for AdminServer, soa_server01 and soa_server02 as Linux services.

certificates

This role creates self-signed certificates and configure key stores, trust stores and SSL for the SOA domain.

configurenodemanager

This role configures three node managers over SSL.

configurewlst

This role configures the file wlst_internal.sh to allow using nmConnect over SSL.

configuredomainpkissl

This role configures the SOA domain to use the certificates created by the role certificates. This role also updated the SSL configuration. These configurations are applied for the AdminServer and all the managed servers within the domain.

How could I start services after executing site.yml?

As I have not had time to create a playbook to start services, you should do this part manually.

On the AdminServer machine.

sudo systemctl start nmadminserver.service

/u01/oracle/product/fmw12214/oracle_common/common/bin/wlst.sh

nmConnect('nmUser', 'weblogic123456', 'machine01.pegasus.net', '5759', 'soa_atenea', '/u01/oracle/domains/soa_atenea', 'ssl')

nmStart('AdminServer')

On managed server machines

sudo systemctl start nmmanagedserver.service

Weblogic console.

Finally use the Weblogic console to start managed servers; if everything goes well you will see this.

Do you need support?

You can contact me here complexsystemsblog@gmail.com