دیتابیس اوراکل

دیتابیس اوراکل
طبقه بندی موضوعی

۳ مطلب با کلمه‌ی کلیدی «Physical Standby» ثبت شده است

PDB Replication in Data Guard

برای کنترل کردن اینکه یک pdb در دیتابیس استندبای سینک شود یا نه، 2 روش وجود دارد:

1- استفاده از عبارت STANDBYS در دستور CREATE PLUGGABLE DATABASE که از ورژن 12.1.0.2 اضافه شده است.

CREATE PLUGGABLE DATABASE PDBTEST

ADMIN USER pdbadmin IDENTIFIED BY Password1

STANDBYS=NONE ;

 

مقادیری که میتوان برای STANDBYS ست کرد به صورت زیر است:

  • STANDBYS=NONE: این pdb با هیچ کدام از استندبای ها سینک نشود.
  • STANDBYS=ALL: این pdb با همه استندبای های سینک شود.
  • STANDBYS=ALL EXCEPT ('cdb1_stby_1','cdb1_stby_2'): این pdb با همه استندبای ها سینک شود بجز استندبای هایی که DB_UNIQUE_NAME آنها cdb1_stby_1 و cdb1_stby_2 است.
  • STANDBYS=('cdb1_stby_1'): این pdb فقط با استندبای cdb1_stby_1 سینک شود.

 

2- استفاده از پارامتر ENABLED_PDBS_ON_STANDBY که از ورژن 12.2 اضافه شده است.

اگر میخواهید یک pdb توسط استندبای سینک نشود، باید قبل از ایجاد pdb ، این پارامتر را به صورت زیر در دیتابیس اصلی یا استندبای ست کنید، ولی این را مد نظر داشته باشید که این پارامتر فقط توسط استندبای استفاده میشود:

ALTER SYSTEM SET enabled_pdbs_on_standby="*", "-PDBTEST";

 

مقادیری که میتوان به پارامتر enabled_pdbs_on_standby پاس داد به صورت زیر است:

  • "*": همه pdbها با استندبای سینک شوند.
  • ""PDB1", "PDB2: فقط PDB1 و PDB2 با استندبای سینک شوند.
  • ""PDB*: فقط pdbهایی که با کلمه "PDB" شروع میشوند با استندبای سینک شوند.
  • ""*", "-PDB*: همه pdbها بجز pdbهایی که با کلمه "PDB" شروع میشوند با استندبای سینک شوند.
  • ""*", "-PDB1: همه pdbها بجز PDB1 با استندبای سینک شوند.

 

بعد از ست کردن این پارامتر به صورت بالا، pdb زیر را ایجاد میکنیم:

CREATE PLUGGABLE DATABASE PDBTEST

ADMIN USER pdbadmin IDENTIFIED BY Password1;

 

در دیتابیس primary:

SQL> SELECT name, open_mode, recovery_status

FROM v$pdbs

WHERE name='PDBTEST';

 

NAME           OPEN_MODE   RECOVERY_STATUS

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

PDBTEST       READ WRITE   ENABLED

 

در دیتابیس standby:

SQL> SELECT name, open_mode, recovery_status

FROM v$pdbs

WHERE name='PDBTEST';

 

NAME           OPEN_MODE   RECOVERY_STATUS

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

PDBTEST       READ WRITE   DISABLED

 

 

Document:

https://oracle-base.com/articles/12c/multitenant-controlling-pdb-replication-in-data-guard-environments-12c

 

Data Guard Physical Standby Switchover using SQLPlus

  1. Verify Managed Recovery is running on the standby:

On Standby:

SQL> select process from v$managed_standby where process like 'MRP%';

PROCESS

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

MRP0

 

On Primary:

SQL> select recovery_mode from v$archive_dest_status where dest_id=2;

RECOVERY_MODE

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

MANAGED REAL TIME APPLY

 

  1. Verify there are no Gaps:

On Primary: 
select a.db_unique_name , a.dest_name ,a.archived_seq# ,  a.applied_seq#, a.gap_status 
  from v$archive_dest_status a
 where a.db_unique_name in ('stby_dbunique');

 

select thread#, max(sequence#) "Last Primary Seq Generated"
from gv$archived_log val, gv$database vdb
where val.resetlogs_change# = vdb.resetlogs_change#
group by thread# order by 1;

 

On Standby:
select thread#, max(sequence#) "Last Standby Seq Applied"
from gv$archived_log val, gv$database vdb
where val.resetlogs_change# = vdb.resetlogs_change#
and val.applied in ('YES')
group by thread# order by 1;

 

select thread#, low_sequence#, high_sequence# from v$archive_gap;

 

  1. Verify all datafiles are online On Target Standby:

SQL> select name from v$datafile where status='OFFLINE';

If there are any OFFLINE datafiles, and these are needed after switchover, bring them ONLINE:

SQL> alter database datafile '<DATAFILE_NAME>' online;

 

  1. Verify Primary and Standby tempfiles match:

select tmp.name filename, bytes, ts.name tablespace
  from v$tempfile tmp, v$tablespace ts
 where tmp.ts#=ts.ts#;

If the queries do not match, then you can correct the mismatch now or immediately after the open of the new primary database;

 

  1. Stop Jobs in Primary

SQL> select * from dba_jobs_running;

Depending on what the running job is, be ready to terminate the job if necessary.

 

Block further job submission by setting the job_queue_processes parameter to 0 so that there would be no jobs running during switchover.

SQL> show parameter job_queue_processes

SQL> alter system set job_queue_processes=0 scope=spfile;

 

  1. Create Guaranteed Restore Points

On Standby:

SQL> alter database recover managed standby database cancel;

SQL> create restore point SWITCHOVER_START_GRP guarantee flashback database;

SQL> alter database recover managed standby database using current logfile nodelay disconnect from session;

 

On Primary: 

SQL> create restore point SWITCHOVER_START_GRP guarantee flashback database;

 

  1. Verify that the primary database can be switched to the standby role.

SQL> select switchover_status from v$database;

SWITCHOVER_STATUS

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

SESSIONS ACTIVE

A value of TO STANDBY or SESSIONS ACTIVE (which requires the WITH SESSION SHUTDOWN clause on the switchover command) indicates that the primary database can be switched to the standby role.

 

Switchover always originates from Primary database. On the request of switchover sql statement "alter database commit to switchover to physical standby with session shutdown", Primary will generate special marker called EOR (end-of-redo) that is placed in the header of online redo log sequence. So this online redo log sequence will be archived locally and sent to all standby databases. Only upon receiving and applying EOR (end-of-redo), v$database.switchover_status will change from "not allowed" to "to primary" or "sessions active". At this stage Physical standby is ready to assume Primary database role.

  1. If The Primary is a RAC, then shutdown all secondary primary instances
  2. Switchover the Primary to a standby database

SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO STANDBY WITH SESSION SHUTDOWN;

 

  1. Verify that the standby database can be switched to the primary role.

SQL> select switchover_status from v$database;

SWITCHOVER_STATUS

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

TO PRIMARY

A value of TO PRIMARY or SESSIONS ACTIVE indicates that the standby database is ready to be switched to the primary role.

 

  1. Switchover the Standby to a primary

SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRIMARY WITH SESSION SHUTDOWN;

SQL> ALTER DATABASE OPEN;

 

  1. Restart the new standby

SQL> shutdown immediate;

SQL> startup mount;

SQL> alter database recover managed standby database using current logfile disconnect;

SQL> alter database open;

If the database is a RAC, then start all secondary instances on the new standby.

 

  1. Check Primary and New Standby:

SQL> select db_unique_name,total_gap,open_mode,database_role from v$database;

 

  1. Drop any Switchover Guaranteed Restore Points on all databases.

DGMGRL> drop restore point SWITCHOVER_START_GRP;

 

  1. Reset Jobs

Set the job queue processes to its original value on the new standby.

SQL> alter system set job_queue_processes=<value> scope=both sid='*';

SQL> show parameter job_queue_processes

 

Document:

Doc ID 1304939.1

 

خطای [ORA-600[kdsgrp1 موقع اجرای کوئری در دیتابیس استندبای

 

موقع اجرای یک کوئری مربوط به گزارش در دیتابیس استندبای با خطای زیر مواجه میشدیم:

ORA-00600: internal error code, arguments: [kdsgrp1], [], [], [], []

 

طبق داکیومنت Doc ID 1332252.1 ، این خطا به دلایل مختلفی ممکن است اتفاق بیفتد:

  1. Lost writes
  2. Parallel DML issues
  3. Index corruption
  4. Data block corruption
  5. Consistent read [CR] issues
  6. Buffer cache corruption

برای ما مورد 5 بود و با flush کردن Buffer Cache مشکل حل شد.

alter system flush buffer_cache;