Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

ORA-03113:fim de arquivo no canal de comunicação


ORA-03113 é um erro bastante comum. Vamos mergulhar fundo nisso

Problema ORA-03113:fim de arquivo no canal de comunicação

Causa: A conexão entre o processo Cliente e Servidor foi interrompida. Isso também pode acontecer se o agente externo extproc travar por algum motivo.

Ação: Ocorreu um erro de comunicação que requer investigação adicional. Primeiro, verifique se há problemas de rede e revise a configuração do SQL*Net. Além disso, procure por erros no arquivo alert.log. Finalmente, teste para ver se o processo do servidor está morto e se um arquivo de rastreamento foi gerado no momento da falha. Pode haver algumas chamadas de sistema na função .NET que podem encerrar o processo. Remova essas chamadas.

Um erro ORA-3113 “fim de arquivo no canal de comunicação” é um erro geral geralmente relatado por um processo cliente conectado a um banco de dados Oracle. O erro basicamente significa 'não consigo me comunicar com o processo de sombra do Oracle'. Por alguma razão, sua máquina cliente e o servidor de banco de dados pararam de se comunicar. Como é um erro tão geral, mais informações devem ser coletadas para ajudar a determinar o que aconteceu – esse erro por si só não indica a causa do problema.

Por exemplo, o ORA-3113 pode ser sinalizado para qualquer um dos seguintes cenários:
• Falha na máquina do servidor
• O processo do servidor foi interrompido no nível do SO
• Problemas de rede
•Erros internos do Oracle (ORA-600 / ORA-7445) / abortos no servidor
•Cliente manipulando incorretamente várias conexões
• etc.. etc.. etc. – muitas causas possíveis! !
É comum que este erro seja acompanhado por outros erros como:
• Erro interno ORA-01041. extensão hostdef não existe
•ORA-03114 não conectado ao ORACLE
• ORA-01012 não conectado

Esse erro às vezes é causado pelas coisas mais simples. Se, no entanto, for causado por um erro interno do Oracle, consulte seu log de alertas para obter mais informações.

Vamos pegar um cenário diferente onde ORA-03113

(1) ORA-3113 durante a inicialização do banco de dados Oracle

Pode ocorrer em todas as etapas de inicialização do banco de dados Oracle

(2) O cliente vê o ORA-3113 executando SQL/PLSQL

Se o erro ORA-3113 ocorrer APÓS você ter se conectado ao Oracle, é mais provável que o executável 'oracle' tenha terminado inesperadamente. O processo do servidor pode ter morrido por vários motivos.

(a) O Administrador do Sistema eliminou o processo deliberadamente matando o ID do processo, pois pode estar consumindo mais CPU e memória


(b) Isso pode acontecer por causa de algum bug, devemos procurar o arquivo de rastreamento para esta sessão no diretório de diagnósticos e verificar a solução no metalink


(c) Somente para UNIX: Se não houver arquivo de rastreamento, verifique se há um dump "núcleo" no CORE_DUMP_DEST. Verifique da seguinte forma:
cd $ORACLE_HOME/dbs # Or your CORE_DUMP_DEST
ls -l core*

Se houver um arquivo chamado 'core', verifique se seu horário corresponde ao horário do problema. Se houver diretórios chamados 'core_', verifique os arquivos principais em cada um deles. É  IMPORTANTE obter o arquivo principal correto. Agora obtenha um rastreamento de pilha deste arquivo 'núcleo'. Verifique cada uma das sequências abaixo para ver como fazer isso. Uma delas deve funcionar para sua plataforma.

Se você tiver dbx:
% script /tmp/core.stack
% dbx $ORACLE_HOME/bin/oracle core
(dbx) where
…
(dbx) quit
% exit

Se você tiver sdb:
% script /tmp/core.stack
% sdb $ORACLE_HOME/bin/oracle core
t
…
q
% exit

Se você tem xdb:
% script /tmp/core.s

(d) É possível que uma  instrução SQL específica ou um bloco PL/SQL esteja causando o erro. Em muitos casos, isso será listado no arquivo de rastreamento produzido sob o título "Instrução SQL atual" ou perto do meio do arquivo de rastreamento sob o cursor referido pela linha "NN do cursor atual".

Se o arquivo de rastreamento não mostrar a instrução com falha, SQL_TRACE poderá ser usado para ajudar a determinar isso, desde que o problema se reproduza. SQL_TRACE pode ser ativado na maioria das ferramentas do cliente

Devemos sempre consultar  a nota principal do Metalink em ORA-03113
Observação principal:solução de problemas ORA-03113 (Doc ID 1506805.1)

Também lê
ORA-01111
ORA-00900
ora-29283:operação de arquivo inválida