Ora 00600 код внутренней ошибки аргументы

Коротко описываются ошибки ORA-0600: их аргументы, последствия возникновения, версия в которой они могут возникать, источник (компонент Oracle), причины возникновения ошибок и что делать если ошибка возникла.

Ошибка ORA-0600 является внутренним кодом ошибки для программных исключений Oracle. Её возникновение указывает на то, что процесс столкнулся на низком уровне с неожиданным условием.

Ошибка ORA-0600 включает список аргументов в квадратных скобках:

ORA-00600 "internal error code, arguments: [%a], [%b], [%c], [%d], [%e]"

Первым аргументом является внутренний номер сообщения или символьная строка.  Этот аргумент и номер версии базы данных является первостепенным в идентификации первопричины и потенциального воздействия на базу данных. Остальные аргументы используются, что бы предоставить дополнительную информацию (например, значения внутренних переменных и т.д.).

В зависимости от вида первого аргумента, в Oracle имеются два типа ошибок ORA-0600:

  • первый аргумент является числом, которое отражает исходный компонент или слой, в котором происходит ошибка.
  • первый аргумент является мнемоникой, которая указывает на исходный модуль, где произошла ошибка. Этот  тип внутренней ошибки более предпочтителен в настоящее время.

Категории ошибок ORA-0600 ранжированные по номеру

В следующей таблице приведена информация относительно внутренних числовых кодов ошибок ORA-0600, используемых в Oracle.

Читать далее…

Категории ошибок ORA-0600 ранжированные по мнемонике

Следующая таблица детализирует возможные мнемоники ошибок ORA-0600.

Читать далее…

Справочник ошибок ORA-0600

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

Последствия:

Сбой процесса, возможный сбой экземпляра.

Версия:

от 6.0 до 9.2

Причины возникновения:

Попытка освободить state object, хотя он уже находиться в свободных списках. Нарушение целостности в памяти SGA или из-за bug в плохом управлении state objects.

Действия:

Проанализировать дамп PMON, установить заплатки на bug.

ORA-00600: internal error code, arguments: [4193], [a], [b]

Аргументы:

[a] – Номер изменения (SCN) записи в серменте отката (Undo), [b] SCN записи в журнале повторного выполнения (Redo)

Последствия:

Сбой процесса, возможное повреждение сегмента отката, невозможность продолжения наката журналов на STANDBY.

Версия:

от 6.0 до 10.1

Источник:

KERNEL TRANSACTION UNDO

Причины возникновения:

Было обнаружено несоответствие между журнальной записью и записью в сегменте отката.

Действия:

Перейти на новую версию Oracle (10.2.0.5, 11.2.0.1); Восстановить экземпляр из резервной копии.

ORA-00600: internal error code, arguments: [12333], [a], [b],[c],[d]

Последствия:

Отказ процесса. Физического искажения нет.

Версия:

от 6.0 до 9.2

Источник:

USER/ORACLE INTERFACE LAYER

Причины возникновения:

В результате сетевой ошибки получены плохие данные, приложение клиента послало неправильные данные, данные в сетевом буфере были записаны поверх, всевозможные bug (столбцы LONG).

Действия:

Проверить сетевое соединение и настройки NLS, заменить версию клиента Net на более новую.

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

Последствия:

Физического искажения нет.

Версия:

от 8.0 до 10.2

Причины возникновения:

Возникает при удалении строк из таблицы, в случаях когда запись уже удалена. Такое обычно происходит если в таблице есть внешний ключ на столбец в этой же таблице. По своей сути не является полноценной ошибкой.

Действия:

Переделать внешний ключ.

ORA-00600: internal error code, arguments: [15419], [a]

Последствия:

Отказ процесса. Физического искажения нет.

Версия:

от 7.0 до 10.1

Источник:

Kernel Kompilation pl/sql Compiler

Причины возникновения:

Всевозможные bug. Для большей информации смотреть дополнительные ошибки в trc файле. Bug: 2829071, 2588469, 2437995

Действия:

Установить заплатки на bug. Если не помогает, модифицируйте PL/SQL код.

ORA-00600: internal error code, arguments: [15735], [a], [b]

Аргумент:

[a] — значение parallel_execution_message_size в котором нуждается запрос, [b] — текущее значение parallel_execution_message_size

Последствия:

Ошибка с записью в trace файл. Физического искажения нет.

Версия:

от 10.1 до 10.2

Причины возникновения:

BUG:5462624.

Действия:

Открыть trc файл ошибки. Найти sql оператор. Для таблиц этого оператора выполнить запрос select table_name, degree from dba_tables where table_name = ». Выбрать таблицы у которых degree ‘1’. Выполнить для каждой таблицы команду alter table noparallel. В качестве второго способа можно порекомендовать увеличить значение параметра parallel_execution_message_size.

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

Последствия:

Сбой процесса, повреждения данных нет.

Версия:

от 8.0 до 10.1

Источник:

Kernel Generic Library cache Subordinate set/cache manager

Причины возникновения:

Была произведена попытка получить подчиненный элемент, но при поиске, куча памяти для данного элемента не была закреплена.

Действия:

Установить заплатки на bug.

ORA-00600: internal error code, arguments: [17090],[a], [b],[c],[d]

Последствия:

Отказ процесса. Физического искажения нет.

Версия:

от 7.0 до 8.1

Источник:

GENERIC CODE LAYER

Причины возникновения:

Всевозможные bug.

Действия:

Уничтожьте сеанс и связанный с ним процесс.

ORA-00600: internal error code, arguments: [17271], [instantiation space leak]

Последствия:

Сбой процесса.  Повреждения данных нет.

Версия:

до 10.2.0.5

Источник:

Kernel Generic Instantiation manager

Причины возникновения:

Исключение возникает при попытке Oracle деинстанцировать (уничтожить экземпляр) разделяемый объект (курсор) во время выхода из сеанса. В этот момент, Oracle проходит связанный список разделяемых объектов для деинстанцирования,  и находит, что объект был помечен как не разделяемый. Этого не должно быть,  поэтому возникает исключение. Может проявляться при работе с распределёнными базами данных.

Действия:

Игнорировать ошибку. Если ошибка повторяется, то идентифицировать курсор в trace файле и переделать, или поставить последний патч Oracle закрывающий баги.

ORA-00600: internal error code, arguments: [25012], [a], [b]

Аргумент:

[a] — номер табличного пространства, [b] — относительный номер файла БД

Последствия:

Возможно физическое искажение.

Версия:

от 8.0 до 10.1

Источник:

KERNEL FILE MANAGEMENT TABLESPACE COMPONENT

Причины возникновения:

Всевозможные bug ( 4305391, 3915343, 3900237, 3771508, 3751874, 3430832, 3258674, 3150268, 3070856, 2531519, 2526334, 2287815, 2214167, 2212389, 2189615, 2184731, 1968815, 1949273, 1872985).

Действия:

Установить заплатки на bug.

ORA-00600: internal error code, arguments:  [ktspgsb-1]

Последствия:

Повреждение данных.

Версия:

До 10.2.0.5

Причины возникновения:

Ошибка возникает если в объекте (таблице) присутствуют логически повреждённые блоки.  Выполнение команд (TRUNCATE, INSERT и т.д.) применительно к  объекту приводит к этой ошибке.

Действия:

Пересоздание объекта.

ORA-00600: internal error code, arguments: [pfri.c: pfri8: plio mismatch ]

Причины возникновения:

Несоответствие создания экземпляра PL/SQL объекта. Вероятнее всего возникает из-за инвалидации PL/SQL объекта  (bug 9691456, зафиксирован в 11.2.0.2). Проявлялась в триггере на версии 10.2.0.5.

Действия:

Приведение PL/SQL объекта в нормальный статус.

Fix ORA-00600 Internal Error Code

Oracle database is the most popular database among the database industry because of its accuracy and performance. It is a Relational database management system (RDBMS) and capable to store and manage lots of new entries in a sufficient manner and why so it is one of popular database.

The majority of getting errors related to Oracle database increases if you do not have enough knowledge of Oracle. Yes, it is a fact and due to having less knowledge of using Oracle database, users get different errors messages and one of them is the ora-00600 internal error code.

One more issue with this error is that it can normally generate along with arguments encloses in a square bracket, and here occurs the critical situation because the meaning of these enclosed arguments alters with the version of the database. It is very difficult for a database administrator to verify the reason for the database error. This error also gets more difficult when more than one ORA-00600 error occurs because due to this the generated trace files and log files become large in number.

If you are the one who got this error then do not worry, you have come to the right place. I am saying so because here you will get to know how to fix ora-00600 internal error code.

Why ORA-00600 Error Occurs?

There are several causes due to which ORA_00600 internal error code occurs. It is a generic internal error number to execute Oracle program. This error indicates that the process has some unexpected conditions. The first argument is internal message number and the other arguments are several names, character strings and numbers. However, the number may change the meaning of different Oracle versions. Here are some of the reasons of getting this error:

#1: File Corruption: When an Oracle supported file has been corrupted then you may get ora-00600 internal error code.

#2: Timeouts: While connecting with the database the timeout occurred or the query runs for a long time and timeout occurs then this internal error code takes place.

#3: Failed Data Checks In the Memory: Due to the failed data checks in the memory, ora-00600 internal error code occurs.

#4: Hardware/Memory/IO: When the hardware is incompatible or the memory is full in Oracle version and you still work on it may cause this error to take place.

#5: Incorrectly Restored Files: When the Oracle files are restored in an improper way then this error will occur.

There are several reasons for ORA-00600 error like compatibility issues to database block error. Sometimes, this kind of error remains unsolvable. However, it is quite difficult to find the root cause of this error.

Several reasons are there ways with the help of which you will be able to fix ora-00600 internal error code. Here, I have tried my best to let you know how to resolve ora-00600 internal error code. Here are some of the major solutions you should try:

Fix #1: Writes Error Message In Alert Log & Trace File

The very first option you can try to fix ora-00600 internal error code is to write error message and trace file in alert.log file. The Oracle engine will write the error in alert.log file. The trace file location will find in alert.log file.

Fix #2: Try Other Solutions Based On Error Code Examples

You may get several errors reported within the space of a few minutes that starts with the ORA-00600 error. Well, apart from fixing ora-00600 error, you can check trace files and alert logs. Another solution you can try is to find the source of the issue is important. Most of the time, you will not be able to find the source by checking the alert or trace the alert logs. Also, these errors will not give you clear information about what has happened with the server.

Here are some great examples that might help the Oracle developers or users and DBAs to restore this issue:

Example #1:

ORA-00600: internal error code, arguments: [kxtotolc_lobopt], [], [], [], [], [], [], [], [], [], [], []
00600. 00000 –  “internal error code, arguments: [%s], [%s], [%s], [%s], [%s], [%s], [%s], [%s]”

Cause of this error: This example is the generic internal error number for Oracle program exceptions. Also, this error indicates that a process has encountered an exceptional condition.

How To Fix This Issue

If you are updating or inserting the CLOB column value as null with the use of merge statement and the merge the statement table has trigger. The same null CLOB column value if you try to update or insert CLOB value in another table with the use of trigger then you will get ora-00600 internal error code. You will also notice that the session is closed automatically, you will also get this error in both Oracle 11g as well as 12c.

Below are the steps to fix this issue:

  • First of all, you have to create a table CLOB_ table(sno number, c_clob clob);
  • Next, you have to create table table test_Clob_table_stg as select * from test_Clob_table;
  • After this, you are required to create a trigger on Clob_table table and then you have to insert data in staging table test_Clob_table_stg using trigger:

CREATE OR REPLACE trigger test_Clob_table_trg AFTER INSERT ON Clob_table
FOR EACH ROW
DECLARE
BEGIN
INSERT INTO test_Clob_table_stg VALUES(:new.sno,:new.c_clob);
EXCEPTION
WHEN others THEN
NULL;
END;
/

  • You have to then run the below query.

MERGE INTO Clob_table a USING (
select 1 AS sno, null AS C_CLOB from dual) b
ON (a.sno = b.sno)
WHEN MATCHED THEN
UPDATE SET C_CLOB = b.C_CLOB
WHEN NOT MATCHED THEN
INSERT (a.sno,a.C_CLOB) VALUES (b.sno,b.C_CLOB);

Example #2:

Error Code:

ORA-00600: internal error code, arguments: [15851], [3], [3499], [2], [1], [], [], [], [], [], [], []
ORA-00600: internal error code, arguments: [15851], [3], [3499], [2], [1], [], [], [], [], [], [], []
ORA-06502: PL/SQL: numeric or value error: character string buffer too small
ORA-06512: at “SIEBEL_ODS.MS_CCM_UTILITIES”, line 2866
ORA-04088: error during execution of trigger ‘SIEBEL_ODS.MS_CCM_TI_INVESTIGATION’
00600. 00000 –  “internal error code, arguments: [%s], [%s], [%s], [%s], [%s], [%s], [%s], [%s]”

Cause of this example: This example is the generic internal error number for Oracle program exceptions. This error message indicates that a process has encountered an exceptional condition.

How To Fix This Issue:

The other function used in trigger has variable size issue because you got this error, this trigger has created on merge statement table that is sued in “_P” package. This error won’t track the error log tables until if you run all the statement outside of the package, you get error in si_application_error_log.

Example #3:

SQL Error: ORA-00600: internal error code, arguments: [13013], [5001], [158796], [30437895], [0], [30437895], [17], [], [], [], [], []

How To Fix This Issue:

You can create index on one table for improving the performance of query, on same table you are updating data in some stages.

This will work and improve the performance in local examples and customer testing examples, but users get ora-00600 internal error code in UAT after applying the patch, whenever users has done update statement stage flow. You will get the below update statement highlighted in trace file with the error message, it helped users to debug the issue and also you will get some more information in alert log for an internal error.

Query to trace file with error message:

UPDATE MS_ITC_AUDIT_V SET STATUS = ’38’, AUDIT_STATUS = ’38’ WHERE AUDIT_ID = :B1 AND INSTANCE_ID = (SELECT MAX(INSTANCE_ID) FROM MS_ITC_AUDIT_V WHERE AUDIT_ID = :B1 );

Ultimate Solution: Try Oracle File Repair Tool To Fix ORA-00600 Internal Error Code

Apart from all these solutions that are mentioned above, if you are unable to fix ora-00600 error then you can try Oracle File Repair Tool. This tool will allow you to fix this error and recover Oracle database easily. This tool has some great features that will let you know how to fix ora-00600 internal error code. I am sure that you will not get disappointed after trying this tool. All you have to do is to download and install this tool and follow the step by step instructions to fix and recover oracle database that shows ora-00600 internal error code.

Steps To Fix ORA-00600 Internal error Code

Step 1: Search the Initial screen of Stellar Phoenix Oracle Repair & Recovery with a pop-up window showing options to select or search corrupt Oracle databases on your computer.

1

Step 2: Click Scan File to initiate the scan process after selecting the oracle database. The recoverable database objects get listed in left-side pane.

2

Step 3: Click an object to see its preview.

3

Step 4: : Click Start Repair in the icon bar to start the repair process. A pop-up window is displayed which show the steps needed to perform further. Click next and continue.

4

Step 5: Give the user name, password and path of the blank database where you want to save the repaired database objects.

5

Step 6: Repairing and restoring various database objects after establishing a connection with blank oracle database.

6

Final Words

I hope after going through this blog and trying the ways to fix ora-00600 internal error code, you will be able to fix it and recover the Oracle database easily. I have tried my best to provide you the best solution I can. Hope these will not let you down in any manner. All the best to you.

Jacob Martin is a technology enthusiast having experience of more than 4 years with great interest in database administration. He is expertise in related subjects like SQL database, Access, Oracle & others. Jacob has Master of Science (M.S) degree from the University of Dallas. He loves to write and provide solutions to people on database repair. Apart from this, he also loves to visit different countries in free time.

Автор признателен руководителям и сотрудникам ЗАО «Нефтегазсистемы»,
начальникам и персоналу вычислительных центров региональных управлений ОАО «Транснефть»,
c чьей помощью был разработан и внедрен данный Oracle-проект.

Возможные ошибки и методы их устранения

            В
данном пункте приводится список ошибок с примерами сообщений на английском и
русском языке (через косую черту). Далее идет текст с указанием причины и
решения проблемы: сначала из фирменной документации, затем комментарий из
практики (чаще всего по решению проблемы, но иногда только по причине, если
решение проблемы ясно).

Ошибка ORA-00020

ORA-00020: maximum number of
processes (num) exceeded

         / превышено максимальное
количество процессов (ном)

По
документации:

Причина:
Операция потребовала ресурс,
оказавшийся недоступным. Максимальное количество процессов определяется
параметром инициализации
PROCESSES.
Когда этот максимум превышается, никакие запросы больше обрабатываться не
могут.

Действие:
Повторите операцию еще раз через
несколько минут. Если это сообщение выдается часто, закройте
ORACLE,
увеличьте параметр
PROCESSES в файле
параметров инициализации, и запустите
ORACLE вновь.

Из
практики:

Действие:
Требуется увеличить параметр PROCESSES в
файле
INIT<SID>.ORA, причем для деф-сайта этот параметр должен
быть больше, чем для дест-сайта. Для БД СИСТЕМЫ было рекомендовано
установить этот параметр в 300 для дест-сайта и 400 для деф-сайта.

Ошибка ORA-00060

ORA-00060: deadlock detected
while waiting for resource

         / во время ожидания ресурса
произошла взаимоблокировка

По
документации:

Причина: Активный сеанс и какой-то другой сеанс, оба ожидающие
один и тот же ресурс, заблокировали друг друга. Это состояние известно как
взаимоблокировка. Для того, чтобы выйти из взаимоблокировки, надо сделать откат
(восстановить предыдущее состояние) одной или нескольких команд, таким образом
другой сеанс сможет продолжить работу.

Действие: Либо:

·        
выдайте команду ROLLBACK и перезапустите все команды, входящие в последнюю транзакцию;

·        
подождите, пока блокировка не
закончится (возможно, через несколько минут), и перезапустите те команды, на
которых произошел откат. 

Из
практики:

Причина:
Ошибка может возникнуть при
перегенерации сайта на БД, куда был неудачно выполнен полный импорт БД другого
сайта (см. Часть 2, Глава 3: Перенос основной БД на сервер с другой ОС).

Действие: Попробуйте удалить мастер-группы вместе с объектами и
повторить генерацию сайта.

Ошибка ORA-00600

ORA-00600:
internal error code, arguments: [num],[?],[?],[?],[?],[?] ,[?],[?]

         / код внутренней ошибки,
аргументы: [ном],[?],[?],[?], [?],[?],[?],[?]

По
документации:

Причина:
Это общее внутреннее сообщение для
исключительных ситуаций программ
ORACLE. Оно указывает, что процесс столкнулся с неожиданным
событием нижнего уровня.
Причинами,
вызывающими это сообщение, могут быть: 

·        
истечение времени
ожидания; 

·        
поломка файла; 

·        
сбойные ситуации при проверке
данных в памяти; 

·        
сообщения ввода/вывода,
аппаратного обеспечения, памяти; 

·        
некорректно
восстановленные файлы.

Первый
аргумент — это номер внутреннего сообщения; другие аргументы — различные 
числа, имена и символьные строки. (Для получения более полной информации см. 
раздел «Обращение в службу поддержки пользователей
ORACLE«.)
Числа могут  меняться в зависимости от версии сервера
ORACLE.

Действие:
Отправьте описание этой ошибки в
службу поддержки пользователей
ORACLE, сопроводив его информацией о: 

·        
событиях, которые привели к
ошибке; 

·        
предпринятых вами действиях,
которые привели к ошибке; 

·        
состоянии операционной системы и ORACLE
на момент ошибки; 

·        
подробностях всех необычных
обстоятельств, предшествовавших получению сообщения
ORA-00600

·        
содержимом всех файлов трассировок,
созданных в результате ошибки; 

·        
относящихся к этому случаю
реакциях сигнального файла. 

Замечание:
необходимо знать предысторию ошибок,
произошедших в самое разное время до этой внутренней ошибки, поскольку именно
они и могут оказаться ее причиной.

Из
практики:

Действие:
Это одна из самых скверных ошибок.
При ее возникновении рекомендуется обратиться к группе технической поддержки
Oracle.
Но существует также еще одна рекомендация: настройте работу в
Oracle через
протокол
IPC.

Ошибка ORA-01400

ORA-01400: cannot
insert NULL into (PLIPEKN.EDITIONS.ID)

         / Пропущен первичный ключ
или обязательный

           (NOT NULL) столбец, или NULL во время операции INSERT

ORA-06512: at
«PLIPEKN.WORKS_LOG», line 16

ORA-04088: error
during execution of trigger ‘PLIPEKN.WORKS_LOG’

ORA-06512: at
«PLIPEKN.WORKS$RP», line 831

ORA-01085:
preceding errors in deferred rpc to «PLIPEKN.WORKS$RP. REP_UPDATE»

ORA-02063:
preceding 5 lines from PLI_NORD

По документации:

Причина: При вводе или редактировании записи Вы не задали
значение обязательного (
NOT
NULL
) столбца.

Действие: Задайте значение для каждого столбца NOT NULL или измените определение таблицы так, чтобы
разрешить  устанавливать пустые значения столбцов.

Из
практики:

Причина:
Возникает при попытке сделать изменение
в таблице при отключенном или отсутствующем триггере
EDITIONS_COR (который расчитывает и устанавливает системный
идентификатор записи
ID).

Действие:
Включите (поставьте Enabled с
помощью
Oracle Schema
Manager
) либо создайте
триггер EDITIONS_COR:

create or replace
trigger EDITIONS_COR

  before insert
or update on EDITIONS

  for each row

begin

  if INSERTING
then

    select
EDITIONS_SEQ.nextval into :new.ID from DUAL;

  end if;

 
:new.CORDATE:=SYSDATE;

 
:new.USERNAME:=USER;

end;

Ошибка ORA-01403

ORA-01403: data not found

         / данные не найдены

ORA-06512: на
«PLIPEKN.DRFEAT$RP», строки 321

ORA-01085: ошибка обработки в
задержанном
rpc в «PLIPEKN.DRFEAT$RP. REP_UPDATE«

По
документации:

Причина: В программе на базовом языке были выбраны все записи.
Код возврата от операции
FETCH равен +4. Это означает, что из запроса на были
извлечены все записи.

Действие: Прекратите обработку для данного оператора SELECT.

Из
практики:

Причина:
Ошибка ORA-01403 является большим сюрпризом. Она возникает в самом важном месте – при выполнении
удаленной транзакции, и, притом, из-за множества причин, большинство которых
Вам еще не известно. Эта трудно распознаваемая ошибка обязательно будет время
от времени у Вас возникать.

Действие:
Дело может быть в следующем: не
обновлено поле, по которому разрешаются конфликты
(отключен или отсутствует
триггер
ТАБЛИЦА_COR, который расчитывает и устанавливает поле CORDATE, по которому как раз и разрешаются конфликты методом Latest Timestamp — см. пример триггера _COR выше при описании ошибки ORA-01400). Эта ошибка не возникает, если транзакция по данной
записи идет одна, без встречной.

Ошибка ORA-01591

ORA-01591: lock held by
in-doubt distributed transaction 6.58.10015

         / блокировка, удерживаемая
распред. транзакцией 6.58.10015,

           находящейся в неопр. сост.

По
документации:

Причина:
Была попытка доступа к ресурсу,
заблокированному «повисшей» распределенной транзакцией, находящейся в
состоянии подготовки.

Действие:
Для того, чтобы определить связь баз
данных и состояние транзакции,  сравните номер транзакции в сообщении со
столбцом
GLOBAL_TRAN_ID таблицы DBA_2PC_PENDING.
Попытайтесь исправить сетевое соединение для координатора и узла точки
завершения транзакции, если это необходимо. Если исправление временно невозможно,
обратитесь к  администратору базы данных узла точки завершения транзакции (если
она известна), чтобы «протолкнуть» ожидающую какого-то действия
транзакцию.

Из
практики:

Причина:
Ошибка диагностирует возникновение
«смертельных объятий», зацикливании процессов друг на друге. Может возникнуть
при попытке удалить из мастер-группы дест-сайт, если одна из БД других
сайтов остановлена.

Действие:
Запустите БД всех сайтов и в
состоянии мастер-группы NORMAL повторите операцию.

Ошибка ORA-02049

ORA-02049: time-out:
distributed transaction waiting for lock

         / таймаут: распределенная
транзакция ждет блокировку

По
документации:

Причина:
Превышено время ожидания блокировки
распределенной транзакции. Это время задается в параметре инициализации
DISTRIBUTED_LOCK_TIMEOUT.

Действие:
Эта ситуация трактуется как
тупиковая, поэтому происходит откат вашей команды. Установите в параметре
инициализации
DISTRIBUTED_LOCK_TIMEOUT более длительный интервал времени ожидания; затем
закройте и перезапустите экземпляр СУБД.

Из
практики:

Причина:
Ошибка может порождаться при
возникновении «смертельных объятий», связанных с тем, что кончилось время
ожидания выполнения распределенной транзакции, заданное в конфигурационном
файле параметром
DISTRIBUTED_LOCK_TIMEOUT.

Действие:
Увеличьте значение указанного
параметра и перезагрузите БД.

ПРИМЕЧАНИЕ 1.

На момент внедрения этот параметр можно снизить до 60
(1 мин), чтобы долго не ожидать результатов выполнения небольших тестов по
проверке репликации. Во время же эксплуатации лучше увеличить этот параметр,
например, до 300 (5 мин).

ПРИМЕЧАНИЕ 2.

Такое сообщение может появиться при выполнении
административных запросов, причем не адекватным образом, например, при переводе
группы в
NORMAL, затем сразу в QUIESCED
(для проверки). Транзакций в этом случае быть не должно (кроме, возможно,
системных). Подождите немного и повторите попытку.

ПРИМЕЧАНИЕ 3.

Сообщение об этой ошибке однажды появилось при
одновременном добавлении сайта к двум мастер-группам (первой и последней),
причем таблицы обеих групп друг на друга не ссылались.

Ошибка ORA-02266

ORA-02266: unique/primary
keys in table referenced by enabled

           foreign keys

         / таблица имеет некие уникальные/первичные
ключи,

           на которые ссылаются внешние ключи

По
документации:

Причина: Была попытка уничтожить таблицу, хотя она имела еще
какие-то уникальные или первичные ключи, на которые имеются активные (
enabled) ссылки внешних ключей.

Действие:
Перед удалением таблицы отключите все
ссылки внешних ключей на уникальные или первичные ключи. Посмотреть имеющиеся
ссылки и их статус Вы можете с помощью следующего
SQL-запроса:

select
CONSTRAINT_NAME, TABLE_NAME, STATUS

from
USER_CONSTRAINTS

where
R_CONSTRAINT_NAME in (

 
select CONSTRAINT_NAME

  from
USER_CONSTRAINTS

  where
TABLE_NAME=’TABNAM’);

Из практики:

Причина:
Фирма Oracle
инструктирует, что эта ошибка возникает при попытке сделать
DROP или TRUNCATE на
таблицу со связями. Но при репликации эта ошибка может возникнуть в случае,
если на дест-сайте таблица имеет статус
Error.

Действие:
Для исправления ситуации требуется
приостановить мастер-группу (
Suspend),
удалить таблицу (
Remove) из
мастер-группы деф-сайта (не удаляя физически), дождаться удаления из дест-сайта,
затем опять ее добавить (
Add) и
активизировать мастер-группу (
Resume).

Ошибка ORA-02449

ORA-02449: unique/primary keys in table referenced by
foreign keys

         / уникальный/первичный
ключ в таблице,

           на которую
ссылаются по внешнему ключу

По документации:

Причина: Была попытка уничтожить таблицу, хотя она имела еще
какие-то уникальные или первичные ключи, на которые ссылаются внешние ключи.

Действие:
Перед удалением таблицы удалите все
ссылки внешних ключей на уникальные или первичные ключи. Посмотреть имеющиеся
ссылки Вы можете с помощью следующего
SQL-запроса:

select * from
USER_CONSTRAINTS where table_name = «TABNAM»;

Из практики:

Причина:
Возникает при попытке удалить таблицу
с первичным или уникальным ключем, если на нее ссылается другая таблица (см.
выше:
ORA-02266).

Ошибка ORA-03113

ORA-03113:
end-of-file on communication channel

         / конец файла по
коммуникационному каналу

По документации:

Причина:       По коммуникационному каналу передан сигнал
конца файла, который не был обработан соответствующим образом программным
обеспечением
SQL*Net (двухзадачным программным обеспечением). Это
сообщение может быть выдано, если теневой двухзадачный процесс, связанный с
SQL*Net, завершился ненормально, или же на устройстве связи
между процессами  произошел физический сбой (сеть или сервер отключились от
коммуникации).

Действие:      Если это сообщение было выдано при попытке
осуществить связь, проверьте установочные файлы для соответствующего драйвера
SQL*Net и убедитесь, что программное обеспечение SQL*Net на сервере установлено правильно. Если сообщение было
выдано после того, как связь правильно установилась, и ошибка не связана с
физическим сбоем, проверьте файл трассировки, если таковой был создан на
сервере в момент сбоя. Существование файла трассировки может указать вам на то,
что эта ошибка — внутренняя ошибка
ORACLE, требующая вмешательства
службы поддержки пользователей
ORACLE.

Из практики:

При
возникновении этой ошибки рекомендуется посмотреть трассировочные файлы (обычно
находятся в каталоге
RDBMS80TRACE). Как
правило, это связано с потерей связи или неисправностью на сервере, возникших
во время выполнения процесса в
Oracle.

Эта
ошибка часто возникает при прохождении на сервер большого пакета транзакций или
подтверждений от них (см. Часть 2, Глава 3: Если пропала связь с сервером),
но может возникнуть и во время выполнения административных запросов (например,
одновременный запуск добавления достаточно больших таблиц в несколько
мастер-групп).

Конкретно
эта ошибка может возникнуть при попытке создания на удаленном сервере большой
таблицы (команда
create table TAB as select * from USER.TAB@DBLINK или
аналогичный процесс в Мультимастере). В этом случае рекомендуется
послать администратору удаленного сервера дамп для импорта больших файлов
(можно целой группы или всей БД), а затем лишь сгенерить репликационную
поддержку для этих таблиц.

Ошибка ORA-04030

ORA-04030: out of
process memory when trying to allocate 524316 bytes

           (pga heap, KSFQ Buffers)

         / выход за пределы
памяти процесса при попытке выделить

           524316 байт (стр)

По
документации:

Причина:
Собственная память системного
процесса исчерпана.

Действие:
Попросите администратора базы данных
или администратора операционной системы увеличить квоту памяти процессу. В
приложении может быть ошибка, которая и приводит к чрезмерному потреблению
памяти процесса.

Из
практики:

Выделяемая
под процессы память на сервере исчерпалась. Причины могут быть разные. На
Netware-сервере
это обычно происходит при фрагментации кэш-памяти и помогает только
перезагрузка сервера.

Ошибка ORA-04052

ORA-04052: error
occurred when looking up remote object

          
REPADMIN
.SYS @ULAN.WORLD

         / ошибка возникла
во время поиска удаленного объекта

           REPADMIN.SYS
@ULAN.WORLD

ORA-00604: error
occurred at recursive SQL level 2

ORA-12154:
TNS:could not resolve service name

ORA-06512: at
«SYS.DBMS_REPCAT_MAS», line 674

ORA-06512: at
«SYS.DBMS_REPCAT», line 516

ORA-06512: at line 2

По
документации:

Причина:
Ошибка возникла во время поиска
удаленного объекта.

Действие:
Исправьте ошибку. Убедитесь, что на
удаленной базе данных были запущены все необходимые командные файлы создания
представлений данных, используемых для запроса/поиска объектов базы данных. См.
книгу Сервер
ORACLE7. Руководство администратора.

Из практики:

Причина: Ошибка может возникнуть при ручном «толкании»
административных запросов (
Apply all admin requests now).

Действие: Посмотрите, не «уронили» ли Вы при этом сервер. Если
да – перезапустите его.

Ошибка ORA-06502

ORA-06502: PL/SQL:
numeric or value error

         / PL/SQL: ошибка в числе или в
значении

По документации:

Причина: Произошла ошибка арифметическая, числовая, строковая,
преобразования или правила целостности. Например, такая ошибка  может произойти
при попытке присвоить значение
NULL
переменной, описанной как
NOT NULL, или при
попытке присвоить целое, больше переменной, описанной как
NUMBER(2).

Действие: Измените данные, которыми вы манипулируете, или  их
описание таким образом, чтобы они не противоречили друг другу.

Из практики:

Причина:
Ошибка может возникнуть при
перегенерации сайта на БД, куда уже был выполнен полный импорт БД другого сайта
(см. Часть 2, Глава 3: Перенос основной БД на сервер с другой ОС).

Действие: Необходимо удалить мастер-группы вместе с объектами и
повторить генерацию сайта (на самом деле так просто отделаться от этой ошибки
не всегда удается).

Ошибка ORA-12011

ORA-12011: execution of 1
jobs failed

         / сбой при выполнении 1
задания

ORA-06512: at «SYS.DBMS_IJOB», line 255

ORA-06512: at «SYS.DBMS_JOB»,
line 218

ORA-06512: at line 2

По
документации:

Причина:
DBMS_IJOB.RUN обнаружил ошибку. Запуск одного или нескольких
заданий привел к ошибке, которую не удалось обработать.

Действие:
Посмотрите в журнале предупреждений,
какое задание не смогло запуститься и почему.

Из
практики:

Причина:
Ошибка возникает при попытке
запустить задачу
PUSH, которая до этого
находилась в состоянии
BROKEN, причем, предварительный перевод ее в состояние NORMAL не помогает –
задача или сама через некоторое время устанавливается в
BROKEN, или это происходит после попытки ее запустить. Это может произойти по
причине выполненного ранее  выполнилось автоматически при установке в это
состояние пакета транзакций).

Ошибка ORA-23308

ORA-23308: object
PLIPEKN.COUNTRY$RU does not exist or is invalid

         / объект PLIPEKN.COUNTRY$RU
либо неправильный,

           либо не
существует

По
документации:

Причина:
Указанное имя введено неправильно или
пусто, заданный тип неправилен, объект не является правильным объектом базы данных
или не существует как тиражируемый объект с соответствующим состоянием.

Действие:
Проверьте, что объект существует,
доступен пользователю и, если требуется, является правильным объектом в списке
ALL_REPOBJECT.

Из
практики:

Причина:
Ошибка возникает при несоответствии
структуры таблицы одного сайта с другим (например, при перегенерации
репликационной поддержки).

Действие:
Тщательно сверьте структуру указанной
таблицы на деф-сайте и дест-сайте. Возможно, на деф-сайте
была изменена ее структура, типы полей или ограничения вне DDL-механизма ORM.

ВНИМАНИЕ
!

Эта ошибка может создать заколдованный круг: при ее удалении на дест-сайте вне
DDL-механизма ORM остаются неудаленными
$RP и $RR модули и операции Remove
затем
Add для этой таблицы на деф-сайте вызывает ошибку.
Удаление вышеназванных модулей тоже не помогает. Не помогает также
соответствующая операция
alter
table
для этой таблицы в БД дест-сайта
(вне ORM). При попытке удаления этой таблицы из мастер-группы деф-сайта
(с тем, чтобы это удаление распространилось на дест-сайт) также
возникает ошибочный административный запрос, поскольку из мастер-группы дест-сайта
в этом случае нельзя удалить таблицу с несоответствующей структурой.

Рекомендуется следующее: сделайте соответствующую
операцию
alter
table
для этой таблицы в БД дест-сайта
через механизм ORM. Если при этом также возникнет ошибка можно поступить
иначе: удалите таблицу из БД дест-сайта с помощью SQL*Plus
(отключив предварительно ограничения) и создайте заново (можно пустую). Затем
можно попытаться удалить эту таблицу из мастер-группы деф-сайта,
подождать окончания административного запроса на обоих сайтах и вновь добавив
таблицу в мастер-группу. Если и это не поможет, то пересоздайте всю
мастер-группу путем удаления и последующего подключения к ней этого сайта с
отключенной опцией
Use
existing object
.

Ошибка ORA-23309

ORA-23309: object
PLIPEKN.COUNTRY of type TABLE exists

         / объект PLIPEKN.COUNTRY типа
TABLE существует

По документации:

Причина:       Объект уже существует в том же пространстве имен,
возможно с другим типом или формой.

Действие:      Удалите объект или повторите запрос со значением
TRUE логического параметра RETRY или USE_EXISTING_OBJECT.

Из
практики:

Причина:
Ошибка может возникнуть после
добавления на мастер-группу деф-сайта нового дест-сайта, если на дест-сайте
уже есть такая таблица, но ее структура другая. Ошибка возникает независимо от
того, была ли включена или отключена опция
Use existing object при создании мастер-группы и включении в нее таблиц
на дест-сайте.

Действие:
Удалите эту таблицу в БД дест-сайта
и повторите добавление этого сайта на мастер-группу дест-сайта.

Ошибка ORA-23312

ORA-23312: not
the masterdef according to …

         / не masterdef согласно …

По документации:

Причина: Имя схемы пусто или неправильно введено,
запрашиваемая заданная база данных не является оригиналом, или один из
оригиналов не считает вызываемую базу данных оригиналом.

Действие:
Если заданное имя схемы и оригинала
правильны, соединитесь с оригиналом и повторите запрос, или переместите
masterdef, использовав RELOCATE_masterdef.

Из
практики:

Причина:
Ошибка может возникнуть при
перегенерации репликационной поддержки для сайта, где объекты имеют статус
Error (см. Часть 2, Глава 3: Работа с административными запросами, Решение
проблем при создании мастер-групп
).

Действие: Удалите всю группу с объектами с этого сайта (или
только
Error-объекты) и перегенерите репликацию.

Ошибка ORA-23313

ORA-23313: object
group PLIPEKN7 is not mastered at PLI_BONN.WORLD

         / схема PLIPEKN7 не явл.главной для PLI_BONN.WORLD

По документации:

Причина:
Имя схемы пусто или неправильно
введено, запрашиваемая база данных не является оригиналом или запрашиваемая
база данных не считает заданную базу данных оригиналом.

Действие:
Если заданное имя схемы правильно,
соединитесь с текущим оригиналом и повторите запрос, установите запрашиваемую
базу данных оригиналом с помощью
ADD_MASTER_DATABASE или используйте SWITCH_SNAPSHOT_MASTER, если запрашиваемая база данных является узлом копии.

Из практики:

Причина:
Ошибка возникает, если мастер-БД с
мастер-группы деф-сайта уже удалена.

Ошибка ORA-23374

ORA-23374: object
group PLIPEKN0 already exists

         / мастергруппа PLIPEKN0 уже существует

ORA-06512: at
«SYS.DBMS_SYS_ERROR», line 86

ORA-06512: at
«SYS.DBMS_REPCAT_MAS», line 1598

ORA-06512: at
«SYS.DBMS_REPCAT», line 113

ORA-06512: at line 2

По документации:

Причина: Данная мастер-БД уже реплицирована данной
мастер-группой.

Действие: Выберите другую мастер-группу или мастер-БД.

Из практики:

Причина:
Ошибка возникает при попытке
«прицепить» дест-сайт к мастер-группе деф-сайта, если на этом дест-сайте
такая мастер-группа уже существует. Эта ситуация возникает, если сайт пытаются
пересоздать (см. Часть 2, Глава 3: Пересоздание дест-сайта), для чего
сначала его «отрывают» от мастер-группы деф-сайта, а потом (переведя ее
в состояние
QUIESCED) пытаются опять присоединить.

Действие: Удалите в режиме NORMAL мастер-группу с дест-сайта
со всеми ее объектами, т.е. отметьте опцию
Drop all objects in the group (на предупреждение, что объекты группы сохранятся на
других сайтах – нажмите
OK). Затем повторите присоединение (Properties… => Destinations => Add… => Asysnc, Use
existing objects
, Copy row
data
).

SQL-команды по анализу и управлению репликацией

Нижеприведенные команды SQL и PL/SQL окажутся для администратора Oracle
полезными и часто необходимыми для.
анализа и управления распределенными транзакциями. Полный синтаксис
использования
DBMS-процедур и структура представлений Словаря данных
приводятся в Приложении 3  и Приложении 4, соответственно.

Анализ объектов в мастер-группе

·        
Поиск мастер-группы для таблицы
(например, BRANCH):

select GNAME from
ALL_REPOBJECT

where
ONAME=’BRANCH’ and TYPE=’TABLE’;

·        
Кол-во записей по всем таблицам
мастер-группы
(пример для PLIPEKN0). Используйте скрипт RowCntMg.sql (предварительно исправив в нем название нужной
мастер-группы или аналогичные скрипты для каждой мастер-группы:
RwCntMg0.sql, …, RwCntMg7.sql), который формирует скрипт Temp.sql и запускает его
(создан по прототипу известного скрипта
TabCount.sql автора Peter Koletzke):

Листинг скрипта
на подсчет записей всех таблиц БД

set echo off

set feed off

set term off

set head off

set pages 10000

col L newline

————————————————————

spool temp.sql

————————————————————

prompt set head off

prompt set feed off

prompt set term on

prompt set recsep off

—prompt set echo off

prompt variable iC number;;

prompt execute :iC:=0;;

prompt begin

select

  ‘select :iC + count(*) into :iC’,’from
‘||T.TABLE_NAME||’;’ L

from

  ALL_REPOBJECT R, USER_TABLES T

where

  R.GNAME=’PLIPEKN0′ and R.TYPE=’TABLE’ and

  R.ONAME = T.TABLE_NAME

/

prompt end;;

prompt /

prompt select :iC from DUAL;;

—prompt set feed on

spool off

————————————————————

set term on

set pages 0

————————————————————

@temp

————————————————————

set pages 23

set feed on

set head on

Сформированный и
запускаемый далее скрипт
Temp.sql имеет следующий вид:

set
head off

set
feed off

set
term on

set
recsep off

variable
iC number;

execute
:iC:=0;

begin

 
select :iC + count(*) into :iC from BRANCH;

 
select :iC + count(*) into :iC from CONOPF;

.

.

.

select
:iC + count(*) into :iC from TYPEM;

select
:iC + count(*) into :iC from TYPEOBJECT;

end;

/

select
:iC from DUAL;

/

·        
Кол-во модулей по всем
мастер-группам
(если объекты – только
таблицы, то равно учетверенному кол-ву таблиц –
Package и Package Body по
модулям
$RP и $RR):

select count(*) from
ALL_REPGENERATED order by ONAME, TYPE;

·        
Кол-во модулей по каждой
мастер-группе
(очень полезный запрос):

select GNAME,
count(*) from ALL_REPOBJECT

where
TYPE=’TABLE’

group by GNAME

order by GNAME;

·        
Объекты, нуждающиеся в перегенерации
репликационной поддержки
:

select ONAME from
ALL_REPOBJECT

where
(GENERATION_STATUS <> ‘GENERATED’) and TYPE=’TABLE’;

·        
Error-объекты на сайте (обязателен к применению):

select GNAME,
ONAME from ALL_REPOBJECT

where
STATUS=’ERROR’ and TYPE=’TABLE’ order by GNAME;

·        
Кол-во Error-объектов по мастер-группам:

select GNAME,
count(*) from ALL_REPOBJECT

where
STATUS=’ERROR’ and TYPE=’TABLE’

group by GNAME

order by GNAME;

·        
Кол-во изменений по мастер-группам
за период времени
(для определения
наиболее активных мастер-групп):

select R.GNAME,
count(A.ID) CNT

from
ALL_REPOBJECT R, EDITIONS A

where

  R.TYPE=’TABLE’
and R.ONAME=A.TABNAME and

 
trunc(A.CORDATE)=trunc(SYSDATE-1)

group by R.GNAME

order by
count(A.ID);

Результат выполнения запроса (пример):

GNAME                                CNT

——————————
———

PLIPEKN6                              
4

PLIPEKN0                              
6

PLIPEKN4                             
35

PLIPEKN5                             
93

PLIPEKN3          
                  143

Анализ административных запросов

·        
Ошибочные административные
запросы по таблицам
(некоторые
ошибки, в частности,
endoffile, могут
не войти):

select

 
ID, to_char(TIMESTAMP,’DD.MM.YYYY HH24:MI:SS’) TIME,

 
substr(MASTER,1,15) MR, substr(GNAME,1,8) GR,

 
substr(ONAME,1,12) OB, substr(MESSAGE,1,40)

from

 
USER_REPCATLOG

where

 
STATUS=’ERROR’ and TYPE=’TABLE’;

·        
Административные запросы по
мастер-группе
(PLIPEKNn):

select

 
ID, to_char(TIMESTAMP,’DD.MM.YYYY HH24:MI:SS’) TIME,

 
substr(MASTER,1,15) MAST, substr(ONAME,1,12) OB,

 
STATUS, REQUEST, ERRNUM

from

 
USER_REPCATLOG

where

 
GNAME=’PLIPEKN0′

order
by ID;

·        
Административные запросы по
мастер-сайту первой очереди
(для
выявления блокирующих административных запросов):

select

 
ID, to_char(TIMESTAMP,’DD.MM.YYYY HH24:MI:SS’) TIME,

 
substr(MASTER,1,15) M, substr(GNAME,1,12) G,

 
substr(ONAME,1,12) O, STATUS, REQUEST, ERRNUM

from

 
USER_REPCATLOG

where

 
ROWNUM < 10;

·        
Кол-во адм-запросов по всему
мастер-сайту
(для общего контроля
выполнения):

   select count(*) from
USER_REPCATLOG;

·        
Кол-во административных
запросов по каждой мастер-группе
(для
общего контроля выполнения):

select  
substr(GNAME,1,12) GR, count(*) REQ_NUM

from    
USER_REPCATLOG

group
by GNAME

order
by GNAME;

·        
Кол-во каждого вида и статуса
административных запросов по каждой мастер-группе
(для детального контроля выполнения):

select

 
substr(GNAME,1,12) GR, REQUEST, STATUS, count(*) REQ_NUM

from

 
USER_REPCATLOG

group
by

 
GNAME, REQUEST, STATUS

order
by

 
GNAME, REQUEST, STATUS

;

Анализ транзакций

·        
Кол-во всех транзакций:

select count(*) from
DEFTRAN;

·        
Кол-во транзакций для каждого
сайта
:

select
substr(DBLINK,1,20), count(*) CNT from DEFTRANDEST

group by DBLINK
order by DBLINK;

·        
Кол-во транзакций для каждого
сайта по дням формирования
:

select

 
substr(DD.DBLINK,1,20) DL,

 
trunc(D.START_TIME) ST,

  count(DD.DEFERRED_TRAN_ID) CT

from

  DEFTRANDEST DD,
DEFTRAN D

where

  DD.DEFERRED_TRAN_ID=D.DEFERRED_TRAN_ID

group by

 
substr(DD.DBLINK,1,20), trunc(D.START_TIME)

order by

  DL, ST

;

Результат выполнения запроса (пример):

DL                  
ST               CT

———————
——— ———

PLI_ANTA.WORLD      
29-FEB-00       939

PLI_ANTA.WORLD      
01-MAR-00      6160

PLI_ANTA.WORLD      
02-MAR-00      7546

PLI_ANTA.WORLD      
03-MAR-00       245

PLI_ANTA.WORLD      
25-FEB-00      1580

PLI_ANTA.WORLD      
26-FEB-00       570

PLI_ANTA.WORLD      
27-FEB-00       165

PLI_ANTA.WORLD      
28-FEB-00      8753

PLI_ANTA.WORLD      
29-FEB-00      7491

PLI_ANTA.WORLD      
01-MAR-00      6160

PLI_ANTA.WORLD      
02-MAR-00      7546

PLI_ANTA.WORLD      
03-MAR-00       245

12
rows selected.

·        
Удаление транзакций. Для удаления одной транзакции (например, с
идентификатором 6.19.11941) используется следующее
DBMS-предложение (значение NULL параметра DESTINATION указывает
о применении команды ко всем мастер-сайтам):

begin

 
DBMS_DEFER_SYS.DELETE_TRAN(

   
deferred_tran_id => ‘6.19.11941’,

   
destination

=>
NULL);

end;

/

Для удаления всех транзакций используется пустое
значение
параметра
DEFERRED_TRAN_ID:

begin

 
DBMS_DEFER_SYS.DELETE_TRAN(

   
deferred_tran_id => »,

   
destination => NULL);

end;

/

·        
Перезапуск транзакций: данная функция отсутствует, но можно использовать
запуск соответствующей задачи, т.е. процесс
PUSH для нужного дест-сайта,
например:

DBMS_JOB.RUN(job
=> 204);

·        
Кол-во ошибочных транзакций:

select count(*)
from DEFERROR;

·        
Удаление всех ошибочных
транзакций
. Для удаления ошибочной
транзакции (например, с идентификатором 8.55.21) используется
нижеприведенная
DBMS-процедура (значение NULL параметра
DESTINATION указывает
о применении команды ко всем мастер-сайтам). Если значение параметра
DEFERRED_TRAN_ID не
указано (=>’’), то удаляются все ошибочные транзакции
(см. RemErr.sql):

begin

 
DBMS_DEFER_SYS.DELETE_ERROR(

   
deferred_tran_id => ‘8.55.21’,

   
destination => NULL);

end;

/

·        
Перезапуск ошибочных транзакций. Для перезапуска ошибочной транзакции (например, с
идентификатором 8.55.21) используется нижеприведенная
DBMS-процедура (параметр DESTINATION не
должен иметь значение
NULL, а
указывать на требуемый мастер-сайт). Если значение параметра
DEFERRED_TRAN_ID не
указано (=>’’), то перезапускаются все ошибочные транзакции
:

begin

 
DBMS_DEFER_SYS.EXECUTE_ERROR(

   
deferred_tran_id => ‘8.55.21’,

   
destination => ‘PLI_ANTA’);

end;

/

Анализ журнала правок БД (EDITIONS)

            В БД
рекомендуется создать и использовать специальную таблицу (например,
EDITIONS), куда триггерами ТАБЛИЦА_LOG заносятся все изменения по таблицам
Вашей системы (находящимся только в БД
Oracle). Анализ
этой таблицы полезен для сверки с выполненными и выполняемыми транзакциями.
Ниже приведен ряд полезных запросов (находятся в файле
ShwAllEd.sql):

— Сводка по таблицам и датам последних правок

select TABNAME, count(TABNAME)
C, max(CORDATE) D

  from EDITIONS

  /*where CORDATE>SYSDATE-5*/

  group by TABNAME

  order by TABNAME;

— Сводка по видам правок за диапазон дат

select ACTION, count(ACTION)
C

  from EDITIONS

  where trunc(CORDATE)
between trunc(SYSDATE)-2 and trunc(SYSDATE)

  group by ACTION

  order by ACTION;

Пример
результата данного запроса (
ACTION=1,2,3 – добавление,
изменение, удаление):

ACTION            C

——— ———

        1       431

        2       247

        3        44

— where to_char(CORDATE,’dd.mm.yy’)=to_char(SYSDATE-1,
‘dd.mm.yy’)

select TABNAME, count(TABNAME)
C

  from EDITIONS

  where trunc(CORDATE)=trunc(SYSDATE-1)

  and ACTION=1

  group by TABNAME

  order by TABNAME;

— Сводка по таблицам, которые правились за
предыдущие дни

select TABNAME, count(TABNAME)
C

  from EDITIONS

  where trunc(CORDATE)>trunc(SYSDATE-2)

  group by TABNAME

  order by TABNAME;

— Все изменения (добавления) за день (для сверки с
репликацией)

select TABNAME,TABKEY,ACTION,to_char(CORDATE,’dd.mm.yy
hh:mi:ss’) DL

  from EDITIONS

  where to_char(CORDATE,’dd.mm.yy’)=to_char(SYSDATE-1,’dd.mm.yyyy’)

—   and ACTION=1

  order by CORDATE;

— Общее кол-во изменений за день

select count(*) CNT

  from EDITIONS

  where to_char(CORDATE,’dd.mm.yyyy’)=to_char(SYSDATE,’dd.mm.yyyy’)

  and ACTION=1;

— Выборка добавленных в таблицу записей за 1 день

select T.ID, T.NAME, A.CORDATE

  from PIPECROSS T, EDITIONS
A

  where trunc(T.CORDATE)=trunc(SYSDATE-1)

  and T.ID=A.TABKEY and A.TABNAME=’PIPECROSS’
and A.ACTION=1

  and trunc(A.CORDATE)=trunc(SYSDATE-1)

  order by A.CORDATE;

Необходимые конфигурационные параметры для репликаци

В этом пункте перечислены параметры конфигурационного
файла
INIT<SID>.ORA, являющиеся важными для работы приложений. Эти
параметры должны иметь следующие значения.

·        
DISTRIBUTED_LOCK_TIMEOUT       =  300;

·        
DISTRIBUTED_TRANSACTIONS       
    =  5
(для
репликации Мультимастер увеличить до 12-20);

·        
GLOBAL_NAMES                        = TRUE;

·        
JOB_QUEUE_INTERVAL             =   10;

·        
JOB_QUEUE_PROCESSES                 =   4 (для репликации Мультимастер
увеличить до 10 — 12, т.е., примерно, удвоенное кол-во мастер-сайтов);

·        
OPEN_LINKS                      =   10;

·        
PARALLEL_MAX_SERVERS            =   10;

·        
PARALLEL_MIN_SERVERS            =    2;

·        
REPLICATION_DEPENDENCY_TRACKING =
TRUE
;

·        
SHARED_POOL_SIZE – не менее 18000000, но не
более 40% ОЗУ сервера (если кроме
Oracle на сервере не выполняются другие процессы), а если на сервере уже
установлены другие экземпляры
Oracle (например, другая система или учебная БД), то сумма этих параметров не
должна превышать 40% ОЗУ;

·        
DML_LOCKне менее 300;

·        
PROCESSES                      = 200 (при использовании репликации Мультимастер
увеличить: 300 на
destination-сайте, 400 на definition-сайте).

In my previous article i have explained about the most common error ORA-12154.In This article i will try to explain another most common error which has been searched approximately 50000 times in a month by oracle developers. While working with a database and performing different scenarios of database every developer or dba might have faced error called as ORA-00600: internal error code.While working with databases i have frequently faced ORA-00600: internal error code and struggled to solve and debug this issue.I would like to share my experience working and debugging with this error.

“ORA-600 error has been searched on google approximately 50 k times per month”

ORA-00600: internal error code

The generic error code will be displayed as :

ORA-00600: internal error code, arguments: [%s], [%s],[%s], [%s], [%s] 

where %s stands for string.

Why ORA-00600 error will come?

There are multiple reasons for which this error will occur.Actually ORA-00600 is generic internal error number for oracle program exceptions.This actually indicates that the process has unexpected conditions.The first argument is internal message number and other arguments are various numbers,names and character strings.The numbers may change meanings of different oracle versions.There should be multiple reasons of this error.I will mention few of them:

Reason 1 :

Timeouts 

While connecting with the database the timeout occurred or the query is running for long time and timeout occurred then this error will come.

Reason 2:

File Corruption 

When any oracle supported file has been corrupted then this error will come.

Reason 3:

Hardware/Memory/IO

When the memory is full or hardware is not compatible with oracle version then this error will come.

Reason 4:

Failed Data checks in the memory 

Because of failed data checks in the memory this error will occur.

Reason 5:

Incorrectly restored files.

If the oracle internal files restored not properly then this error will come.

There should be lot of reasons for ORA-00600 like compatibility problem to data block error.Most of the times these kind of errors remains unresolved.We can not be able to find the root cause of this issue.We need to call oracle support to resolve this issue in 60-70 percent of times.

NO TIME TO READ CLICK HERE TO GET THIS ARTICLE

Resolution of Error :

There is no specific reason for which ” ORA-00600: internal error code “error will come.For these kind of internal errors following activities is done by oracle engine :

1.Writes Error message in Alert Log :

The oracle engine will write the error in alert.log file.

2.Trace file :

Write detailed message in trace file.The trace file location will find in alert.log file.

3.Often you will see multiple errors reported within the space of a few minutes, typically starting with an ORA-600. It is usually, but not always, the case that the first is the significant error and the others are side effects.

If you are facing these kind of error first step is to check trace files and alert logs.There is no way to resolve these kind of issues so we need to do trial and error to resolve this issue.Finding the source of the problem is important. Sometimes you won’t be finding the source by checking the alert or trace logs. And neither these errors give you clear information about what exactly has happened with your server.

Following are some examples where i have faced this error and resolved.These examples might help developers and DBAs to resolve this issue.

Example 1 :

Error Code :

ORA-00600: internal error code, arguments: [15851], [3], [3499], [2], [1], [], [], [], [], [], [], []
ORA-00600: internal error code, arguments: [15851], [3], [3499], [2], [1], [], [], [], [], [], [], []
ORA-06502: PL/SQL: numeric or value error: character string buffer too small
ORA-06512: at “SIEBEL_ODS.MS_CCM_UTILITIES”, line 2866
ORA-04088: error during execution of trigger ‘SIEBEL_ODS.MS_CCM_TI_INVESTIGATION’
00600. 00000 –  “internal error code, arguments: [%s], [%s], [%s], [%s], [%s], [%s], [%s], [%s]”
*Cause:    This is the generic internal error number for Oracle program
exceptions.            This indicates that a process has encountered an
exceptional condition.
*Action:   Report as a bug – the first argument is the internal error number

Resolution :

one of the function used in trigger has variable size issue due to this we got above error,
this trigger created on merge statement table used in “_P” package. This error we will not track in any of the error log tables until if you run each and every statement outside of the package, we got socket error in si_application_error_log.

Example 2 :

ORA-00600: internal error code, arguments: [kxtotolc_lobopt], [], [], [], [], [], [], [], [], [], [], []
00600. 00000 –  “internal error code, arguments: [%s], [%s], [%s], [%s], [%s], [%s], [%s], [%s]”
*Cause:    This is the generic internal error number for Oracle program
exceptions.             This indicates that a process has encountered an
exceptional condition.
*Action:   Report as a bug – the first argument is the internal error number

Resolution :
If we are inserting/updating CLOB column value as null using merge statement, and merge statement table has trigger,same null CLOB column value if we try to insert/update CLOB value in another table using trigger then we will get the above error,also session is automatically closed, we got this error in both Oracle 11g and 12c.

Steps :

1) create table Clob_table(sno number, c_clob clob);

2) create table test_Clob_table_stg as select * from test_Clob_table;

3) Create a trigger on Clob_table table and insert data in staging table test_Clob_table_stg using trriger

CREATE OR REPLACE trigger test_Clob_table_trg AFTER INSERT ON Clob_table
FOR EACH ROW
DECLARE
BEGIN
INSERT INTO test_Clob_table_stg VALUES(:new.sno,:new.c_clob);
EXCEPTION
WHEN others THEN
NULL;
END;
/
4) Run the below query.
MERGE INTO Clob_table a USING (
select 1 AS sno, null AS C_CLOB from dual) b
ON (a.sno = b.sno)
WHEN MATCHED THEN
UPDATE SET C_CLOB = b.C_CLOB
WHEN NOT MATCHED THEN
INSERT (a.sno,a.C_CLOB) VALUES (b.sno,b.C_CLOB);

Example 3 :

SQL Error: ORA-00600: internal error code, arguments: [13013], [5001], [158796], [30437895], [0], [30437895], [17], [], [], [], [], []

Resolution :

We have created index on one table to improve performance of query, on same table we are updating data in some stages.
It worked fine and improved performance  in local instances and customer testing instance, but we got above error in UAT after applying patch, whenever they has done update statement stage flow. After 3 days of debugging ,we suspect some data blocks are corrupted in UAT due that we got the error and then we dropped the newly index and check the flow, it worked fine. We got the below update statement highlighted in trace file with error message, it helped us to debug the issue and also we will get some more information in alert log for any internal error.

Query for the same :

UPDATE MS_ITC_AUDIT_V SET STATUS = ’38’, AUDIT_STATUS = ’38’ WHERE AUDIT_ID = :B1 AND INSTANCE_ID = (SELECT MAX(INSTANCE_ID) FROM MS_ITC_AUDIT_V WHERE AUDIT_ID = :B1 );

These are some examples of the ORA-00600: internal error code.Hope you like this article.If you like this article dont forget to share it with everyone.

Понравилась статья? Поделить с друзьями:

Читайте также:

  • Oracle error 12899
  • Ora 00600 internal error code arguments ошибка
  • Ora 12571 ошибка
  • Oracle error 12537
  • Oracle error 1017

  • 0 0 голоса
    Рейтинг статьи
    Подписаться
    Уведомить о
    guest

    0 комментариев
    Старые
    Новые Популярные
    Межтекстовые Отзывы
    Посмотреть все комментарии