Skip to content

Latest commit

 

History

History
311 lines (217 loc) · 15.3 KB

README.md

File metadata and controls

311 lines (217 loc) · 15.3 KB

Ansible OSB Role

Description

This is an Ansible role to install and configure Oracle Service Bus 12c.

Supported systems

  • CentOS 7

Role dependencies

Requirements

Software Requirements

  • Ansible 1.9 or higher (can be easily installed via pip. E.g: sudo pip install ansible==1.9.2)
  • Vagrant 1.7 or higher
  • sshpass package which is needed by Ansible if you are using SSH authentication by password. On Ubuntu/Debian: $ sudo apt-get install sshpass
  • Virtualbox
  • Oh-my-box tool, optional, if you want to quickly provision and package a Vagrant base box with Ansible and Ruby pre-installed.

System requirements

  • Oracle JDK 8 (see ansible-java)

  • Fusion Middleware Infrastructure 12c Plateform. You can download the installer JAR file fmw_12.2.1.0.0_infrastructure.jar from the Oracle Software Delivery Cloud, put it somewhere in the machine(s) to provision and use the ansible-weblogic role to install and configure a WebLogic platform.

  • Oracle Service Bus installer JAR file fmw_12.2.1.0.0_osb.jar which can be obtained from the Oracle Software Delivery Cloud.

  • An access to an Oracle 12c Database is required too in order to create the OSB essential schemas using RCU tool (the role should work with an Oracle 11g DB also).

Memory requirements

The specific memory requirements for your Oracle Service Bus 12c deployment depends on which components, or combination of components, you install. Please read the Oracle Fusion Middleware installation guidelines for more details about memory requirements.

In case of a plain installation using this Ansible role such as a combination of a nodemanager, an AdminServer and one Managed Server in the same server, the required memory is at least 4GB of physical memory and 1GB of Swap space.

Role Variables

OSB installation parameters

  • oracle_base_dir - The Oracle base directory (default: /u01/app/oracle)
  • middleware_home_dir - The Oracle Middleware installation directory (default: /u01/app/oracle/product/middleware)
  • osb_installation_type - The Oracle Service Bus installation type (default: 'Service Bus')
  • osb_jar_path - Required absolute path to the OSB installer JAR file (default: '')
  • osb_version - The OSB version to install (default: 12c)
  • osb_already_installed - A Flag to indicate if OSB is already installed (default: false)
  • osb_schemas_created - A Flag to tell if the OSB schemas are installed or not (default: false)

Oracle database connection parameters

  • oracle_db_address - A required Oracle database address (default: localhost)
  • oracle_db_port - The Oracle database connection port (default: 1521)
  • oracle_db_sid - A required Oracle database connection system identifier (default: xe)
  • oracle_db_user - The Oracle database admin user name (default: sys)
  • oracle_db_password - A required Oracle database admin user password (default: oracle)
  • oracle_db_role - The Oracle database admin user role (default: SYSDBA)

OSB database schemas

  • osb_rcu_components - The OSB schemas components to install (default: [ MDS, IAU, IAU_APPEND, IAU_VIEWER, OPSS, UCSUMS, WLS, STB, SOAINFRA ])
  • osb_rcu_schema_prefix - The OSB database schemas prefix (default: OSB)
  • osb_schemas_common_password - Required OSB schemas common password (default: oracle)

Cluster parameters

  • osb_domain_name - The OSB WebLogic domain name (default: osb_domain)
  • osb_cluster_name - The OSB cluster name (default: osb_cluster)
  • osb_cluster_nodes - The OSB cluster nodes/machines (default: ["{{ ansible_fqdn }}"])

OSB NodeManager parameters

  • osb_nodemanager_listen_address - The NodeManager listening address (default: localhost)
  • osb_nodemanager_listen_port - The NodeManager listening port (default: 5556)
  • osb_nodemanager_connection_mode - The NodeManager's connection mode (default: ssl)

OSB AdminServer parameters

  • osb_admin_server_name - The AdminServer instance name (default: AdminServer)
  • osb_admin_server_listen_address - The AdminServer listening address (default: "{{ ansible_fqdn }}")
  • osb_admin_server_listen_port - The AdminServer listening port (default: 7001)
  • osb_admin_username - The WebLogic administrator user name (default: weblogic)
  • osb_admin_password - The WebLogic administrator user password (default: manager1)

OSB NodeManager parameters

  • osb_managed_servers_per_machine - The maximum number of managed servers per machine (default: 1)
  • osb_managed_server_listen_port_start - The managed servers start listening port number (default: 8000)
  • osb_managed_server_listen_address - The managed servers listen address (default: "{{ ansible_fqdn }}")

JVM heap parameters

  • osb_admin_server_heap_size - The AdminServer heap size (default: 512m)
  • osb_admin_server_perm_size - The AdminServer permanent generation size (default: 256m)
  • osb_managed_server_heap_size - The Managed server heap size (default: 1024m)
  • osb_managed_server_perm_size - The Managed server permanent generation size (default: 512m)
  • osb_coherence_server_heap_size - The Coherence server heap size (default: 256m)
  • osb_coherence_server_perm_size - The Coherence server permanent generation size (default: 128m)

Import OSB project parameters

  • osb_sbconfig_jar_file - Path to the OSB project's JAR file to be imported (default: /tmp/sbconfig.jar)
  • osb_sbconfig_customization_file - Path to the OSB project's customization XML file to be applied (default: /tmp/ALSBCustomizationFile.xml)

Available tags

  • osb-create-db-schemas - Specify this tag to create the OSB schemas using RCU.
  • osb-purge-db-schemas - Use this tag if you want to purge an existing OSB schemas to prepare for a clean installation. If you want that the purge take effect, you have to set the role parameter osb_schemas_created to true. The role parameters for db connection, the schemas prefix and the RCU components are required too.
  • osb-plain-install - This tag performs only the installation of the OSB software.
  • osb-configure - When mentioned, the OSB configuration tasks are executed (Create OSB cluster, etc).
  • osb-install-and-init - This is the default installation mode of the OSB. When mentioned, this tag performs the creation of a new domain, the configuration and startup of an OSB cluster with 3 services: a nodemanager, an AdminServer and one Manager Server.
  • osb-start-nodemanager - Starts the nodemanager service.
  • osb-stop-nodemanager - Stops the nodemanager service.
  • osb-restart-nodemanager - Restarts the nodemanager service.
  • osb-start-adminserver - Starts the AdminServer process.
  • osb-stop-adminserver - Stops the AdminServer process.
  • osb-start-managed-servers - Starts the Managed Servers processes.
  • osb-stop-managed-servers - Stops the Managed Servers processes.
  • osb-import-project - Import existing OSB project.

Local facts

  • osb.db.created - Tell if the OSB schemas are installed or not

Usage

Oracle database setup

Personally and for quick tests, I use the Docker image sath89/oracle-12c that brings up an Oracle 12c database server. All you need is to pull the image, create a local data directory and spin up an oracle-db container:

$ sudo docker pull sath89/oracle-12c:latest
$ sudo mkdir -p /var/lib/oracledb/data
$ sudo docker run --name oracle-db -d -p 8080:8080 -p 1521:1521 -v /var/lib/oracledb/data:/u01/app/oracle -e DBCA_TOTAL_MEMORY=1024 sath89/oracle-12c

To test the database connection:

$ sqlplus -L sys/[email protected]/xe.oracle.docker as sysdba

Connected to:
Oracle Database 12c Standard Edition Release 12.1.0.2.0 - 64bit Production

SQL>

All from scratch

First, download Oracle JDK 8 rpm, Fusion Middleware Infrastructure and OSB 12c installer JARs and put them somewhere in the server to provision. Below an example:

$ ls -1 /srv/files/
fmw_12.2.1.0.0_infrastructure.jar
fmw_12.2.1.0.0_osb.jar
jdk-8u77-linux-x64.rpm

Next, clone this project and download the required Ansible roles to install and configure the Oracle JDK and the WebLogic platform:

$ sudo ansible-galaxy install -p /etc/ansible/roles/ -r requirements.txt

To install an Oracle Service Bus Infrastructure (that uses Oracle JDK 8 as the Java Virtual Machine) you can use the following provision.yml playbook:

- hosts: my-server
  roles:
    - role: abessifi.java
      sudo: yes
      java_version: 8
      java_jdk_type: 'oracle'
      oracle_jdk_rpm_package: 'jdk-8u77-linux-x64.rpm'
      rpm_download_directory: '/srv/files'
      java_set_as_default: true
      tags:
        - install-java

    - role: abessifi.weblogic
      weblogic_jar_path: '/srv/files/fmw_12.2.1.0.0_infrastructure.jar'
      weblogic_quick_installation: false
      weblogic_installation_type: 'Fusion Middleware Infrastructure'
      weblogic_domain_name: 'osb_domain'

    - role: ansible-osb
      osb_jar_path: '/srv/files/fmw_12.2.1.0.0_osb.jar'
      oracle_db_address: 'db.weblogic.local'
      oracle_db_sid: 'xe.oracle.docker'
      oracle_db_password: 'oracle'
      osb_schemas_common_password: 'oracle'
      osb_domain_name: 'osb_domain'
      osb_admin_server_listen_address: 'osb.weblogic.local'
      osb_managed_server_listen_address: 'osb.weblogic.local'

That's all ! It's now time to call Ansible to provision your server. Here is an example of ansible-playbook command:

$ ansible-playbook --user=<user-name> --connection=ssh --timeout=30 --inventory-file=inventory.ini --tags='install-java,wls-plain-install,osb-plain-install' -v provision.yml

Notes:

  • In the above playbook example, the db.weblogic.local refers to the host machine where the oracle database is installed and the osb.weblogic.local is the FQDN of the server we are provisioning.
  • Make sure you have updated /etc/hosts file, so the FQDNs db.weblogic.local and osb.weblogic.local can be resolved correctly. Otherwise, replace the FQDNs by IP address in the playbook.
  • You need to create and adapt the Ansible inventory files and variables to suit your environment (services ports, IP addresses, etc)

Import OSB project

You can use the magic tag osb-import-project to import an existing OSB project exported as a JAR file and apply a customization file to adapt the OSB platform to feet the required configuration. To do so you have just to specify the input project JAR and XML customization files:

- hosts: ansible-vm
  roles:
    - role: ansible-osb
      osb_sbconfig_jar_file: '/srv/files/osb_cabestan.jar'
      osb_sbconfig_customization_file: '/srv/files/ALSBCustomizationFile_cabestan.xml'
$ ansible-playbook --user=<user-name> --connection=ssh --timeout=30 --inventory-file=inventory.ini --tags='osb-import-project' -v provision.yml

Notes:

  • Mainly the OSB 11g projects may be imported to the 12c platform.
  • If importation fails, take a look to the default log file /home/oracle/logs/osb_import_project_<timestamp>.log to identify the failure root reason.

Purge existing OSB schemas

If you want to purge an existing OSB schemas and start a clean installation, use the Ansible tags osb-purge-db-schemas and set the role parameter osb_schemas_created to remove the schemas from the Oracle database before recreating them during installation process:

$ ansible-playbook --user=<user-name> --connection=ssh --timeout=30 --inventory-file=inventory.ini --tags='install-java,wls-plain-install,osb-purge-db-schemas,osb-plain-install' -v provision.yml

Installation on top of an existing WebLogic platform

The installation is kept straightforward even with a such use case ! Just specify the absolute path of the Oracle Middleware installation directory using the middleware_home_dir parameter:

- hosts: my-server
  roles:

    - role: ansible-osb
      osb_jar_path: '/srv/files/fmw_12.2.1.0.0_osb.jar'
      oracle_db_address: 'db.weblogic.local'
      oracle_db_sid: 'xe.oracle.docker'
      oracle_db_password: 'oracle'
      osb_schemas_common_password: 'oracle'
      middleware_home_dir: '/u01/app/oracle/product/middleware_12.2.1'
      osb_domain_name: 'osb_domain'
      osb_admin_server_listen_address: 'osb.weblogic.local'
      osb_managed_server_listen_address: 'osb.weblogic.local'
$ ansible-playbook --user=<user-name> --connection=ssh --timeout=30 --inventory-file=inventory.ini --tags='osb-plain-install' -v provision.yml

Note that the only passed Ansible tag to perform the installation is osb-plain-install.

Restart cluster services

In case of problem with the WebLogic instances, you can restart the chain service by restarting the Nodemanager service "the entrypoint":

$ ansible-playbook --user=<user-name> --connection=ssh --timeout=30 --inventory-file=inventory.ini --tags='osb-restart-nodemanager' -v provision.yml

Development and testing

Test with Vagrant

For quick tests, you can spin-up a CentOS VM using Vagrant. You maybe need to adapt the Vagrantfile to suit your environment (IP addresses, etc):

  • Change the Vagrant box name in the Vagrantfile if needed.

  • Create the virtual machine:

(host)$ vagrant up --no-provision
  • Update the /etc/hosts in the host machine and the VM accordingly to reach the addresses db.weblogic.local and osb.weblogic.local:
	<db-server-address>   db.weblogic.local
	<osb-server-address>  osb.weblogic.local
  • Create a working directory to copy installer files to:
	[vagrant@ansible-vm ~]$ sudo mkdir /srv/files/ && sudo chown vagrant:vagrant /srv/files/
  • Copy downloaded installer JAR files:
	(host)$ rsync -iav /path/to/{fmw_12.2.1.0.0_infrastructure.jar,jdk-8u77-linux-x64.rpm,fmw_12.2.1.0.0_osb.jar} [email protected]:/srv/files/
  • Download the required Ansible roles to install and configure the Oracle JDK and the WebLogic platform (not required if your box is already provision):
	(host)$ sudo ansible-galaxy install -p /etc/ansible/roles/ -r requirements.txt
  • Install all stuff !
	(host)$ vagrant provision

Run acceptance tests

Acceptance/Integration tests could be run against the role using the magic test-kitchen tool. All the written acceptance tests are in the ./test/integration/ directory.

The .kitchen.yml file describes the testing configuration and the list of tests suite to run. By default, your instances will be converged with Ansible and run in Vagrant virtual machines.

To list the instances:

$ kitchen list

Instance                    Driver   Provisioner      Verifier  Transport  Last Action
default-centos-7-x64        Vagrant  AnsiblePlaybook  Busser    Ssh        <Not Created>

To run the default test suite on a CentOS 7 platform, run the following:

$ kitchen test

Author

This role was created by Ahmed Bessifi, a DevOps enthusiast.