Category: Patching

  • Oracle Data Pump – New Diagnostic V$ Views For Performance Issues in 23ai

    Oracle 23c AI introduces new V$ views to diagnose Data Pump performance issues. These views help monitor and troubleshoot Data Pump activities by providing detailed insights into job execution, resource usage, and potential bottlenecks.

    Key V$ Views:

    • (G)V$DATAPUMP_PROCESS_INFO: Provides information about active Data Pump processes
    • (G)V$DATAPUMP_PROCESSWAIT_INFO: Details the waits encountered by Data Pump processes
    • (G)V$DATAPUMP_SESSIONWAIT_INFO: Provides information about session waits related to Data Pump operations.

    These views enable administrators to efficiently manage and optimize Data Pump tasks. The outputs will be needed, along with the DataPump job logs, traces and other job specific info for diagnostic purpose. 

    (G)V$DATAPUMP_PROCESS_INFO

    SQL> desc gv$datapump_process_info;
    
    Name    Null?    Type
    ---------------------------
    INST_ID          NUMBER
    CUR_DATE         VARCHAR2(19)
    PROGRAM          VARCHAR2(84)
    SESSIONID        NUMBER
    STATUS           VARCHAR2(8)
    USERNAME         VARCHAR2(128)
    JOBNAME          VARCHAR2(128)
    SPID             VARCHAR2(24)
    SERIALNUMBER     NUMBER
    PROCESSID        NUMBER
    CON_ID           NUMBER
    
    Sample output:
    
    select * from v$datapump_process_info;
    
    CUR_DATE PROGRAM SESSIONID STATUS USERNAME JOBNAME SPID SERIALNUMBER PROCESSID CON_ID
    ------------------- -------------------------------------- --------- -------- ---------- ------------------
    2023-01-09 13:56:07 ude@orcl (TNS V1-V3) 42 ACTIVE SYSTEM SYS_EXPORT_FULL_01 3891480 11829 70 0
    2023-01-09 13:56:07 oracle@orcl (DW00)   48 ACTIVE SYSTEM SYS_EXPORT_FULL_01 3891500 36244 82 0
    2023-01-09 13:56:07 oracle@orcl (DM00)  149 ACTIVE SYSTEM SYS_EXPORT_FULL_01 3891494 42966 79 0

     (G)V$DATAPUMP_PROCESSWAIT_INFO

    SQL> desc gv$datapump_processwait_info;
    
    Name              Null?   Type
    -------------------------------------
    INST_ID                   NUMBER
    WAITING_SESSION           NUMBER
    HOLDING_SESSION           NUMBER
    SERIAL_NUMBER             NUMBER
    EVENT                     VARCHAR2(64)
    PROGRAM_WAITSESSION       VARCHAR2(84)
    PROGRAM_HOLDINGDSESSION   VARCHAR2(84)
    MODULE_WAITSESSION        VARCHAR2(64)
    MODULE_HOLDINGSESSION     VARCHAR2(64)
    DATAPUMP_LOCKID           NUMBER
    CON_ID                    NUMBER
    
     Sample output:
    
    SQL> select * from gv$datapump_processwait_info;
    
    INST_ID WAITING_SESSION HOLDING_SESSION SERIAL_NUMBER EVENT PROGRAM_WAITSESSION PROGRAM_HOLDINGDSESSION MODULE_WAITSESSION MODULE_HOLDINGSESSION DATAPUMP_LOCKID CON_ID
    -------------------------------------------------------------------------------------------------------------------------------------------------------------
          1   174   57 40525 enq: TM - contention oracle@orcl (DM00) oracle@orcl (DW00) Data Pump Master Data Pump Worker 79473 1

    (G)V$DATAPUMP_SESSIONWAIT_INFO

    SQL> desc gv$datapump_sessionwait_info;
    
    Name    Null?    Type
    ------------------------------------
    INST_ID             NUMBER
    WAITING_SESSION     NUMBER
    SERIAL_NUMBER       NUMBER
    SEQ_NUMBER          NUMBER
    EVENT               VARCHAR2(64)
    DP_WAITTIME         NUMBER
    DP_SECONDS_IN_WAIT  NUMBER
    DP_STATE_IN_WAIT    VARCHAR2(19)
    DP_P1TEXT           VARCHAR2(64)
    DP_P1               NUMBER
    DP_P2TEXT           VARCHAR2(64)
    DP_P2               NUMBER
    DP_P3TEXT           VARCHAR2(64)
    DP_P3               NUMBER
    CON_ID              NUMBER
    
    Sample output:
    
    SQL> select * from gv$datapump_sessionwait_info;
    
    INST_ID WAITING_SESSION SERIAL_NUMBER SEQ_NUMBER EVENT DP_WAITTIME DP_SECONDS_IN_WAIT DP_STATE_IN_WAIT DP_P1TEXT DP_P1 DP_P2TEXT DP_P2 DP_P3TEXT DP_P3 CON_ID
    --------------------------------------------------------------------------------------------------------------------------------------------
    1 46 65244 1319 enq: TM - contention 0 8086 WAITING name|mode 1414332419 object # 80996 table/partition 0

  • Postgres dB Installation in Linux

    Red Hat Enterprise Linux 8

    Step 1: Set up the EDB repository

    To determine if your repository exists, enter this command:

    dnf repolist | grep enterprisedb

    If no output is generated, the repository isn’t installed.

    To set up the EDB repository:

    • Go to EDB repositories.
    • Select the button that provides access to the EDB repository.
    • Select the platform and software that you want to download.
    • Follow the instructions for setting up the EDB repository.

    Install the EPEL repository:

    sudo dnf -y install https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm

    Enable additional repositories to resolve dependencies:

    ARCH=$( /bin/arch ) subscription-manager repos --enable "codeready-builder-for-rhel-8-${ARCH}-rpms"

    Disable the built-in PostgreSQL module:

    dnf -qy module disable postgresql

    Install the package

    sudo dnf -y install postgresql<xx>-server postgresql<xx>-contrib

    Where <xx> is the version of PostgreSQL you are installing. For example, if you are installing version 16, the package name would be postgresql16-server postgresql16-contrib.

  • NetworkManager tool in Linux

    NetworkManager is a utility in Linux that simplifies the management of network connections and devices. It provides both command-line and graphical interfaces for configuring and controlling network settings. Two of the key tools associated with NetworkManager are nmtui and nmcli.

    1. NetworkManager (nmcli):

    • nmcli Overview:
      • nmcli is the command-line client for NetworkManager, offering a powerful and flexible way to manage network connections in a text-based environment.
    • Features:
      • Connection Management: nmcli allows users to create, edit, activate, and deactivate network connections, including wired, wireless, and virtual connections.
      • Device Status: Users can check the status and details of network devices, such as their IP addresses, MAC addresses, and connection profiles.
      • Profile Management: nmcli enables users to manage connection profiles, modify settings, and prioritize connections.
    • Usage Examples:
      • Displaying all available connections:
        • nmcli connection show
      • Activating a specific connection:
        • nmcli connection up ConnectionName
      • Displaying details of a specific device:
        • nmcli device show DeviceName

    2. NetworkManager TUI (nmtui):

    • nmtui Overview:
      • nmtui stands for NetworkManager Text User Interface. It is a user-friendly, console-based interface that provides a simple and interactive way to manage network connections.
    • Features:
      • Intuitive Menu System: nmtui presents a menu-driven interface that allows users to navigate through various options to configure and control network settings.
      • Connection Management: Users can easily create, edit, activate, and deactivate network connections using the interactive menus.
      • Device Configuration: nmtui provides options to configure settings for specific network devices, such as Ethernet or Wi-Fi.
    • Usage Examples:
      • Launching the nmtui interface:
        • nmtui
      • Navigating through the menus to configure a new connection or modify an existing one.
      • Activating or deactivating a connection using the on-screen options.

    3. Advantages of NetworkManager, nmtui, and nmcli:

    • User-Friendly Interfaces: Both nmtui and nmcli provide interfaces that cater to users with different preferences – interactive and menu-driven (nmtui) or command-line and scriptable (nmcli).
    • Versatility: NetworkManager supports a wide range of connection types and devices, making it suitable for various networking scenarios.
    • Consistency: nmtui and nmcli provide consistent interfaces across different Linux distributions, promoting a standardized approach to network management.
    • Scripting and Automation: nmcli allows users to automate network-related tasks by scripting commands, making it a powerful tool for system administrators and advanced users.

  • CentOS 7 to Oracle Linux 8

    CentOS 7 and Oracle Linux 8 are both popular Linux distributions that serve different purposes within the open-source community.

    CentOS 7:

    1. Origin and Community-driven:

    • CentOS (Community ENTerprise Operating System) is a free and open-source Linux distribution derived from the sources of Red Hat Enterprise Linux (RHEL).
    • CentOS 7, based on RHEL 7, was known for its stability, long-term support, and compatibility with RHEL packages.

    Oracle Linux 8:

    Origin and Enterprise Focus:

    • Oracle Linux is an open-source Linux distribution sponsored by Oracle Corporation. Oracle Linux 8 is based on the source code of RHEL 8, emphasizing enterprise features and performance.

    Transition from CentOS 7 to Oracle Linux 8:

    This guide explains how to combine a software upgrade and migration into a single process, taking you from CentOS 7 directly to Oracle Linux 8. It demonstrates using the open-source projects Leapp and Elevate to achieve this streamlined migration and upgrade in one go.

    • The first step is to get your existing CentOS 7 system updated to latest packages release available and then reboot. To do this, please execute following step:
    #update YUM package
    yum update -y
    
    #reboot
    init 6
    • Installing the “elevate” release RPM is necessary to access and utilize the Elevate utilities.
    yum install -y http://repo.almalinux.org/elevate/elevate-release-latest-el$(rpm --eval %rhel).noarch.rpm
    • Install “leapp” packages and migration data for Oracle Linux, as the target to migrate to
    yum install -y leapp-upgrade leapp-data-oraclelinux

    Before upgrading, use the preupgrade check to assess your system’s readiness. This analysis will highlight potential conflicts without making any changes. The report files and debug log it creates offer valuable insights into your system’s configuration and possible upgrade challenges. To initiate this process, simply run the leapp preupgrade command.

    leapp preupgrade

    Edit /var/log/leapp/answerfile and uncomment Confirm and add TRUE as answer.

    leapp upgrade
    
    reboot

    Post-Migration Steps:

    1. Verify Successful Migration:
      • Once the system reboots, log in and confirm that the operating system is now Oracle Linux 8.
    2. Review Leftover Packages:
      • Check for any remaining CentOS 7 packages that might not have been migrated automatically. You can then decide whether to remove them manually or update them to their Oracle Linux 8 equivalents.
    3. Examine Upgrade Logs:
      • Finally, review the upgrade logs to ensure the migration process completed successfully and identify any potential issues that require attention.

    cat /etc/oracle-release
    cat /etc/os-release

    Thank you ..!

  • Basic SRVCTL Commands

    SRVCTL, short for Server Control Utility, is a command-line tool, used to manage various entities in an Oracle Cluster environment, including databases, instances, listeners, services, and more. It allows you to perform various tasks like starting, stopping, modifying.

    Common Basic SRVCTL Commands:

    • Starting and Stopping Services:

    Start a database instance:

    SYNTAX – srvctl start database -d db_name [-o start_options]

    start_option – nomount/mount/open(default)

    srvctl start database -d PRODB -o nomount
    srvctl start database -d PRODB -o mount
    srvctl start database -d PRODB -o open

    Stop a running database:

    SYNTAX – srvctl stop database -d db_name [-o stop_options]

    stop_options – normal /immediate(default)/transactional/abort

    srvctl stop database -d PRODB -o normal
    srvctl stop database -d PRODB -o immediate
    srvctl stop database -d PRODB -o transactional
    srvctl stop database -d PRODB -o abort

    • Checking Status

    View the status of all database instances:

    srvctl status database -d

    Get detailed information about a service:

    srvctl info service -s

    • Adding and Removing Resources:

    Add a new database:

    srvctl add database -d (caution: advanced usage)

    Remove an existing service:

    srvctl remove service -s
  • Manual Oracle Database Grid Patching

    As the database home owner execute:

    /u01/app/oracle/product/19.0.0/db_1/bin/srvctl stop home -o /u01/app/oracle/product/19.0.0/db_1 -s /tmp/stat_file

    Run the pre root script (As Root User)

    /u01/app/oragrid/product/19.0.0/grid/crs/install/roothas.sh -prepatch

    Patch GI home.

    As the GI home owner execute:

    . oraenv
    +ASM
    
    ## OCW Release Update
    $ /u01/app/oragrid/product/19.0.0/grid/OPatch/opatch apply -oh /u01/app/oragrid/product/19.0.0/grid -local /tmp/Patch202308/35642822/35655527
    
    ## Database Release Update
    $ /u01/app/oragrid/product/19.0.0/grid/OPatch/opatch apply -oh /u01/app/oragrid/product/19.0.0/grid -local /tmp/Patch202308/35642822/35643107
    
    ## ACFS Release Update
    $ /u01/app/oragrid/product/19.0.0/grid/OPatch/opatch apply -oh /u01/app/oragrid/product/19.0.0/grid -local /tmp/Patch202308/35642822/35652062
    
    ## Tomcat Release Update
    $ /u01/app/oragrid/product/19.0.0/grid/OPatch/opatch apply -oh /u01/app/oragrid/product/19.0.0/grid -local /tmp/Patch202308/35642822/35553096
    

    Patch DB home (As the database home owner execute:)

    . oraenv
    <DB_SID>
    
    ## OCW Release Update
    
    $ /tmp/Patch202308/35642822/35655527/custom/scripts/prepatch.sh -dbhome /u01/app/oracle/product/19.0.0/db_1
    
    
    ## OCW Release Update
    
    $ /u01/app/oracle/product/19.0.0/db_1/OPatch/opatch apply -oh /u01/app/oracle/product/19.0.0/db_1 -local /tmp/Patch202308/35642822/35655527
    
    ## Database Release Update
    $ /u01/app/oracle/product/19.0.0/db_1/OPatch/opatch apply -oh /u01/app/oracle/product/19.0.0/db_1 -local /tmp/Patch202308/35642822/35643107
    
    
    ## OCW Release Update
    $ /tmp/Patch202308/35642822/35655527/custom/scripts/postpatch.sh -dbhome /u01/app/oracle/product/19.0.0/db_1
    

    Run the post script.

    As the root user execute:

    # /u01/app/oragrid/product/19.0.0/grid/rdbms/install/rootadd_rdbms.sh
    
    If this is a GI Home, as the root user execute:
    
    # /u01/app/oragrid/product/19.0.0/grid/crs/install/rootcrs.sh -postpatch
    
    If this is an Oracle Restart Home, as the root user execute:
    
    # /u01/app/oragrid/product/19.0.0/grid/crs/install/roothas.sh -postpatch

  • Login from Non-Oracle User Run SQL*Plus

    In Linux or Unix platform, installed SQL*Plus in database server can be executed by anyone.

    We just need to make the tnsnames.ora file readable by others.

    TNSNAMES Readable

    [oracle@test ~]$ chmod o+r $ORACLE_HOME/network/admin/tnsnames.ora

    After this just login to the user you want to login the database and set the environment by .oraenv and providing the SID.

    [root@sql ~]# su - test
    Last login: Tue Aug 22 11:53:14 UTC 2023 on pts/0
    [test@sql ~]$
    [test@sql ~]$
    [test@sql ~]$
    [test@sql ~]$ . oraenv
    ORACLE_SID = [test] ?
    ORACLE_BASE environment variable is not being set since this
    information is not available for the current user ID test.
    You can set ORACLE_BASE manually if it is required.
    Resetting ORACLE_BASE to its previous value or ORACLE_HOME
    The Oracle base has been set to /u01/app/oracle/product/19.3/db_home
    [test@sql ~]$
    [test@sql ~]$
    [test@sql ~]$ sqlplus
    
    SQL*Plus: Release 19.0.0.0.0 - Production on Tue Aug 22 11:53:47 2023
    Version 19.20.0.0.0
    
    Copyright (c) 1982, 2022, Oracle.  All rights reserved.
    
    Enter user-name: system
    Enter password:
    Last Successful login time: Tue Aug 22 2023 09:04:05 +00:00
    
    Connected to:
    Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
    Version 19.20.0.0.0
    
    SQL>
  • Oracle Database Patching

    Oracle Database 19c standalone patching involves applying patches and updates to an existing Oracle Database 19c installation that is not part of an Oracle Real Application Clusters (RAC) configuration.

    High-Level steps for applying the patching

    • Check current version of Opatch Tool
    • Upgrade the Opatch utility
    • Take the backup of ORACLE_HOME
    • Shutdown the Database and Listener
    • Apply PSU patch on ORACLE_HOME
    • Execute Post installation Scripts (datapatch)
    • Startup the Database and Listener
    • Check the dba_registry_sqlpatch .

    Check current version of Opatch Tool

    [oracle@sql ~]$ $ORACLE_HOME/OPatch/opatch version
    OPatch Version: 12.2.0.1.17
    
    OPatch succeeded.

    Move the current OPatch tool as backup

    [oracle@sql db_home]$ mv OPatch/ OPatch_old

    unzip the new OPatch tool to the ORACLE_HOME location

    [oracle@sql db_home]$ unzip /stage_soft/p6880880_190000_Linux-x86-64.zip

    After unzip, check the updated version of OPatch tool

    [oracle@sql db_home]$ OPatch/opatch version
    OPatch Version: 12.2.0.1.39
    
    OPatch succeeded.

    Download the necessary patch, ensuring that you’ve obtained the correct version that corresponds to your specific OS type and Oracle Database version.

    Create a directory to unzip the patch.

    mkdir /u01/patch
    cd /stage_soft/
    unzip p35320081_190000_Linux-x86-64.zip -d /u01/patch/

    
    
    cd /u01/patch/
    [oracle@sql patch]$ ll
    total 1712
    drwxr-xr-x. 5 oracle oinstall      81 Jul 15 19:54 35320081
    -rw-rw-r--. 1 oracle oinstall 1749054 Jul 18 13:03 PatchSearch.xml
    [oracle@sql patch]$ 

    Gather details about active instances, the listener, patch inventory, the oratab file, and create a backup of the relevant ORACLE_HOME.

    [oracle@sql patch]$ mkdir prechecks
    [oracle@sql patch]$ 
    [oracle@sql patch]$ 
    [oracle@sql patch]$ cd prechecks/
    [oracle@sql prechecks]$ 
    [oracle@sql prechecks]$ ps -ef |grep pmon > /u01/patch/prechecks/current_instance.txt
    [oracle@sql prechecks]$ ps -ef |grep tns > /u01/patch/prechecks/current_tns.txt
    [oracle@sql prechecks]$ cat /etc/oratab > /u01/patch/prechecks/current_oratab.txt
    [oracle@sql prechecks]$ $ORACLE_HOME/OPatch/opatch lsinventory > /u01/patch/prechecks/current_lsinv.txt
    [oracle@sql prechecks]$ 
    [oracle@sql prechecks]$ 
    [oracle@sql prechecks]$ 
    [oracle@sql prechecks]$ ls -lrta
    total 24
    drwxr-xr-x. 4 oracle oinstall   62 Aug 21 14:58 ..
    -rw-r--r--. 1 oracle oinstall   71 Aug 21 14:58 current_instance.txt
    -rw-r--r--. 1 oracle oinstall  126 Aug 21 14:59 current_tns.txt
    -rw-r--r--. 1 oracle oinstall  785 Aug 21 14:59 current_oratab.txt
    drwxr-xr-x. 2 oracle oinstall  108 Aug 21 15:00 .
    -rw-r--r--. 1 oracle oinstall 8728 Aug 21 15:00 current_lsinv.txt
    [oracle@sql prechecks]$ 
    [oracle@sql prechecks]$ 
    

    Check for any potential conflicts between the currently installed interim patches and the patch you’re planning to install.

    [oracle@sql 35320081]$ $ORACLE_HOME/OPatch/opatch prereq CheckConflictAgainstOHWithDetail -ph ./
    Oracle Interim Patch Installer version 12.2.0.1.39
    Copyright (c) 2023, Oracle Corporation.  All rights reserved.
    
    PREREQ session
    
    Oracle Home       : /u01/app/oracle/product/19.3/db_home
    Central Inventory : /u01/app/oraInventory
       from           : /u01/app/oracle/product/19.3/db_home/oraInst.loc
    OPatch version    : 12.2.0.1.39
    OUI version       : 12.2.0.7.0
    Log file location : /u01/app/oracle/product/19.3/db_home/cfgtoollogs/opatch/opatch2023-08-21_15-27-06PM_1.log
    
    Invoking prereq "checkconflictagainstohwithdetail"
    
    Prereq "checkConflictAgainstOHWithDetail" passed.
    
    OPatch succeeded.
    [oracle@sql 35320081]$ 

    Make sure to stop all services running from the Oracle home where the patching is taking place. This includes shutting down any databases and the listener that are associated with the same ORACLE_HOME as the patch being applied.

    [oracle@sql 35320081]$ lsnrctl stop
    
    LSNRCTL for Linux: Version 19.0.0.0.0 - Production on 21-AUG-2023 15:39:44
    
    Copyright (c) 1991, 2019, Oracle.  All rights reserved.
    
    Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=sql.dbace.in)(PORT=1521)))
    The command completed successfully
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ sqlplus / as sysdba
    
    SQL*Plus: Release 19.0.0.0.0 - Production on Mon Aug 21 15:39:50 2023
    Version 19.3.0.0.0
    
    Copyright (c) 1982, 2019, Oracle.  All rights reserved.
    
    
    Connected to:
    Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
    Version 19.3.0.0.0
    
    SQL> 
    SQL> 
    SQL> shut immediate
    Database closed.
    Database dismounted.
    ORACLE instance shut down.
    SQL> 

    Check for the services are stopped.

    [oracle@sql 35320081]$ ps -ef|grep pmon
    oracle    7831  3040  0 15:42 pts/0    00:00:00 grep --color=auto pmon
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ ps -ef|grep tns
    root        23     2  0 14:03 ?        00:00:00 [netns]
    oracle    7837  3040  0 15:42 pts/0    00:00:00 grep --color=auto tns
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ ps -ef|grep exp
    oracle    7845  3040  0 15:42 pts/0    00:00:00 grep --color=auto exp
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ 
    [oracle@sql 35320081]$ ps -ef|grep rman
    oracle    7852  3040  0 15:42 pts/0    00:00:00 grep --color=auto rman

    Navigate to the directory where the patch is located, and then execute the opatch utility using the following commands:

    cd /u01/patch/35320081

    Start applying Patch

    [oracle@sql 35320081]$ $ORACLE_HOME/OPatch/opatch apply
    Oracle Interim Patch Installer version 12.2.0.1.39
    Copyright (c) 2023, Oracle Corporation.  All rights reserved.
    
    
    Oracle Home       : /u01/app/oracle/product/19.3/db_home
    Central Inventory : /u01/app/oraInventory
       from           : /u01/app/oracle/product/19.3/db_home/oraInst.loc
    OPatch version    : 12.2.0.1.39
    OUI version       : 12.2.0.7.0
    Log file location : /u01/app/oracle/product/19.3/db_home/cfgtoollogs/opatch/opatch2023-08-21_16-01-18PM_1.log
    
    Verifying environment and performing prerequisite checks...
    OPatch continues with these patches:   35320081  
    
    Do you want to proceed? [y|n]
    y
    User Responded with: Y
    All checks passed.
    
    Please shutdown Oracle instances running out of this ORACLE_HOME on the local system.
    (Oracle Home = '/u01/app/oracle/product/19.3/db_home')
    
    
    Is the local system ready for patching? [y|n]
    y
    User Responded with: Y
    Backing up files...
    Applying interim patch '35320081' to OH '/u01/app/oracle/product/19.3/db_home'
    ApplySession: Optional component(s) [ oracle.network.gsm, 19.0.0.0.0 ] , [ oracle.rdbms.ic, 19.0.0.0.0 ] , [ oracle.rdbms.tg4db2, 19.0.0.0.0 ] , [ oracle.tfa, 19.0.0.0.0 ] , [ oracle.rdbms.tg4msql, 19.0.0.0.0 ] , [ oracle.options.olap, 19.0.0.0.0 ] , [ oracle.ons.cclient, 19.0.0.0.0 ] , [ oracle.network.cman, 19.0.0.0.0 ] , [ oracle.rdbms.tg4ifmx, 19.0.0.0.0 ] , [ oracle.rdbms.tg4sybs, 19.0.0.0.0 ] , [ oracle.net.cman, 19.0.0.0.0 ] , [ oracle.rdbms.tg4tera, 19.0.0.0.0 ] , [ oracle.sdo.companion, 19.0.0.0.0 ] , [ oracle.oid.client, 19.0.0.0.0 ] , [ oracle.xdk.companion, 19.0.0.0.0 ] , [ oracle.ons.eons.bwcompat, 19.0.0.0.0 ] , [ oracle.options.olap.api, 19.0.0.0.0 ] , [ oracle.jdk, 1.8.0.191.0 ]  not present in the Oracle Home or a higher version is found.
    
    Patching component oracle.rdbms, 19.0.0.0.0...
    
    Patching component oracle.rdbms.util, 19.0.0.0.0...
    
    Patching component oracle.rdbms.rsf, 19.0.0.0.0...
    
    Patching component oracle.assistants.acf, 19.0.0.0.0...
    
    Patching component oracle.assistants.deconfig, 19.0.0.0.0...
    
    Patching component oracle.assistants.server, 19.0.0.0.0...
    
    Patching component oracle.blaslapack, 19.0.0.0.0...
    
    Patching component oracle.buildtools.rsf, 19.0.0.0.0...
    
    Patching component oracle.ctx, 19.0.0.0.0...
    
    Patching component oracle.dbdev, 19.0.0.0.0...
    
    Patching component oracle.dbjava.ic, 19.0.0.0.0...
    
    Patching component oracle.dbjava.jdbc, 19.0.0.0.0...
    
    Patching component oracle.dbjava.ucp, 19.0.0.0.0...
    
    Patching component oracle.duma, 19.0.0.0.0...
    
    Patching component oracle.javavm.client, 19.0.0.0.0...
    
    Patching component oracle.ldap.owm, 19.0.0.0.0...
    
    Patching component oracle.ldap.rsf, 19.0.0.0.0...
    
    Patching component oracle.ldap.security.osdt, 19.0.0.0.0...
    
    Patching component oracle.marvel, 19.0.0.0.0...
    
    Patching component oracle.network.rsf, 19.0.0.0.0...
    
    Patching component oracle.odbc.ic, 19.0.0.0.0...
    
    Patching component oracle.ons, 19.0.0.0.0...
    
    Patching component oracle.ons.ic, 19.0.0.0.0...
    
    Patching component oracle.oracore.rsf, 19.0.0.0.0...
    
    Patching component oracle.perlint, 5.28.1.0.0...
    
    Patching component oracle.precomp.common.core, 19.0.0.0.0...
    
    Patching component oracle.precomp.rsf, 19.0.0.0.0...
    
    Patching component oracle.rdbms.crs, 19.0.0.0.0...
    
    Patching component oracle.rdbms.dbscripts, 19.0.0.0.0...
    
    Patching component oracle.rdbms.deconfig, 19.0.0.0.0...
    
    Patching component oracle.rdbms.oci, 19.0.0.0.0...
    
    Patching component oracle.rdbms.rsf.ic, 19.0.0.0.0...
    
    Patching component oracle.rdbms.scheduler, 19.0.0.0.0...
    
    Patching component oracle.rhp.db, 19.0.0.0.0...
    
    Patching component oracle.sdo, 19.0.0.0.0...
    
    Patching component oracle.sdo.locator.jrf, 19.0.0.0.0...
    
    Patching component oracle.sqlplus, 19.0.0.0.0...
    
    Patching component oracle.sqlplus.ic, 19.0.0.0.0...
    
    Patching component oracle.wwg.plsql, 19.0.0.0.0...
    
    Patching component oracle.xdk.parser.java, 19.0.0.0.0...
    
    Patching component oracle.ldap.ssl, 19.0.0.0.0...
    
    Patching component oracle.ctx.rsf, 19.0.0.0.0...
    
    Patching component oracle.rdbms.dv, 19.0.0.0.0...
    
    Patching component oracle.rdbms.drdaas, 19.0.0.0.0...
    
    Patching component oracle.network.client, 19.0.0.0.0...
    
    Patching component oracle.rdbms.hsodbc, 19.0.0.0.0...
    
    Patching component oracle.network.listener, 19.0.0.0.0...
    
    Patching component oracle.ldap.rsf.ic, 19.0.0.0.0...
    
    Patching component oracle.dbtoolslistener, 19.0.0.0.0...
    
    Patching component oracle.nlsrtl.rsf, 19.0.0.0.0...
    
    Patching component oracle.xdk.xquery, 19.0.0.0.0...
    
    Patching component oracle.rdbms.install.common, 19.0.0.0.0...
    
    Patching component oracle.ovm, 19.0.0.0.0...
    
    Patching component oracle.oraolap, 19.0.0.0.0...
    
    Patching component oracle.rdbms.rman, 19.0.0.0.0...
    
    Patching component oracle.install.deinstalltool, 19.0.0.0.0...
    
    Patching component oracle.rdbms.install.plugins, 19.0.0.0.0...
    
    Patching component oracle.rdbms.lbac, 19.0.0.0.0...
    
    Patching component oracle.sdo.locator, 19.0.0.0.0...
    
    Patching component oracle.oraolap.dbscripts, 19.0.0.0.0...
    
    Patching component oracle.oraolap.api, 19.0.0.0.0...
    
    Patching component oracle.ctx.atg, 19.0.0.0.0...
    
    Patching component oracle.javavm.server, 19.0.0.0.0...
    
    Patching component oracle.rdbms.hs_common, 19.0.0.0.0...
    
    Patching component oracle.xdk, 19.0.0.0.0...
    
    Patching component oracle.xdk.rsf, 19.0.0.0.0...
    
    Patching component oracle.ldap.client, 19.0.0.0.0...
    
    Patching component oracle.mgw.common, 19.0.0.0.0...
    
    Patching component oracle.odbc, 19.0.0.0.0...
    
    Patching component oracle.precomp.lang, 19.0.0.0.0...
    
    Patching component oracle.precomp.common, 19.0.0.0.0...
    
    Patching component oracle.jdk, 1.8.0.201.0...
    Patch 35320081 successfully applied.
    Sub-set patch [29517242] has become inactive due to the application of a super-set patch [35320081].
    Please refer to Doc ID 2161861.1 for any possible further required actions.
    Log file location: /u01/app/oracle/product/19.3/db_home/cfgtoollogs/opatch/opatch2023-08-21_16-01-18PM_1.log
    
    OPatch succeeded.
    [oracle@sql 35320081]$ 

    After installing the patch:

    Verify that the applied Oracle Home patch is registered in the inventory.

    [oracle@sql 35320081]$ $ORACLE_HOME/OPatch/opatch lspatches
    35320081;Database Release Update : 19.20.0.0.230718 (35320081)
    29585399;OCW RELEASE UPDATE 19.3.0.0.0 (29585399)
    
    OPatch succeeded.
    [oracle@sql 35320081]$ 

    Start Oracle Service

    [oracle@sql 35320081]$ sqlplus / as sysdba
    
    SQL*Plus: Release 19.0.0.0.0 - Production on Mon Aug 21 16:22:24 2023
    Version 19.20.0.0.0
    
    Copyright (c) 1982, 2022, Oracle.  All rights reserved.
    
    Connected to an idle instance.
    
    SQL> startup
    ORACLE instance started.
    
    Total System Global Area 2415917856 bytes
    Fixed Size		    8928032 bytes
    Variable Size		  520093696 bytes
    Database Buffers	 1879048192 bytes
    Redo Buffers		    7847936 bytes
    Database mounted.
    Database opened.
    SQL> 
    SQL> 
    SQL> 
    SQL> exit
    Disconnected from Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
    Version 19.20.0.0.0

    RunPerform the necessary post-patch procedures and execute the “datapatch” command.

    [oracle@sql 35320081]$ cd $ORACLE_HOME/OPatch
    [oracle@sql OPatch]$ 
    [oracle@sql OPatch]$ 
    [oracle@sql OPatch]$ ./datapatch -verbose
    SQL Patching tool version 19.20.0.0.0 Production on Mon Aug 21 16:25:43 2023
    Copyright (c) 2012, 2023, Oracle.  All rights reserved.
    
    Log file for this invocation: /u01/app/oracle/cfgtoollogs/sqlpatch/sqlpatch_13350_2023_08_21_16_25_43/sqlpatch_invocation.log
    
    Connecting to database...OK
    Gathering database info...done
    Bootstrapping registry and package to current versions...done
    Determining current state...done
    
    Current state of interim SQL patches:
      No interim patches found
    
    Current state of release update SQL patches:
      Binary registry:
        19.20.0.0.0 Release_Update 230715022800: Installed
      SQL registry:
        Applied 19.3.0.0.0 Release_Update 190410122720 successfully on 21-AUG-23 08.58.21.281567 AM
    
    Adding patches to installation queue and performing prereq checks...done
    Installation queue:
      No interim patches need to be rolled back
      Patch 35320081 (Database Release Update : 19.20.0.0.230718 (35320081)):
        Apply from 19.3.0.0.0 Release_Update 190410122720 to 19.20.0.0.0 Release_Update 230715022800
      No interim patches need to be applied
    
    Installing patches...
    Patch installation complete.  Total patches installed: 1
    
    Validating logfiles...done
    Patch 35320081 apply: SUCCESS
      logfile: /u01/app/oracle/cfgtoollogs/sqlpatch/35320081/25314491/35320081_apply_TEST_2023Aug21_16_26_19.log (no errors)
    SQL Patching tool complete on Mon Aug 21 16:33:05 2023
    [oracle@sql OPatch]$ 

    Validate the patches applied to the database

    SQL> 
    SET PAGES 55
    SET LINESIZE 601
    COLUMN ACTION_TIME FORMAT A21
    COLUMN ACTION FORMAT A11
    COLUMN STATUS FORMAT A11
    COLUMN DESCRIPTION FORMAT A55
    COLUMN VERSION FORMAT A11
    COLUMN BUNDLE_SERIES FORMAT A11
    SELECT TO_CHAR(ACTION_TIME, 'DD-MON-YYYY HH24:MI:SS') AS ACTION_TIME, PATCH_TYPE, ACTION,STATUS,DESCRIPTION, SOURCE_VERSION,TARGET_VERSION, PATCH_ID FROM SYS.DBA_REGISTRY_SQLPATCH ORDER BY ACTION_TIME DESC;
    
      PATCH_ID ACTION     STATUS	 DESCRIPTION				  ACTION_TIME
    ---------- ---------- ---------- ---------------------------------------- --------------------
      29517242 APPLY      SUCCESS	 Database Release Update : 19.3.0.0.19041 21-AUG-23 08.58.21.2
    				 6 (29517242)				  81567 AM
    
      35320081 APPLY      SUCCESS	 Database Release Update : 19.20.0.0.2307 21-AUG-23 04.33.05.4
    				 18 (35320081)				  02900 PM

    Patching is done, start the Listener and services

    [oracle@sql OPatch]$ lsnrctl start
    
    LSNRCTL for Linux: Version 19.0.0.0.0 - Production on 21-AUG-2023 16:40:19
    
    Copyright (c) 1991, 2023, Oracle.  All rights reserved.
    
    Starting /u01/app/oracle/product/19.3/db_home/bin/tnslsnr: please wait...
    
    TNSLSNR for Linux: Version 19.0.0.0.0 - Production
    System parameter file is /u01/app/oracle/product/19.3/db_home/network/admin/listener.ora
    Log messages written to /u01/app/oracle/diag/tnslsnr/sql/listener/alert/log.xml
    Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=sql.dbace.in)(PORT=1521)))
    Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521)))
    
    Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=sql.dbace.in)(PORT=1521)))
    STATUS of the LISTENER
    ------------------------
    Alias                     LISTENER
    Version                   TNSLSNR for Linux: Version 19.0.0.0.0 - Production
    Start Date                21-AUG-2023 16:40:19
    Uptime                    0 days 0 hr. 0 min. 0 sec
    Trace Level               off
    Security                  ON: Local OS Authentication
    SNMP                      OFF
    Listener Parameter File   /u01/app/oracle/product/19.3/db_home/network/admin/listener.ora
    Listener Log File         /u01/app/oracle/diag/tnslsnr/sql/listener/alert/log.xml
    Listening Endpoints Summary...
      (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=sql.dbace.in)(PORT=1521)))
      (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521)))
    The listener supports no services
    The command completed successfully
    [oracle@sql OPatch]$ 

    Rollback

    Check existing patches

    Shutdown Database and Listener

    Rollback patch

    $ORACLE_HOME/OPatch/opatch rollback -id 35320081

    Start the Database and Listener

    Rollback SQL changes (datapatch)

    $ORACLE_HOME/OPatch/datapatch -verbose

    Check Registry Status

    sqlplus / as sysdba
    SET LINESIZE 500
    SET PAGESIZE 1000
    SET SERVEROUT ON
    SET LONG 2000000
    
    COLUMN action_time FORMAT A25
    COLUMN action FORMAT A10
    COLUMN bundle_series FORMAT A4 
    COLUMN comments FORMAT A30
    COLUMN description FORMAT A40
    COLUMN namespace FORMAT A20
    COLUMN status FORMAT A10
    COLUMN version FORMAT A10
    
    SELECT TO_CHAR(action_time, 'DD-MON-YYYY HH24:MI:SS') AS action_time,
     action,
     status,
     description,
     version,
     patch_id,
     bundle_series
     FROM   sys.dba_registry_sqlpatch
     ORDER by action_time;