Saturday, 27 June 2015

Enabling Automatic Memory Management (AMM) :


SQL> show parameter target


    NAME                                               TYPE        VALUE
    ------------------------------------ -----------       -------
    archive_lag_target                                     integer     0
    db_flashback_retention_target                  integer     1440
    fast_start_io_target                                   integer     0
    fast_start_mttr_target                                integer     0
    memory_max_target                                 big integer 26048M
    memory_target                                         big integer 0
    parallel_servers_target                              integer     2048
    pga_aggregate_target                               big integer 6502M
    sga_target                                                big integer 19520M

SQL> ALTER SYSTEM SET MEMORY_MAX_TARGET = 20000M scope=spfile ;

SQL > SHUTDOWN IMMEDIATE;
SQL > STARTUP ;

SQL> ALTER SYSTEM SET SGA_TARGET = 0 scope=spfile ;
System altered.

SQL> ALTER SYSTEM SET PGA_AGGREGATE_TARGET = 0 scope=spfile ;
System altered.

SQL> ALTER SYSTEM SET MEMORY_TARGET=12288M scope=spfile ;
System altered.
ORA-01940: cannot drop a user that is currently connected :


    SQL> drop user ANDY cascade ;
    drop user ANDY cascade
    *
    ERROR at line 1:
    ORA-01940: cannot drop a user that is currently connected


    SQL> select sid,serial# ,username from v$session where username like '%AND%';
           SID    SERIAL# USERNAME
    ---------- ---------- ------------------------------
           745        821 ANDY

    SQL> alter system kill session '745,821' immediate ;
    System altered.


    SQL> drop user ANDY ;
    drop user ANDY
    *
    ERROR at line 1:
    ORA-01940: cannot drop a user that is currently connected

Solution is :

    SQL> startup force restrict;
    ORACLE instance started.
    Total System Global Area 7686086656 bytes
    Fixed Size                  2228032 bytes
    Variable Size            1811939520 bytes
    Database Buffers         5729419264 bytes
    Redo Buffers              142499840 bytes
    Database mounted.
    Database opened.


     SQL> drop user ANDY cascade ;
    User dropped.

Friday, 26 June 2015

 Logical Standby Vs Physical Standby :


What is the difference between these two Data Guard configuration , When To Use them :

Physical Standby:

1- Physical Standby Database Its exactly same As Primary Database.
2-  In Physical Data Guard The archivelog Applied directly after transfer from primary database (FTP)

Properties of Physical Standby

1- Maintain Is Easy.
2- Creation is Easy .
3- Copy Of your Primary Database ( Disaster Recovery Solution ).

Usage :

High availability solutions Or disaster recovery Solution.

Logical Standby

1 - Opposite Of standby Database , Which is not Match primary Database .
2 - This Kind Of Configuration can be Opened in Read Only Mode .
3 - can have additional materialized views and indexes added for faster performance
4 - LogMiner Techniques to transfer Archivelog.

Properties Of Logical Database :

1 - Open In Read only Mode .
2 - Sometimes its used as RollBack Solution In Upgrade ,

Usage:

1 - reporting Database to avoid overhead in primary database.
2 - Query Database .


How they Works :

Regarding to Oracle documentation  :

LNS (log-write network-server) and ARCH (archiver) processes running on the primary database select archived redo logs and send them to the standby database, where the RFS (remote file server) background process within the Oracle instance performs the task of receiving archived redo-logs originating from the primary database.

Alternatively, a supplementary mechanism may transfer the archived redo logs. On the standby database a Fetch Archive Log (FAL) client monitors for gaps in the sequence of received logs. If it finds a gap, it may invoke one or more Fetch Archive Log (FAL) servers to run on the primary database to forward the missing item(s).

Once the archived redo logs have arrived, other processes (such as an ARCH (Archiver process), an MRP (Managed Recovery Process), and/or an LSP (Logical Standby Process)) may set about applying the log contents to the standby database.

 Conclusion :

The difference between physical and logical standby is in the way the changes from the primary are applied. Both created as an exact image of the primary database. Both receive redo logs from the primary database.

 Refernce :
 Oracle DataGuard architecture
Steps to convert Standby Database to Logical Standby Database :

Step #1 :

In this step logminer Dictionary Must be Built into redo data. ( Build LogMiner Tables for Dictionary)

On Primary

    SQL> begin
      2  dbms_logstdby.build;
      3  end ;
      4  /



OR

     SQL> execute dbms_logstdby.build;


Step #2:

Now we have stop Managed recovery between primary and standby :

On Standby :


    SQL> alter database recover managed standby database cancel ;

    Database altered.


Step #3 :

Convert Physical Standby to Logical Standby .

On Standby :


    SQL> alter database recover to logical standby stdby ;

    Database altered.


Step #4:

On Standby ( New Logical)  we open it in Resetlog mode .


On New Logical ( Standby) :

    SQL> shutdown immediate ;
    ORA-01507: database not mounted


    ORACLE instance shut down.

    SQL> startup mount ;
    ORACLE instance started.

    Total System Global Area  839282688 bytes
    Fixed Size                  2217992 bytes
    Variable Size             532678648 bytes
    Database Buffers          301989888 bytes
    Redo Buffers                2396160 bytes
    Database mounted.

    SQL>
    SQL>
    SQL> alter database open resetlogs ;

    Database altered.


Step #5:

Start Apply Service On logical


    SQL> alter database start logical standby apply ;

    Database altered.


OR


    SQL> alter database start logical standby apply immediate ;
    Database altered.


    Check if everything Goes Fine :

    SQL> select database_role , Name from v$database ;

    DATABASE_ROLE    NAME
    ---------------- ---------
    LOGICAL STANDBY  STDBY



Cheers!


 Startup/Shutdown Logical Standby Database :


Simple Steps to do that


Shutdown Steps :

On Primary do the following :

    SQL > alter system switch logfile ;
    SQL > alter system archive log current ;


Go to Standby :

    SQL> ALTER DATABASE STOP LOGICAL STANDBY APPLY;
    SQL> shutdown immediate;

Primary Database :

    SQL> shutdown immediate;


Startup Steps :

Primary Database


    SQL>startup;

 Standby Database:

    SQL > startup
    SQL > alter database start logical standby apply immediate;

Cheers!
ORA-01210: data file header is media corrupt

    ORA-00283: recovery session canceled due to errors
    ORA-01110: data file 24: 'D:\app\Ram\oradata\DATAGUARD\system02.DBF'
    ORA-01122: database file 24 failed verification check
    ORA-01110: data file 24: 'D:\app\Ram\oradata\DATAGUARD\system02.DBF'
    ORA-01210: data file header is media corrupt




Error Cause:
The file header block is internally inconsistent. The beginning of the block has a header with a checksum and other data for insuring the consistancy of the block. It is possible that the last disk write did not operate correctly. The most likely problem is that this is not a datafile for any database.


Solution :

Have operating system make correct file available to database. If the trace file dump indicates that only the checksum is wrong, restore from a backup and do media recovery.

 Or The Below Solution , You Must Be Sure that you have Valid Backup to restore it .


    SQL> shutdown immediate
    SQL > Startup mount
    SQL> ALTER DATABASE DATAFILE 'D:\app\Ramtech\oradata\dataguard\system02.DBF' OFFLINE ;
    SQL > ALTER database Open ;




Cheers!
Oracle Physical Standby Modes :

Regarding to Oracle Documents That Describe Standby Modes, There's Are Three Types you can follow the documentation.



Check Standby Modes :

SQL> select PROTECTION_MODE from v$database ;

PROTECTION_MODE
--------------------
MAXIMUM PERFORMANCE

prmdbary Database: prmdb
Standby Database: stldb


Note: the below Commands Should Apply on prmdbary Database on Mount Mode Then Open database.


Convert Between Modes (Switch Modes)


MAXIMIZE AVAILABILITY


SQL> alter system set log_archive_dest_2='SERVICE=stdby AFFIRM SYNC VALID_FOR=(online_logfiles,prmdbary_role) db_unique_name=stdby';
System altered.

 SQL> alter database set standby Database to MAXIMIZE AVAILABILITY ;
Database altered.

MAXIMIZE PERFORMANCE


 SQL>ALTER SYSTEM SET LOG_ARCHIVE_DEST_2='SERVICE=stby NOAFFIRM ASYNC VALID_FOR=(ONLINE_LOGFILES,prmdbARY_ROLE) DB_UNIQUE_NAME=stdby';
 System Altered 

SQL>ALTER DATABASE SET STANDBY DATABASE TO MAXIMIZE PERFORMANCE;
Database Altered

MAXIMIZE Proctection


SQL> alter system set log_archive_dest_2='SERVICE=stdby AFFIRM SYNC VALID_FOR=(online_logfiles,prmdbary_role) db_unique_name=stdby';
System altered.

shutdown immediate ;
Startup mount ;
Alter database set standby database to maximize Protection ;
Alter database open ;
ORA-01093: ALTER DATABASE CLOSE only permitted with no sessions connected ---
execute the following command while switchover.
 alter database commit to switchover to PHYSICAL STANDBY WITH SESSION SHUTDOWN;
Automatic Failover :

Data Guard has implemented something called Fast-start Failover (FSFO) which uses the Broker to perform the failover actions when there is a problem. This architecture uses a third member quorum that ensures that the failover occurs only when everything meets the rules that you have defined, when the failover has happened the primary will never be allowed to open to avoid any split-brain scenarios, this would be a bit of a nightmare should both databases be open and processing transactions.

The third member is called the Observer and its job is to maintain a connection with the primary and target standby databases, monitoring there health and performing any failover's necessary, the Observer will also reinstate the old primary when it comes back on, if it can. The observer pings the primary database and that the first sign of trouble it will start to countdown (which you configure), if it does re-establish the connection it will make all the necessary checks before goes back to watch mode again, if the timer expires then it checks that the standby can take over and initiates a failover, this switchover will have all automatically and in the background using the Broker. If and when the primary comes back the Observer will reinstate the old primary as a standby database again using the Broker to achieve this.

It is import on where he Observer is placed in the network, only one observer per Data Guard installation can be installed, so this server must have access to both the primary and standby databases with as much redundant networking as possible. Next your thing is how much is the observer going to cost me, not much as it can run on most platforms and only required the Oracle Client Kit for the version of Oracle that you are running, you must setup the TNSNAMES on the observer to allow it to ping the databases. If the Observer was to crash it will have no impact on the current Oracle environment, the only impact is that FSFO will not be available until the Observer is up and running again. The Observer can monitoring the following

    Database crash
    System crash
    The loss of the network
    Complete site outage

You can also get FSFO to perform a shutdown abort on the primary when other issues arise such as

    Datafile Offline
    Corrupted Controlfile
    Corrupted Dictionary
    Inaccessible Logfile
    Stuck Archiver

The tags above must be entered as they are above otherwise the Broker will not understand them
Monitor a specific condition via the Broker     DGMGRL> enable fast_start failover condition "Corrupted Controlfile";
DGMGRL> enable fast_start failover condition "Datafile Offline";

To display what you are monitoring use
Display conditions that are be monitored     DGMGRL> show fast_start failover;

Fast-Start Failover: DISABLED

Threshold: 30 seconds
Target: (none)
Observer: (none)
Lag Limit: 30 seconds
Shutdown Primary: TRUE
Auto-reinstate: TRUE

Configurable Failover Conditions
Health Conditions:
Corrupted Controlfile YES
Corrupted Dictionary YES
Inaccessible Logfile NO
Stuck Archiver NO
Datafile Offline YES

Oracle Error Conditions:
(none)

Now that you have an overview of FSFO it's time to set it up and test it, just a quick check before we progress, make sure that the following has been setup or configured

    Use the Broker with all its prerequisites
    Enable flashback database on both primary and standby
    Setup the configuration correctly for the protection mode (standby redo logs files on both sides, redo transport setup the same in both directions)
    Install the Observer system and configure TNSNAME

If you are using more than one standby you must let the Broker know which one you want to become the primary, if you only have one then the broker will know already
Select the standby to become the primary     DGMGRL> edit database prod1 set property FastStartFailoverTarget = 'prod1dr';
DGMGRL> edit database prod1dr set property FastStartFailoverTarget = 'prod1';

Now its time to discuss how long you should wait before you want to failover, you don't want it too short just in case you network blips, by default it is set to 30 seconds but you can go down to 6 seconds if you wish.
change threshold     DGMGRL> edit configuration set property FastStartFailoverTargetThreshold = 45;

You can control the amount of data loss, if using one of the lesser protection modes, the greater the lag limit set the greater the data loss, again the time is in seconds.
lag limit     DGMGRL> edit configuration set property FastStartFailoverLagLimit = 60;

If the data loss is less then the limit the failover will proceed, if more redo would be loss than the lag limit, the failover will not occur and nothing happens until the primary database either comes back and processing continues or you choose to failover manually, suffering the additional data loss. If you are using maximum protection mode then this property is ignored.

Here are two more additional properties that you can setup regarding the primary, one is to shutdown it down if it becomes hung and the other is to reinstate it if a failover does occur
abort primary if in a hung state     DGMGRL>edit configuration set property FastStartFailoverPmyShutdown = true;
reinstate primary after a failover     DGMGRL>edit configuration set property FastStartFailoverAutoReinstate = true;

Once you are happy with everything you can now enable the FSFO
Enable FSFO     DGMGRL> enable fast_start failover;

## Display the configuration

DGMGRL> show fast_start failover;

Once all setup you can test the FSFO by performing a shutdown abort on the primary, and checking that the failover occurs and that they primary is reinstated and with the amount of data loss expected if using the lesser protection modes. If you are using a test environment this is the time to experiment and play around with different settings. Again keep an eye on the log files including the Broker log file to see how Oracle handles the failover's and to become familiar with them.


Performing a Failover :

Hopefully you have prepared yourself as you never know when this will happen it could be in the middle of the night and you are awoken when your Boss calls you saying that the Production Data Center is no longer, but you will be ready as no chance of getting any redo from the primary as it is gone. Depending on the protection mode selected there may be some data loss but again everyone will be aware of this as it will be part of the DR documentation. Firstly you must choose a standby database to become the primary, if you have one standby in maximum protection mode then this would be the prime target as this is guaranteed to be synchronized with the primary database, below would be the choice of database to use
Mode    
Order
Maximum Protection Mode database    
1
Maximum Availability (SYNC)    
2
Maximum Availability (ASYNC)    
3
Maximum Performance (SYNC)    
4
Maximum Performance (ASYNC)    
  5

Basically choose any maximum protection mode database first, then maximum availability second, etc. If you have two database with the same protection and using SYNC, then you need to determine which one has the most redo to do this run the below command
Check redo applied     ## This will tell you the lag time

select name, value, time_computed from v$dataguard_stats where name like '%lag%';

## You can also use the SCN number

select thread#, sequence#, last_change#, last_time from v$standby_log;

Once you have a chosen a target we are ready to failover, firstly shutdown any other instances if you are using a RAC, hen tell the standby that it is to become the primary
the failover process (physical standby)    

## Start by telling the apply process that this standby is going to be the new primary, and to apply all
## the redo that it has

alter database recover managed standby database cancel;
alter database recover managed standby database finish;

## At this point the protection mode is lowered

select protection_mode from v$database;

## Now issue the switchover command and then open the database

alter database commit to switchover to primary with session shutdown;
alter database open;

## Startup the other RAC instances if using RAC

## You can then raise the protection mode (if desired)

set standby database to maximum protection;

If you want to failover to a logical standby then it's one command, there is no need to shutdown any other instances if using a RAC environment
the failover process (logical standby)     alter database activate logical standby database finish apply;

The Old Primary

The data center has now been fixed and the old primary is back online and you need to do this quick to make sure that you are protected again. If yo are not using failback database then you have to delete the original database and re-create it using the RMAN procedure I used in setting up a physical standby. If you have enabled flashback database then we can easily bring back the primary
bring back the old primary (physical standby)    

## Since redo is applied by SCN we need he failover SCN from the new primary

select to_char(standby_became_primary_scn) failover_scn from v$database;

FAILOVER_SCN
-----------------------------------------------
7658841

## Now flashback the old primary to this SCN and start in mount mode
startup mount;
flashback database to scn 7658841;
alter database convert to physical standby;
shutdown immediate;
startup mount;

## hopefully the old primary will start to resolve any gap issues at the next log switch, which means we can start the MRP
## process to get this standby going to catchup as fast as possible

alter database recover managed standby database using current logfile disconnect;

## eventually the missing redos will be sent to the standby and applied, bring us back to synchronization again.
bring back the old primary (logical standby)    

## again we need to obtained the SCN
select merge_change# as flashback_scn, processed_change# as recovery_scn from dba_logstdby_history where stream_sequence# = (select max(stream_sequence#)-1 from dba_logstdby_history);

flashback_scn      recovery_scn
---------------------------------------------------------
         7658941              7659568

## Now flashback the old primary to this SCN and start in mount mode
startup mount;
flashback database to scn 7658841;
alter database convert to physical standby;
shutdown immediate;
startup mount;

## Now we need to hand feed the archive logs from the primary to the standby (old primary) into the MRP
## process, so lets get those logs (run on the primary)

select file_name from dba_logstdby_log where first_changed# <= recovery_scn and next_change# > flashback_scn;

## Now you will hopefully have a short list of the files you need, now you need to register them with
## the standby database (old primary)

alter database register logfile '<files from above list>';

## Now you can recover up to the SCN but not including the one you specify
recover managed standby database until change 7659568;

## Now the standby database becomes a logical standby as up to this point it has been a physical one.
alter database active standby database;

## Lastly you need tell your new logical standby to ask the primary for a new copy of the dictionary and
## all the redo in between. The SQL Apply will connect to the new primary using the database link and
## retrieve the LogMiner dictionary, once the dictionary has been built, SQL Apply will apply all the
## redo sent from the new primary and get itself synchronized

create public database link reinstatelogical connect to system identified by password using 'service_name_of_new_primary_database';

alter database start logical standby apply new primary reinstatelogical;

At a convenient time you will perform a switchover which will put the whole environment back to normal.

Again if you use the Broker it makes very light work of this
Failover using the Broker     DGMGRL> failover to prod1dr;

Again reinstating the old primary is much easier too
reinstating the old primary using the Broker    

DGMGRL> reinstate database prod1;
Switching over to a Logical Standby :

Switching over to a logical standby is simpler because the database is already open for reading and writing, but there is a second set of steps that guarantee the safety of your data if a failure occurs after the switchover but before the the new logical standby can process transactions. As of Oracle 11g you no longer need to shutdown any database instances to perform the switchover, older versions of Oracle you need to shutdown all auxiliary instances.

Firstly check the state of the primary
Check primary database state     ## It should have a status of "to standby"

select switchover_status from v$database;

Unlike a physical standby which a exact copy of the primary, a logical standby could be different and once the roles are reversed the new logical standby needs to know what the new primary looks like so SQL Apply process can process the redo stream. So to prepare we run the following command on the primary
Prepare the primary standby     alter database prepare to switchover to logical standby;

## confirm that the prepare has started to happen, you should now see "preparing switchover"
select switchover_status from v$database;

Now go to the logical standby and tell it to send the preparation information to the primary in its redo stream
Prepare the logical standby     alter database prepare to switchover to primary;

## confirm that the prepare has started to happen, you should see "preparing dictionary"
select switchover_status from v$database;

## wait a while until the dictionary is built and sent and you should see "preparing switchover"
select switchover_status from v$database;

The logical will commence a dictionary build and put it into the redo stream of the logical standby, which will be sent to the primary. The reason for this step is that new logical standby knows how to apply the redo from the new primary the moment new primary transactions start to generate redo. If you skip this step you will be generating redo from business transactions that will be sent to your logical standby. The new dictionary would then be behind that redo, and if you had a failure of the new primary before the dictionary was sent to the new logical standby, a failover would result in data loss.

Now check the primary again and it should be ready to become the new logical standby, to confirm this use the following command
Check primary database state     ## you should now see its in the state of "to logical standby"

select switchover_status from v$database;

At this point you can cancel the whole switchover as you are not committed yet
cancel the switchover     ## On the primary
alter database prepare to switchover cancel;

## on the logical
alter database prepare to switchover cancel;

If you are happy to continue the switchover then on the primary lets tell it that its going to be a logical standby
switchover the primary to a logical standby     alter database commit to switchover to logical standby;

Your users will now have to wait until the switchover has completed, they may experience significant stalling. Once the switchover is completed and Data Guard enables the Guard on the primary to prevent more updates to the data, as this is now a logical standby database.

Now finish off the logical standby database
switchover the logical standby to a primary     ## check that its ready to become the primary, you should see "to primary"

select switchover_status from v$database

## Complete the switchover
alter database commit to standby to primary;

Start the apply process on the new logical standby
start the apply process     alter database start logical standby apply immediate;

That's it, you should now have a successful switchover, you can use my monitoring section to check everything is working correctly.

That seemed a lot of work above to switchover, if you have a broker configured then it just one command, buts its good to learn what goes on behind the scenes when you use the broker.
Switchover using the broker     DGMGRL> switchover to prod1lr

Don't forget that when you are learning to tail the alert and broker logs when your are playing around with switching over, you get a better understanding on what Oracle is doing.

So the finals checks you need to make before the switchover are

    Make sure that your configuration has been setup properly and has not been altered
    Meet all the Data Prerequisites
    Enable Flashback Database
    Verify that redo is being sent to the standbys and is being applied
    Ensure that the standby will not encounter problems during the switchover due to nologging DML on the primary if you have not enabled FORCE LOGGING.


Flashback and Data Guard :

You can enable flashback on the primary database, on one or more standby databases or on any combination of the two. You can use flashback in the following circumstances
On the primary database     to recover data in lieu of a delay on the apply processing.
On a physical standby database     to open a physical standby database in snapshot mode (read-write for test). Data Guard uses a guaranteed restore point (GRP) before opening the physical standby in read-write mode. The retention period is also not needed as the flashback logs will be maintained as long as necessary. Make sure that you size the flash area accordingly as this could stop the redo processing.
On the primary and all standby databases     If you want to flashback primary database, you must enable it on all standby databases as well. The retention period must be the same across all databases. If you perform a flashback recovery on the primary, you must stop the apply process on all standbys, when the open resetlogs has been executed, you must flashback each standby to a point in time prior to the primary. When the redo starts to be transmitted again the standby will recognize the change and recover the standby up to the point of the flashback and then start processing the new redo stream.
On the primary but after a failover     to be able to recover the database after a failover. Data Guard needs only a little bit of flashback log to move the failed primary back in time so that it can be converted to a standby database and resynchronized with the primary.

Physical Switchover

In this section we will perform a switchover, we will perform some checks before the switchover, then switchover. I will discuss the switchover using SQLPlus then how to do it using the Broker, learning the SQLPlus will give you a good understanding on how the whole processes works and what the broker does in the background.

To start with the check that you must do are the following

    Make sure that all of the necessary Data Guard parameters have been configured
    Make sure that the SRL files have been configured
    Make sure that you have a temporary data file defined
    Make sure that Flashback has been enabled (optional)

The reason for the checks is that if it all goes wrong it would easy be able to switchback to the primary.

First we verify that the standby has received all the redo
check redo has been received    

## check the syn status, it should say yes (run on the standby)
select db_unique_name, protection_mode, synchronization_status, synchronized from v$archive_dest_status;

## if it says NO then lets make further checks (run on the standby)
select client_process, process, sequence#, status from v$managed_standby;

## now check on the primary we should be one in front (run on the primary)
select thread#, sequence#, status from v$log;

Note: if using a RAC environment make sure you check each instance

Once you have determined that the redo stream is current, we need to check that the redo has been applied
check that redo has been applied (physical)    

## check that MRP (applying_log) matches the RFS process, if the MRP line is missing then you need to
## start the apply process, you also may see the status of wait_for_gap so wait until the gap have been
## resolved first

select client_process, process, sequence#, status from v$managed_standby;

check that redo has been applied (logical)     ## if you are using a logical standby then you need to check the following to confirm the redo has been
## applied

select applied_scn, latest_scn, mining_scn from v$logstdby_progress;

## if the mining scn is behind you may have a gap check this by using the following

select status from v$logstdby_process where type = 'READER';

Finally you must cancel any jobs and backups that are running, however there should be none as you will probably be performing the switchover during a quiet period
show any running jobs or backups    

select process, operation, r.status, mbytes_processed pct, s.status from v$rman_status r, v$session s where r.sid=s.sid;

Once the checks have been carried out you are ready to perform the switchover, you may want to tail the alert logs as it will give you an idea on what is going in the background and you can formularize yourself with the messages that are displayed, you can increase the level of messaging for diagnostic purposes
increase logging level     alter system set log_archive_trace=8129;

## to turn it off again
alter system set log_archive_trace=0;

One point to make is that if you are using flashback make sure that you drop the GRP restore point on all databases after the switchover is complete, otherwise you will be generating permanent flashback database logs forever.

If you are running a Oracle RAC then you need to bring the RAC down to a single instance, because this is a planned it may be worth using shutdown immediate and try not you use shutdown abort, as oracle will have to recover first. You can check the session by running the below command
check active sessions    
 select switchover_status from v$database;

check the switchover status    
 select switchover_status from v$database;

Now it it is time to switchover
switchover     ## on the primary

alter database commit to switchover to physical standby with session shutdown;

keep an eye on your alert logs, then check that first part of the switchover has completed
check the switchover status      
select switchover_status from v$database;

to finish off the switchover
complete the switchover    
alter database commit to switchover to primary with session shutdown;

open the new primary database
open the new primary    
alter database open;

finish off the old primary and start it up as a standby
finish off the old primary    
shutdown immediate;
startup mount;
alter database recover managed standby database using current logfile disconnect;

You can now startup auxiliary RAC instances on the primary and standby databases if you are using RAC.
Switchover and Failover :

This section is what Data Guard is really all about, its about a standby database taking over the production database, and how to revert back when problems have been fixed.

Role transition is divide into two types switchover and failover, they also might be called switchback, failback but they all mean the the same thing to transition the state of Data Guard from one state to another.

Switchover

Switchover is the act of change the standby database into the primary but in a controlled manor, the planned event means that it is safe from data loss because the primary database must complete all redo generation on the production data before allowing the switchover to commence. The switchback does not exists as it is a switchover but in the reserve order, which would restore the database back on its original server. This planned event normally happens during a quiet period, the reason for the switchover might be DR testing, patch, hardware changes, implementing RAC, etc.

Once the switchover is complete the redo from the new primary will send it to the remaining standby servers, including the old primary, if using either grid control or the broker this should be all automatically do for you, but if you are using SQLPlus you have to performance some manual work.

You always start the switchover on the primary database, the actual switchover command is below whether you are using Grid Control, Broker or SQLPlus.
start the switchover (primary)    

alter database commit to switchover to standby;

When the switchover command is executed the redo generation is stopped, all DML related cursors are invalidated and users are either prevented from executing transactions or terminated and he current redo log is archived for each tread. A special switchover marker called the EOR (end of redo) is then placed in the header of the next sequence for each thread, and the online redo files are archived a second time, sending the final sequences to the standby databases. At this point the physical standby database is closed and the final log switch is done without allowing the primary database to advance the sequence numbers for each thread.

After the EOR redo is sent to the standby databases, the original primary database is finalized as a standby and its control file backed up to the trace file and converted to the correct type of standby control file. In the case of a physical standby switchover the managed recovery process (MRP) is automatically started on the original primary to apply the final archive logs that contain the EOR so that all the redo ever generated is processed. The primary is then dismounted and must then be restarted as a standby database in at least the mount state.

The standby database must received this EOR redo otherwise the switchover cannot occur, once this redo has been received and applied to complete the switchover you run the following command, this will be automatic if you are using the Grid Control or the Broker
complete the switchover (new primary)   


alter database commit to switchover to primary;

The physical standby switchover will wait for the MRP process to exit after processing the EOR redo and then convert the standby control file into a normal production control file. The final thing to do is to open the database for general production use
complete the switchover (new primary)    


alter database open;

A logical standby also has to wait for the EOR redo from the primary to be applied and SQL apply to shut down before the switchover command can complete, once the EOR has been processed, the GUARD can be turned off and production processing can begin.

Failover



A failover is a unplanned event when something has happened to hardware, networking, etc. This is when you invoke you DR procedures (hopefully documented), and you will have full confidence in getting the new primary up and running as quickly as possible. Unlike the switchover which begins on the primary, no primary is involved which means you will not be able to get the redo from the primary. Depending on what protection mode you have chosen there may be data loss (less you have a Maximum Protection mode enabled), you start be telling Data Guard to apply the remaining redo that it can. Once the redo has been applied you run the same command that you do with a physical standby to switchover the standby to a primary.


complete the switchover (new primary)   

alter database commit to switchover to primary; 


Once difference is when the switchover has completed the protection mode will be maximum performance regardless what it was before, to get it back to your original protection mode you must get a standby database back up and running, then manually execute the steps to get it into the protection mode you want.
change the protection mode    

# Choose what level of protection you require

alter database set standby to maximize performance;
alter database set standby to maximize availability;
alter database set standby to maximize protection;


If you are using a protection mode that may result in data, the received archive redo logs are merged into a a single thread and the sequence is sorted on the dependant transaction, this merged thread is then applied to the standby database up until the last redo. This may take sometime if using a RAC environment as the redo data has to be transfers from each instance.

Since the redo heartbeat is sent every 6 seconds or so, the general rule is that you may lose 6 seconds of redo during a failover but this is a best guess. At failover the merging thread will look at the last log of the disconnected thread and use the last heartbeat in it to define the consistent point, throwing away all the redo that the surviving nodes had been sending all along.


Important collective commands used for monitoring and enhancing the performance of an Oracle database :


EXECUTE DBMS_STATS.GATHER_SCHEMA_STATS('SCHEMA_NAME',DBMS_STATS.AUTO_SAMPLE_SIZE);

EXEC DBMS_STATS.gather_dictionary_stats;

EXEC DBMS_STATS.gather_system_stats;

EXEC DBMS_STATS.gather_fixed_objects_stats;


EXEC DBMS_UTILITY.analyze_schema('SCHEMA_NAME','ESTIMATE', estimate_rows => 100);

EXEC DBMS_STATS.gather_database_stats(estimate_percent => 15);

EXEC DBMS_UTILITY.ANALYZE_SCHEMA('SCHEMA_NAME','COMPUTE');

EXEC DBMS_UTILITY.ANALYZE_SCHEMA('SCHEMA_NAME','ESTIMATE', estimate_rows => 1000);

EXEC DBMS_STATS.GATHER_TABLE_STATS('SCHEMA_NAME', 'TABLE_NAME',estimate_percent => dbms_stats.auto_sample_size);

 EXEC DBMS_DDL.alter_compile('PROCEDURE', 'SCHEMA_NAME', 'PROCEDURE_NAME');



How to check all invalid procedures, packages  in Oracle :



COLUMN object_name FORMAT A30
SELECT owner,
       object_type,
       object_name,
       status
FROM   dba_objects
WHERE  status = 'INVALID'
ORDER BY owner, object_type, object_name;
How to check tablespace name, size (alternate SQL) :



 set linesize 150
        column tablespace_name format a20 heading 'Tablespace'
     column sumb format 999,999,999
     column extents format 9999
     column bytes format 999,999,999,999
     column largest format 999,999,999,999
     column Tot_Size format 999,999 Heading 'Total| Size(Mb)'
     column Tot_Free format 999,999,999 heading 'Total Free(MB)'
     column Pct_Free format 999.99 heading '% Free'
     column Chunks_Free format 9999 heading 'No Of Ext.'
     column Max_Free format 999,999,999 heading 'Max Free(Kb)'
     set echo off
     PROMPT  FREE SPACE AVAILABLE IN TABLESPACES
     select a.tablespace_name,sum(a.tots/1048576) Tot_Size,
     sum(a.sumb/1048576) Tot_Free,
     sum(a.sumb)*100/sum(a.tots) Pct_Free,
     sum(a.largest/1024) Max_Free,sum(a.chunks) Chunks_Free
     from
     (
     select tablespace_name,0 tots,sum(bytes) sumb,
     max(bytes) largest,count(*) chunks
     from dba_free_space a
     group by tablespace_name
     union
     select tablespace_name,sum(bytes) tots,0,0,0 from
      dba_data_files
     group by tablespace_name) a
     group by a.tablespace_name
order by pct_free;


How to Check the tablespace name, size, percentage free?

SQL> select df.tablespace_name "Tablespace",
totalusedspace "Used MB",
(df.totalspace - tu.totalusedspace) "Free MB",
df.totalspace "Total MB",
round(100 * ( (df.totalspace - tu.totalusedspace)/ df.totalspace))
"Pct. Free"
from
(select tablespace_name,
round(sum(bytes) / 1048576) TotalSpace
from dba_data_files
group by tablespace_name) df,
(select round(sum(bytes)/(1024*1024)) totalusedspace, tablespace_name
from dba_segments
group by tablespace_name) tu
where df.tablespace_name = tu.tablespace_name ;

Tablespace                             Used MB    Free MB      Total MB     Pct. Free
------------------------------ ----------    ----------     ----------    ----------
SYSAUX                                879           935              1814             52
UNDOTBS1                           181           5107            5288            97
USERS                                   6086          4184           10270          41
SYSTEM                                758           1026            1784           58


Thursday, 25 June 2015

How to switch primary database into a standby database and a standby database into a primary database :

 - Switching the primary and standby databases:

- set oracle_sid=primarydb_name

- sqlplus / as sysdba

- alter database commit to switchover to PHYSICAL STANDBY WITH SESSION SHUTDOWN;

====================

- Connect to standby database 'standbydb_name' and run the following command :

- alter database commit to switchover to primary;

- select database_role from v$database;

- alter database open;







How to create a temporary tablespace in Oracle :


CREATE TEMPORARY TABLESPACE temp1 TEMPFILE 'D:\app\oracle\oradata\DATA\temp022.dbf' SIZE 1g REUSE AUTOEXTEND ON NEXT 400M MAXSIZE unlimited;
How to compile a procedure in Oracle :

EXEC DBMS_DDL.alter_compile('PROCEDURE', 'SCHEMA_NAME', 'PROCEDURE_NAME')
How To Enable & Configure Dataguard And Create One Standby Database with Switching? 

Follow the steps as they are and you will be able to configure and enable dataguard.

--------------------------

Primary Database Name : PRMDB

On primary database :

- sqlplus sys/password@prmdb as sysdba

- select name, log_mode,database_role,force_logging from v$database;
Archive log and force logging should be enabled on primary database.

- shut immediate

- set oracle_sid=prmdb

- sqlplus / as sysdba

- startup mount

- alter database archivelog;

- alter database open;

- alter database force logging;.

- select name, log_mode,database_role,force_logging from v$database;

- exit

- Now create a new folder on same machine in D:\ drive or wherever feasible for first standby database 'STLDB'.

"D:\Oracle\ORADATA\STLDB\CONTROLFILE"

"D:\Oracle\FRA\STLDB"

- Now open cmd and create pfile and controlfile;

- set oracle_sid=prmdb

- sqlplus / as sysdba

- create pfile='D:\oracle\PFILESTLDB.ora' from spfile;

- alter database create standby controlfile as 'D:\oracle\ORADATA\STLDB\CONTROLFILE\CONTROL01.CTL';

- exit

- Open pfile created in notepad and replace 'prmdb' with 'stldb'

- Change the control file path as 'D:\oracle\ORADATA\STLDB\CONTROLFILE\CONTROL01.CTL'

- Add following parameters:

*.db_name='PRMDB'
*.db_unique_name='STLDB'

- Change path for *.db_recovery_file_dest as 'D:\oracle\FRA'

- Now create oracle instance and password file :

- oradim -new -sid STLDB

- Copy the password file of PRMDB And paste as same location 'D:\app\Admin\product\11.2.0\dbhome_1\database\'. Rename the copied file as PWDSTLDB.ora

- Add the entry of STLDB in TNSNAMES.ora and listener.ora and restart the listener.

- Now startup the STLDB database in nomount mode from the created pfile.

- set oracle_sid=stldb

- sqlplus / as sysdba

- create spfile from pfile='D:\oracle\PFILESTLDB.ora';

- startup nomount

- show parameter control_f

- Open the database in mount mode

- alter database mount

- select name from v$datafile;

- Now copy all the oradata files of PRMDB from primary to standby(D:\oracle\ORADATA\STLDB\) database except controlfile.

- set oracle_sid=prmdb

- sqlplus / as sysdba

- shut immediate

- Now copy all the oradata files except controlfile.

- Now startup the PRMDB database.

- startup

- exit

- set oracle_sid=stldb

- sqlplus / as sysdba

- select name from v$datafile;

- select name from v$tempfile;

- select member from v$logfile;

- Now we will rename datafile, logfile and tempfile for standby database

- show parameter STAND

- alter system set standby_file_management='MANUAL';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\SYSAUX01.DBF' to 'D:\oracle\ORADATA\STLDB\SYSAUX01.DBF';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\SYSTEM01.DBF' to 'D:\oracle\ORADATA\STLDB\SYSTEM01.DBF';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\UNDOTBS01.DBF' to 'D:\oracle\ORADATA\STLDB\UNDOTBS01.DBF';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\USERS01.DBF' to 'D:\oracle\ORADATA\STLDB\USERS01.DBF';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\REDO01.LOG' to 'D:\oracle\ORADATA\STLDB\REDO01.LOG';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\REDO02.LOG' to 'D:\oracle\ORADATA\STLDB\REDO02.LOG';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\REDO03.LOG' to 'D:\oracle\ORADATA\STLDB\REDO03.LOG';

- alter database rename file 'D:\app\Admin\oradata\PRMDB\TEMP01.DBF' to 'D:\oracle\ORADATA\STLDB\TEMP01.DBF';

- select name from v$datafile;

- select name from v$tempfile;

- select member from v$logfile;

- exit

- Now we are creating a data guard configuration with dataguard command line interface.

- set oracle_sid=PRMDB

- DGMGRL /

- show configuration

- exit

- set oracle_sid=PRMDB

- sqlplus / as sysdba

- show parameter dg_

- alter system set dg_broker_start=TRUE scope=both;

- exit

- set oracle_sid=stldb

- sqlplus / as sysdba

- show parameter dg_

- alter system set dg_broker_start=TRUE scope=both;

- exit

- Now, add standby logs to primary and standby database.

- sqlplus sys/password@prmdb as sysdba

- alter database add standby logfile ('D:\app\Admin\oradata\PRMDB\SLOG01.LOG') size 500M;

- alter database add standby logfile ('D:\app\Admin\oradata\PRMDB\SLOG02.LOG') size 500M;

- alter database add standby logfile ('D:\app\Admin\oradata\PRMDB\SLOG03.LOG') size 500M;

- exit

- sqlplus sys/password@stldb as sysdba

- alter database add standby logfile ('D:\oracle\ORADATA\STLDB\SLOG01.LOG') size 500M;

- alter database add standby logfile ('D:\oracle\ORADATA\STLDB\SLOG02.LOG') size 500M;

- alter database add standby logfile ('D:\oracle\ORADATA\STLDB\SLOG03.LOG') size 500M;

- exit

-  CREATE CONFIGURATION DG AS
   PRIMARY DATABASE IS prmdb
   CONNECT IDENTIFIER IS prmdb;
  
- ADD DATABASE stldb
   AS CONNECT IDENTIFIER IS stldb
   MAINTAINED AS PHYSICAL;
  
- enable configuration;

- show configuration

- exit

- sqlplus sys/password@prmdb as sysdba

- show parameter log_arch

- Now check that the archive logs will be created in both databases on switching redo log files

- alter system switch logfile;

"D:\oracle\FRA\STLDB\ARCHIVELOG\2015_06_25"
"D:\app\Admin\flash_recovery_area\PRMDB\ARCHIVELOG\2015_06_25"

- Now we can check database roles

- select database_role from v$database;

- exit

- sqlplus sys/password@stldb as sysdba

- select database_role from v$database;

- exit

- Switching the primary and standby databases:

- set oracle_sid=prmdb

- sqlplus / as sysdba

- alter database commit to switchover to PHYSICAL STANDBY WITH SESSION SHUTDOWN;

====================

- Connect to standby database 'stldb' and run the following command :

- alter database commit to switchover to primary;

- select database_role from v$database;

- alter database open;

====================


Cheers!
























Tuesday, 16 June 2015

How to take a dump by excluding the grants in Oracle SQL Query :

expdp system/password@DB_NAME directory=data_pump_dir schemas=SCHEMA_NAME dumpfile=DUMPFILE_NAME.dmp logfile=LOGFILE_NAME.log exclude=grant
How to Update(Drop/Create) Sequences in Oracle:


select * from user_sequences where sequence_name like '%IP%';



drop sequence ORACLE_IPID_SEQ;


CREATE SEQUENCE ORACLE_IPID_SEQ
INCREMENT BY 1
START WITH 96800000
MAXVALUE 97000000
MINVALUE 96800000;


select ORACLE_IPID_SEQ from dual;


How to split and export multiple dumpfiles in Oracle SQL Query :


 expdp system/password@DB_NAME directory=data_pump_dir dumpfile=DUMP1_0%u.dmp ,DUMP2_1%u.dmp, DUMP3_2%u.dmp logfile=SPLITTED_DUMPFILES.log schemas=Schema_name FILESIZE=1024M

Note : You may decide the Filesize parameter of the dumpfile with reference to the size of the dump.


SQL Query to find all columns in a database :

select OWNER, TABLE_NAME, COLUMN_NAME from dba_tab_columns;