Tuesday, December 10, 2024

Dataguard Switchover Using DGMGRL

 A switchover is a role reversal between the primary database and one of its standby databases. A switchover guarantees no data loss.

This is typically done for planned maintenance of the primary system.
During a switchover, the primary database transitions to a standby role and the standby database transitions to the primary role

The role of the primary database and a standby database is going to change using the SWITCHOVER command

The broker configuration file is updated to reflect the change in roles.

DETAILS SOURCE TARGET

IP_ADDRESS 192.168.1.44         192.168.1.37

SERVER_NAME PRIMARY STANDBY

DB_VERSION 19.3.0.0                 19.3.0.0

DB_NAME PROD         STANDBY

CHECK THE DATABASE STATUS : 

DGMGRL> show configuration

Configuration – samiora

Protection Mode: MaxPerformance
Members:
PROD – Primary database
STANDBY – Physical standby database

Fast-Start Failover: Disabled

Configuration Status:
SUCCESS (status updated 42 seconds ago)

Check the  Database Is Ready for a Role Change

It will checks whether it is ready for switchover.

DGMGRL> VALIDATE DATABASE ‘prod’;
Database Role: Primary database
Ready for Switchover: Yes
Flashback Database Status:
prime: Off
DGMGRL> VALIDATE DATABASE ‘standby’;
Database Role: Physical standby database
Primary Database: prime
Ready for Switchover: Yes
Ready for Failover: Yes (Primary Running)
Flashback Database Status:
prime: Off
stand: Off

PERFORM THE SWITCHOVER OPERATION :

DGMGRL> switchover to standby;
Performing switchover NOW, please wait…
Operation requires a connection to database “STANDBY”
Connecting …
Connected to “STANDBY”
Connected as SYSDBA.
New primary database “STANDBY” is opening…
Operation requires start up of instance “prod” on database “BALL”
Starting instance “prod”…
Connected to an idle instance.
ORACLE instance started.
Connected to “PROD”
Database mounted.
Connected to “PROD”
Switchover succeeded, new primary is “standby”
DGMGRL>

CHECK THE STATUS IN DG_BROKER :

DGMGRL> show configuration

Configuration – samiora

Protection Mode: MaxPerformance
Members:
STANDBY – Primary database
PROD – Physical standby database

Fast-Start Failover: Disabled

Configuration Status:
SUCCESS (status updated 21 seconds ago)

VERIFY THE STATUS :

DGMGRL> show database ‘PROD‘;

Database – PROD

Role: PHYSICAL STANDBY
Intended State: APPLY-ON
Transport Lag: 0 seconds (computed 0 seconds ago)
Apply Lag: 0 seconds (computed 0 seconds ago)
Average Apply Rate: 7.00 KByte/s
Real Time Query: OFF
Instance(s):
PROD

Database Status:
SUCCESS

DGMGRL> SHOW DATABASE ‘STANDBY‘;

Database – STANDBY

Role: PRIMARY
Intended State: TRANSPORT-ON
Instance(s):
PROD

Database Status:
SUCCESS

Wednesday, November 20, 2024

Oracle DataGuard SWITCHOVER Primary to DR using DGMGRL

 Below are all the steps to be followed to SWITCHOVER from Primary to DR database using Oracle 19c DGMGRL broker utility. 

Prepare for the switchover

Before starting the switchover process, make sure that both the primary and standby databases are synchronized and that all required logs have been applied to the standby database. Also, ensure that the broker is configured and running on both the primary and standby sites.

Step 1: Check Archvie Gap

Before starting the switchover activity let's verify the archive gap between primary and standby.

On Primary:

SQL> select thread#, max(sequence#) "Last Primary Seq# Generated" from v$archived_log v, v$database d
where v.resetlogs_change# = d.resetlogs_change#
group by thread# order by 1;

   THREAD# Last Primary Seq# Generated
---------- ---------------------------
         1                          27

On Standby:

SQL> select thread#, max(sequence#) "Last Primary Seq# Generated" from v$archived_log v, v$database d
where v.resetlogs_change# = d.resetlogs_change#
group by thread# order by 1;  2    3

   THREAD# Last Primary Seq# Generated
---------- ---------------------------
         1                          27

Step 2: Connect to the broker

Connect to the broker using the dgmgrl utility on the primary database. For example, you can run the command "dgmgrl /" to connect to the default broker configuration.

[oracle@primary ~]$ dgmgrl sys/pwd
Welcome to DGMGRL, type "help" for information.
Connected to "digital"
Connected as SYSDBA.

Step 3: Verify the configuration

Verify that the broker configuration is correct by running the "show configuration" command. This will display the current configuration settings for the broker.

DGMGRL> show configuration

Configuration - digital

  Protection Mode: MaxPerformance
  Members:
  digital - Primary database
    digidr  - Physical standby database

Fast-Start Failover:  Disabled

Configuration Status:
SUCCESS   (status updated 51 seconds ago)

In this configuration, we have Primary Database "DIGITAL" and the standby Database is "DIGIDR".

Step 4: Prepare for the switchover

Prepare for the switchover by running the "validate database" command to ensure that both the primary and standby databases are ready for switchover.

Validate Primary Database

DGMGRL> validate database digital;

  Database Role:    Primary database

  Ready for Switchover:  Yes

  Flashback Database Status:
    digital:  Off

  Managed by Clusterware:
    digital:  NO
    Validating static connect identifier for the primary database digital...
    The static connect identifier allows for a connection to database "digital".

Validate Standby Database

DGMGRL> validate database digidr;

  Database Role:     Physical standby database
  Primary Database:  digital

  Ready for Switchover:  Yes
  Ready for Failover:    Yes (Primary Running)

  Flashback Database Status:
    digital:  Off
    digidr :  Off

  Managed by Clusterware:
    digital:  NO
    digidr :  NO
    Validating static connect identifier for the primary database digital...
    The static connect identifier allows for a connection to database "digital".

  Current Log File Groups Configuration:
    Thread #  Online Redo Log Groups  Standby Redo Log Groups Status
              (digital)               (digidr)
    1         3                       2                       Insufficient SRLs

  Future Log File Groups Configuration:
    Thread #  Online Redo Log Groups  Standby Redo Log Groups Status
              (digidr)                (digital)
    1         3                       0                       Insufficient SRLs
    Warning: standby redo logs not configured for thread 1 on digital

Step 5: Initiate the switchover

Initiate the switchover by running the "switchover to " command in dgmgrl. This will start the switchover process and automatically failover the primary database to the standby database.

DGMGRL> switchover to digidr;
Performing switchover NOW, please wait...
Operation requires a connection to database "digidr"
Connecting ...
Connected to "digidr"
Connected as SYSDBA.
New primary database "digidr" is opening...
Operation requires start up of instance "digital" on database "digital"
Starting instance "digital"...
Connected to an idle instance.
ORACLE instance started.
Connected to "digital"
Database mounted.
Database opened.
Connected to "digital"
Switchover succeeded, new primary is "digidr"

Step 6: Verify the switchover

After the switchover, verify that the new primary database is running by running the "show database" command in dgmgrl.

Current Primary digidr

DGMGRL> show database digidr

Database - digidr

  Role:               PRIMARY
  Intended State:     TRANSPORT-ON
  Instance(s):
    digidr

Database Status:
SUCCESS

Current standby digital

DGMGRL> show database digital

Database - digital

  Role:               PHYSICAL STANDBY
  Intended State:     APPLY-ON
  Transport Lag:      0 seconds (computed 0 seconds ago)
  Apply Lag:          0 seconds (computed 0 seconds ago)
  Average Apply Rate: 0 Byte/s
  Real Time Query:    ON
  Instance(s):
    digital

Database Status:
SUCCESS

Database Warnings

Sometimes you will face the below error, then you have to check the log_archive_dest_1 and log_archive_dest_2 parameter on the standby side and configure it properly.

DGMGRL> show database digital

Database - digital

  Role:               PHYSICAL STANDBY
  Intended State:     APPLY-ON
  Transport Lag:      (unknown)
  Apply Lag:          (unknown)
  Average Apply Rate: (unknown)
  Real Time Query:    ON
  Instance(s):
    digital

  Database Warning(s):
    ORA-16854: apply lag could not be determined
    ORA-16856: transport lag could not be determined
    ORA-16858: last communication time from redo source could not be determined

Database Status:
WARNING


DGMGRL> show database digidr;

Database - digidr

  Role:               PRIMARY
  Intended State:     TRANSPORT-ON
  Instance(s):
    digidr
      Error: ORA-16736: unable to find the destination entry of member "digital" in V$ARCHIVE_DEST
      Warning: ORA-16728: consistency check for property RedoRoutes found ORA-16777 error
      Warning: ORA-16777: unable to find the destination entry of a member in V$ARCHIVE_DEST
      Warning: ORA-16728: consistency check for property LogXptMode found ORA-16777 error
      Warning: ORA-16777: unable to find the destination entry of a member in V$ARCHIVE_DEST
      Warning: ORA-16728: consistency check for property DelayMins found ORA-16777 error
      Warning: ORA-16777: unable to find the destination entry of a member in V$ARCHIVE_DEST
      Warning: ORA-16728: consistency check for property Binding found ORA-16777 error
      Warning: ORA-16777: unable to find the destination entry of a member in V$ARCHIVE_DEST
      Warning: ORA-16728: consistency check for property MaxFailure found ORA-16777 error
      Warning: ORA-16777: unable to find the destination entry of a member in V$ARCHIVE_DEST
      Warning: ORA-16728: consistency check for property ReopenSecs found ORA-16777 error
      Warning: ORA-16777: unable to find the destination entry of a member in V$ARCHIVE_DEST
      Warning: ORA-16728: consistency check for property RedoCompression found ORA-16777 error
      Warning: ORA-16777: unable to find the destination entry of a member in V$ARCHIVE_DEST

Database Status:
ERROR

Step 7: Reconfigure the environment

If necessary, reconfigure the environment to point to the new primary database. For example, update connection strings, DNS entries, or load balancer settings to point to the new primary database.

Step 8: Start Recovery

After the switchover start the MRP process using the broker or manually.

Enable with Broker:

DGMGRL> EDIT DATABASE digital SET STATE='APPLY-ON';
Succeeded.

Check MRP status using SQL command, if no row is selected that means MRP is disabled.

SQL> select inst_id, process, status from gv$managed_standby where process='MRP0';

   INST_ID PROCESS   STATUS
---------- --------- ------------
         1 MRP0      APPLYING_LOG

Disable with Broker

DGMGRL> EDIT DATABASE digital SET STATE='APPLY-OFF';

Enable/Disable manually:

SQL> alter database recover managed standby database disconect from session;

SQL> alter database recover managed standby database cancel;

Note

Note that the exact steps for performing a switchover using a broker may vary depending on your specific configuration and requirements. It is important to carefully review the Oracle Data Guard documentation and consult with experienced database administrators before attempting a switchover.

Tuesday, October 1, 2024

Change PostgreSQL DATA DIRECTORY to a New location

 In PostgreSQL, the database files are typically stored in the data directory, which contains the configuration files, database clusters, and other essential files. The exact location of the data directory depends on your PostgreSQL installation and operating system.

Here are common locations for the PostgreSQL data directory:

1. Linux-based systems

  • The data directory is usually located in:
    • /var/lib/postgresql/<version>/main/
    • Example: /var/lib/postgresql/12/main/

You can find the location by checking the PostgreSQL service file or querying the database.

2. Windows

  • On Windows, the default data directory might be:
    • C:\Program Files\PostgreSQL\<version>\data
    • Example: C:\Program Files\PostgreSQL\13\data

3. macOS

  • If PostgreSQL is installed via Homebrew, the data directory is typically:
    • /usr/local/var/postgres

4. Custom Installations

  • If PostgreSQL was compiled from source or installed in a custom location, the data directory will be specified during the initialization of the database cluster using the initdb command. In that case, it would be the path you specified.

Finding the Data Directory in PostgreSQL

You can determine the exact location of the data directory by running the following SQL query in the PostgreSQL environment:

postgers=# SHOW data_directory;

data_directory
/var/lib/postgresql/12/main

To change the location of the PostgreSQL data directory, you need to follow a series of steps carefully. The process involves stopping the PostgreSQL service, moving the data files to the new location, configuring PostgreSQL to use the new directory, and starting the service again.

Here’s a step-by-step guide:

1. Stop the PostgreSQL Service

Before moving any files, stop the PostgreSQL service to avoid any corruption or data loss.

  • On Linux (systemd):

sudo systemctl stop postgresql

  • On Windows: Stop the PostgreSQL service via the Services app (services.msc), or run:

net stop postgresql

2. Copy the Data Directory to the New Location

Next, move the contents of the current data directory to the new location. Be sure to use a command that preserves file permissions and ownership.

  • On Linux:

sudo rsync -av /current/data/directory/ /new/data/directory/

  • On Windows: Use file explorer or the command prompt to move the files:

xcopy "C:\current\data\directory" "D:\new\data\directory" /E /I /H /K /O /X /Y

3. Update PostgreSQL Configuration

Now, you need to update the PostgreSQL configuration to point to the new data directory.

  • For Linux (systemd):

    1. Open the PostgreSQL service configuration file (usually located in /etc/postgresql/<version>/main/postgresql.conf).
    2. Modify the data_directory parameter

data_directory = '/new/data/directory'

For Windows:

  1. Open the PostgreSQL configuration file (postgresql.conf) located in the PostgreSQL installation directory.
  2. Update the data_directory setting to point to the new location.

4. Set the Correct Ownership and Permissions

Ensure that the new data directory has the correct ownership and permissions.

  • On Linux: Change ownership to the PostgreSQL user (usually postgres):

sudo chown -R postgres:postgres /new/data/directory

sudo chmod 700 /new/data/directory

  • On Windows: Ensure that the user running PostgreSQL (usually NETWORK SERVICE or postgres) has full control over the new directory.

5. Start PostgreSQL with the New Data Directory

Start PostgreSQL, and it should now use the new data directory.

  • On Linux (systemd):

sudo systemctl start postgresql

  • On Windows: Start the service from the Services app or via command:

net start postgresql

6. Verify the New Data Directory

After starting PostgreSQL, verify that it’s using the new data directory by running the following command:

postgres=# SHOW data_directory;

data_directory 

  /new/data/directory 

(1 row)

7. Clean Up (Optional)

After confirming that everything works correctly, you can remove the old data directory to free up space:

sudo rm -rf /old/data/directory

Be careful with this step#7 and make sure the new setup is fully functional before
deleting the old files.

For any DBA related questions on below databases, please email me samiappsdba@gmail.com
Oracle, Oracle EBS Apps DBA, PostgreSQL, Microsoft SQL Server, IBM DB2

Thursday, September 5, 2024

Top Oracle Commands & Utilities

1. Oracle Database Commands and Tools:

- SQL*Plus: A command-line tool used for running SQL and PL/SQL commands and scripts against Oracle databases.
- expdp (Export Data Pump): Used to export data and metadata from an Oracle database into a set of dump files.
- impdp (Import Data Pump): Used to import data and metadata from dump files into an Oracle database.
- DBCA (Database Configuration Assistant): DBCA is a utility provided by Oracle to simplify the creation, configuration, and management of Oracle databases.
- DBUA (Database Upgrade Assistant): DBUA is a utility provided by Oracle to automate the process of upgrading an existing Oracle database to a newer version.
- NETCA (Network Configuration Assistant): is a GUI utility that simplifies the configuration of Oracle network components.
- NETMGR (Oracle Net Manager): is a more advanced and flexible tool compared to NETCA, providing a graphical interface for detailed configuration of Oracle Net Services.
- RMAN (Recovery Manager): A command-line interface for performing backup and recovery operations in Oracle databases.

2. Golden Gate Commands:
- GGSCI (GoldenGate Software Command Interface): Used for managing, configuring, and monitoring Oracle GoldenGate processes.
- OGGCA (Oracle GoldenGate Configuration Assistant): A command-line tool for configuring Oracle GoldenGate instances.
- Logdump: A utility for viewing and analyzing trail files generated by Oracle GoldenGate.
- DEFGEN (Definition File Generator): A command-line tool used to generate definition files in heterogeneous environments.

3. Oracle Grid Infra Commands:
- CRSCTL (Cluster Ready Services Control Utility): Used to manage Oracle Clusterware components.
- SRVCTL (Service Control): Used for managing Oracle RAC databases and other resources within the cluster.
- ASMCMD (ASM Command Line Utility): A command-line tool for managing Oracle ASM instances and disks.
- CLUVFY (Cluster Verification Utility): A tool for verifying the integrity and proper configuration of Oracle RAC and Oracle Grid Infrastructure.
- CRSSTAT: A utility that provides a summary of the current status of all cluster resources.
- OCRCONFIG: Used to manage the Oracle Cluster Registry (OCR).

4. Additional commands:
-dbcli (Database Command Line Interface): Used on Oracle OCI Cloud to apply patches and upgrade oracle software like database oracle home.
- EMCLI (Oracle Enterprise Manager CLI): Used to manage and automate Oracle Enterprise Manager operations via scripts.
- OPatch: A tool for applying and rolling back patches in Oracle software installations.
- ADRCI (Automatic Diagnostic Repository Command Interpreter): Used for managing diagnostic data such as alert logs, trace files, and incidents.
- ORAPWD (Oracle Password Utility): Used for creating and managing password files for Oracle databases.
- ORAPKI (Oracle Public Key Infrastructure): is a command-line utility provided by Oracle for managing security credentials.
- DGMGRL (Data Guard Manager Command-Line Interface): is the primary command-line interface for managing Oracle Data Guard configurations.



Saturday, August 10, 2024

Display Oracle RAC Cluster Name

 Below are different ways to know the RAC cluster name,

1. The command “cemutlo” provides cluster name and version.

$GI_HOME/bin/cemutlo [-n] [-w]

[oracle@rac1 ~]$ cemutlo -n
sami-rac-scan <—– This is the Cluster name.

2. $CRS_HOME/cdata/<cluster_name> directory

3. ocrdump
which will create a text file called OCRDUMPFILE open that file and look for this entry
+[SYSTEM.css.clustername]+ ORATEXT : crs_cluster In this case, “crs_cluster” is the cluster name.

4. gpnptool get
search for keyword “ClusterName

5. ASM SP File location
[root@rac1 ]# gpnptool getpval -asm_spf (or) SQL> show parameter spfile 
+DATA/<clusterName>/asmparameterfile/registry.253.783619900

Note: We cannot change the cluster name. 

The only way to change the cluster name is to reinstall the Clusterware and provide a new name to the cluster. 

Tuesday, July 30, 2024

IBM DB2 STOP and START

 #!/bin/bash

# Function to stop Db2
stop_db2() {
echo “Stopping Db2…”
db2stop
if [ $? -eq 0 ]; then
echo “Db2 stopped successfully.”
else
echo “Regular stop failed. Attempting forceful stop…”
db2stop force
if [ $? -eq 0 ]; then
echo “Db2 stopped forcefully.”
else
echo “Failed to stop Db2.”
fi
fi
}

# Function to start Db2
start_db2() {
echo “Starting Db2…”
db2start
if [ $? -eq 0 ]; then
echo “Db2 started successfully.”
else
echo “Failed to start Db2.”
fi
}

# Main script
if [ “$1” == “stop” ]; then
stop_db2
elif [ “$1” == “start” ]; then
start_db2
else
echo “Usage: $0 [stop|start]”
exit 1
fi