Wednesday, June 15, 2011

New initialization parameters and Obsolete parameter in Oracle 11gR1


The best way to find new parameters is to create a database link between the two versions and run a set query using MINUS.Here are the new initialization parameter which was introduce in oracle 11gr1(11.1.0.6).

asm_preferred_read_failure_groups
client_result_cache_lag
client_result_cache_size
commit_logging
commit_wait
control_management_pack_access
db_lost_write_protect
db_securefile
db_ultra_safe
ddl_lock_timeout
diagnostic_dest
enable_ddl_logging
global_txn_processes
java_jit_enabled
ldap_directory_sysauth
memory_max_target
memory_target
optimizer_capture_sql_plan_baselines
optimizer_use_invisible_indexes
optimizer_use_pending_statistics
optimizer_use_sql_plan_baselines
parallel_io_cap_enabled
plscope_settings
redo_transport_user
resource_manager_cpu_allocation
result_cache_max_result
result_cache_max_size
result_cache_mode
result_cache_remote_expiration
sec_case_sensitive_logon
sec_max_failed_login_attempts
sec_protocol_error_further_action
sec_protocol_error_trace_action
sec_return_server_release_banner
xml_db_events

The list of obsolete parameter in oracle 11gr1(11.1.0.6) are :

_dlm_send_timeout
_fast_start_instance_recovery_target
_lm_rcv_buffer_size
_log_archive_buffer_size
ddl_wait_for_locks
logmnr_max_persistent_sessions
plsql_compiler_flags
remote_archive_enable


Enjoy    :-)


Tuesday, June 14, 2011

32-bit Oracle Database server is *not* certified on Windows x64

Once while Monitering alert logfile, i found that the below error is occuring at every 10 sec. The error is as : 
Tue Jun 07 16:19:43 2011
OER 7451 in Load Indicator : Error Code = OSD-04500: illegal option specified
O/S-Error: (OS 1) Incorrect function. !
OER 7451 in Load Indicator : Error Code = OSD-04500: illegal option specified
O/S-Error: (OS 1) Incorrect function. !
Tue Jun 07 16:19:53 2011
OER 7451 in Load Indicator : Error Code = OSD-04500: illegal option specified
O/S-Error: (OS 1) Incorrect function. !
OER 7451 in Load Indicator : Error Code = OSD-04500: illegal option specified
O/S-Error: (OS 1) Incorrect function. !
Tue Jun 07 16:20:03 2011

After googling, I find that Oracle Support states that “Running 32-bit applications on a 64-bit operating system is generally referred to as “Compatibility-Mode” by many AMD64/EM64T hardware vendors. Irrespective of this terminology, 32-bit Oracle Database server is *not* certified on Windows x64. For the 32-bit Oracle database client, check the certification matrix for more details.”

Actually the Oracle database software installs without an issue.  It is when I created the actual database that I encountered the same repeated errors in my alert.log after startup. On searching Meta-link points to Doc. ID 1060806.1 which states the cause and solution as below

Cause  :     Installed 32-bit Oracle database software on a 64-bit MS Windows OS which is not supported.

Note: For the Database software, you can ONLY install the x64 version on MS Windows (x64).  You can NOT install the 32-bit version Database software on MS Windows (x64).

Solution  :   Install 32-bit Oracle database software only on 32-bit MS Windows OS.


Enjoy    :-)


Handling Corrupt Datafile Blocks in RMAN Backup

We have two different kinds of block corruption:
Physical corruption (media corrupt) : Physical corruption can be caused by defected memory boards, controllers or broken sectors on a hard disk.
Logical corruption (soft corrupt) : Logical corrution can among other reasons be caused by an attempt to recover through a NOLOGGING action.

When RMAN encounters a corrupt datafile block during a backup, the behavior depends upon whether RMAN has encountered this corrupt block during a previous backup. If the block is already identified as corrupt, then it is included in the backup. If the block is not previously identified as corrupt, then RMAN's default behavior is to stop the backup. We can override this behavior using the SET MAXCORRUPT command with BACKUP in a RUN block. Setting MAXCORRUPT allows a specified number of previously  undetected block corruptions in datafiles during the execution of an RMAN BACKUP command. Here is the example of set maxcorrupt example.
Syntax  :  set maxcorrupt  for datafile <dataFileSpec>  TO  <integer>

Example :
i.) RMAN>run  {
                             set maxcorrupt for datafile 3,4,5,6  to 1 ; 
                              backup check logical database ; 
                           }
In the above example datafile 3,4,5,6 may not more than 1 corruption datafile block otherwise backup will fail.
ii.)RMAN> run {
                                set maxcorrupt for datafile 1 to 10;
                                backup database;
                                skip inaccessible;
                                skip readonly
                          }

If RMAN detects more than this number of new corrupt blocks while taking the backup, then the backup job aborts, and no backup is created. As RMAN finds corrupt blocks during the backup process, it writes the corrupt blocks to the backup with a special header indicating that the block has media corruption. If the backup completes without exceeding the specified MAXCORRUPT limit, then the database records the address of the corrupt blocks and the type of corruption found (logical or physical) in the control file. We can access these records through the V$DATABASE_BLOCK_CORRUPTION view.

Detecting Physical Block Corruption With RMAN BACKUP : RMAN checks only for physically corrupt blocks with every backup it takes and every image copy it makes. RMAN depends upon database server sessions to perform backups, and the database server can detect many types of physically corrupt blocks during the backup process. Each new corrupt block not previously encountered in a backup is recorded in the control file and in the alert.log. By default, error checking for physical corruption is enabled. At the end of a backup, RMAN stores the corruption information in the recovery catalog and control file.

How to detect block corruption ? 

1.)  DBVERIFY utility   :  DBVERIFY is an external command-line utility that performs a physical data structure integrity check. It can be used on offline or online databases, as well on backup files. we use DBVERIFY primarily when we need to ensure that a backup database (or datafile) is valid before it is restored
2.) Block checking parameters  : There are two initialization parameters for dealing with block corruption :                            
  • DB_BOCK_CHECKSUM (calculates a checksum for each block before it is written to disk, every time) causes 1-2% performance overhead .
  • DB_BLOCK_CHECKING (server process checks block for internal consistency after every DML) causes 1-10% performance overhead .
For more about db_block_checking parameter click here

3.) ANALYZE TABLE  :  ANALYZE TABLE tablename VALIDATE STRUCTURE CASCADE SQL  statement  Validate the structure of an index or index partition, table or table partition, index-organized table, cluster, or object reference (REF) . More about Analyze:Report Corruption click here

4.) RMAN BACKUP command with  VALIDATE option   :   We can use the VALIDATE option of the BACKUP command to verify that database files exist and are in the correct locations, and have no physical or logical corruptions that would prevent RMAN from creating backups of them. When performing a BACKUP... VALIDATE, RMAN reads the files to be backed up in their entirety, as it would during a real backup. It does not, however, actually produce any backup sets or image copies.

RMAN> RESTORE DATABASE VALIDATE;
RMAN> RESTORE ARCHIVELOG ALL VALIDATE;

To check for logical corruptions in addition to physical corruptions, run the following variation of the preceding command:
RMAN> BACKUP VALIDATE 
              CHECK LOGICAL  DATABASE 
              ARCHIVELOG ALL;

Detection of Logical Block Corruption :  Besides testing for media corruption, the database can also test data and index blocks for logical corruption, such as corruption of a row piece or index entry. If RMAN finds logical corruption, then it logs the block in the alert.log. If CHECK LOGICAL was used,the block is also logged in the server session trace file. By default, error checking for logical corruption is disabled.

1.) RMAN found any block corruption in database then following Data Dictionary view populated.
V$COPY_CORRUPTION
V$BACKUP_CORRUPTION
V$DATABASE_BLOCK_CORRUPTION

2.)  EXPORT/IMPORT command line utility
Full database EXPORT/IMPORT show=y is another method.
. about to export SCOTT's tables via Conventional Path ...
. . exporting table BONUS
EXP-00056: ORACLE error 1578 encountered
ORA-01578: ORACLE data block corrupted (file # 4, block # 43)
ORA-01110: data file 4: 'D:\app\Neerajs\oradata\orcl\USERS01.DBF'

3.) DBMS_REPAIR package
dbms_repair is a utility that can detect and repair block corruption within Oracle. It is provided by Oracle as part of the standard database installation.For detail about dbms_repair Package click here .


Enjoy     :-)