使用orachk工具检查数据库实例的时候,发现报告里面有类似下面这样一些错误(最近有给Oracle 10g应用补丁PSU 10.2.0.5.180717,不清楚是这个产生的还是其他原因导致),使用脚本检查,发现有很多INVALID对象(具体参考[转载]—Health Check Reports Problem: Dependency$ p_timestamp mismatch for VALID objects (文档 ID 781959.1)

[W] - P_OBJ#=37817 D_OBJ#=38416

[W] - P_OBJ#=38014 D_OBJ#=38605

[W] - P_OBJ#=38020 D_OBJ#=38611

[W] - P_OBJ#=38043 D_OBJ#=38634

[W] - P_OBJ#=38061 D_OBJ#=38652

[W] - P_OBJ#=38064 D_OBJ#=38655

[W] - P_OBJ#=38087 D_OBJ#=38678

[W] - P_OBJ#=38090 D_OBJ#=38681

select 

do.obj# d_obj,do.name d_name, do.type# d_type, 

po.obj# p_obj,po.name p_name, 

to_char(p_timestamp,'DD-MON-YYYY HH24:MI:SS') "P_Timestamp", 

to_char(po.stime ,'DD-MON-YYYY HH24:MI:SS') "STIME", 

decode(sign(po.stime-p_timestamp),0,'SAME','*DIFFER*') X 

from sys.obj$ do, sys.dependency$ d, sys.obj$ po 

where P_OBJ#=po.obj#(+) 

and D_OBJ#=do.obj# 

and do.status=1 /*dependent is valid*/ 

and po.status=1 /*parent is valid*/ 

and po.stime!=p_timestamp /*parent timestamp not match*/ 

order by 2,1;

然后在执行编译一些INVALID对象时遇到了下面错误ORA-04045,如下所示:

SQL> alter public synonym "SM$VERSION" compile;

alter public synonym "SM$VERSION" compile

*

ERROR at line 1:

ORA-00604: error occurred at recursive SQL level 1

ORA-04045: errors during recompilation/revalidation of LBACSYS.LBAC_EVENTS

ORA-04064: not executed, invalidated

ORA-04064: not executed, invalidated package body "LBACSYS.LBAC_EVENTS"

ORA-06508: PL/SQL: could not find program unit being called:

"LBACSYS.LBAC_EVENTS"

ORA-06512: at line 2

ORA-06508: PL/SQL: could not find program unit being called:

"LBACSYS.LBAC_EVENTS"

如下所示,LBACSYS下有很多INVALID对象,最奇怪的是,执行了上面脚本,会触发ORA-04045,似乎还会导致其他会话执行脚本时也触发这个错误:

 

SQL> col comp_name for a36;

SQL> col version for a30;

SQL> col version for a10;

col status for a8;

select comp_id, comp_name, version, status 

from dba_registry 

where comp_name='Oracle Label Security';

 

COMP_ID                        COMP_NAME                            VERSION    STATUS

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

OLS                            Oracle Label Security                10.2.0.5.0 VALID

 

SQL> 

 

SQL>  select * from v$option where parameter = 'Oracle Label Security';

 

PARAMETER                                                        VALUE

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

Oracle Label Security                                            FALSE

 

SQL> 

 

 

Tue Jun 25 20:15:01 HKT 2019

Errors in file /u01/app/oracle/admin/xxx/udump/xxx_ora_11203.trc:

ORA-00604: error occurred at recursive SQL level 1

ORA-04045: errors during recompilation/revalidation of LBACSYS.LBAC_EVENTS

ORA-04064: not executed, invalidated 

ORA-04064: not executed, invalidated package body "LBACSYS.LBAC_EVENTS"

ORA-06508: PL/SQL: could not find program unit being called: "LBACSYS.LBAC_EVENTS"

ORA-06512: at line 2

ORA-06508: PL/SQL: could not find program unit being called: "LBACSYS.LBAC_EVENTS"

ORA-06512: at line 2

 

 

 

[oracle@xxxxx bdump]$ more  /u01/app/oracle/admin/xxxx/udump/xxx_ora_11203.trc

/u01/app/oracle/admin/EPPS/udump/epps_ora_11203.trc

Oracle Database 10g Release 10.2.0.5.0 - 64bit Production

ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1

System name:    Linux

Node name:      xxxx

Release:        2.6.32-200.13.1.el5uek

Version:        #1 SMP Wed Jul 27 21:02:33 EDT 2011

Machine:        x86_64

Instance name: xxx

Redo thread mounted by this instance: 1

Oracle process number: 48

Unix process pid: 11203, image: oracle@xxxx (TNS V1-V3)

 

*** ACTION NAME:() 2019-06-25 20:15:01.745

*** MODULE NAME:(sqlplus@xxxx (TNS V1-V3)) 2019-06-25 20:15:01.745

*** SERVICE NAME:(SYS$USERS) 2019-06-25 20:15:01.745

*** SESSION ID:(113.2150) 2019-06-25 20:15:01.745

Error in executing triggers on connect internal

*** 2019-06-25 20:15:01.750

ksedmp: internal or fatal error

ORA-00604: error occurred at recursive SQL level 1

ORA-04045: errors during recompilation/revalidation of LBACSYS.LBAC_EVENTS

ORA-04064: not executed, invalidated 

ORA-04064: not executed, invalidated package body "LBACSYS.LBAC_EVENTS"

ORA-06508: PL/SQL: could not find program unit being called: "LBACSYS.LBAC_EVENTS"

ORA-06512: at line 2

ORA-06508: PL/SQL: could not find program unit being called: "LBACSYS.LBAC_EVENTS"

ORA-06512: at line 2

当时参考“ORA-04045: errors during recompilation/revalidation of LBACSYS.LBAC_EVENTS”这篇文章做了如下处理,告警日志里面不会出现ORA-04045错误了,但是如果我使用

上面的语句编译INVALID对象。就又会触发这个错误出现。似乎这种方法是指标不治本

shutdown immediate; 

 

startup migrate; 

 

alter view lbacsys.lbac$all_table_policies compile; 

 

alter package lbacsys.lbac_events compile body; 

 

shutdown immediate; 

 

startup;

最后参考官方文档“ORA-07445 [zllcini] or ORA-04045 in a Database with OLS Set to FALSE (文档 ID 233110.1)“给出解决方案:

ORA-4045 related to LBACSYS.LBAC_EVENTS

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

ORA-00604: error occurred at recursive SQL level 1

ORA-04045: errors during recompilation/revalidation of LBACSYS.LBAC_EVENTS

ORA-06508: PL/SQL: could not find program unit being called

ORA-06512: at line 2

ORA-06508: PL/SQL: could not find program unit being called

ORA-06512: at line 2

Solution Description

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

1. Install Oracle Label Security with the Oracle Universal Installer

2. Run $ORACLE_HOME/rdbms/admin/catnools.sql script to disable OLS

3. Optionally de-install 'The Label Security' software

Explanation

-----------

The Oracle Universal Installer may install OLS components in some cases:

patchset apply

解决方案:

 

1:卸载Oracle Label Security

@?/rdbms/admin/catnools.sql

2:运行/tmp/compiling.lst重编译失效对象

具体参考[转载]—Health Check Reports Problem: Dependency$ p_timestamp mismatch for VALID objects (文档 ID 781959.1)

3:运行@?/rdbms/admin/catols.sql脚本安装Oracle Label Security

第三步可以做也可以不做,是具体情况而定。

参考资料:

http://www.itpux.com/thread-568-1-1.html

ORA-07445 [zllcini] or ORA-04045 in a Database with OLS Set to FALSE (文档 ID 233110.1)

ORA-04045: errors during recompilation/revalidation of LBACSYS.LBAC_EVENTS的更多相关文章

  1. 误删除AUD$所在的表空间,无法切换用户

    问题故障:数据库Open,无法切换普通用户: ---递归SQL无法执行   SQL> conn hr/hr ERROR at line 1: ORA-00604: error occurred  ...

  2. Oracle10g使用$ORACLE_HOME/rdbms/admin/awrrpt.sql报错

    Enter value for report_name: Using the report name awrrpt_1_591_593.htmlselect output from table(dbm ...

  3. 记录一次Oracle导入数据库失败的解决办法,最终报错:UDI-04045、ORA-04045、ORA-01775

    费了很大的工夫,终于解决了.做个记录. ******************************************************************************** ...

  4. Oracle的静默安装 升级和卸载 参考规范

    Oracle的静默安装 升级和卸载 参考规范 20180912 V1 一.Oracle的安装 Oracle产品的三种安装方式分别为: 1.图形化(Java向导)安装引导 2.使用应答文件静默安装 3. ...

  5. Oracle数据库迁移--->从Windows到Linux

    I did a practice to migrate the oracle database from windows to linux operation system. The followin ...

  6. 【RMAN】RMAN跨版本恢复(下)--大版本异机恢复

    [RMAN]RMAN跨版本恢复(下)--大版本异机恢复 BLOG文档结构图 ORACLE_SID=ORA1024G 关于10g的跨小版本恢复参考:http://blog.chinaunix.net/u ...

  7. Oracle Study之--Oracle 单实例11.2.0.1.0升级到11.2.0.3.0

    Oracle Study之--Oracle 单实例11.2.0.1.0升级到11.2.0.3.0 系统环境: 操作系统:RedHat EL6(64位) Oracle:    Oracle 11gR2 ...

  8. 探索Oracle数据库升级6 11.2.0.4.3 Upgrade12c(12.1.0.1)

    探索Oracle数据库升级6 11.2.0.4.3 Upgrade12c(12.1.0.1) 一.前言:       Oracle 12c公布距今已经一年有余了,其最大亮点是一个能够插拔的数据库(PD ...

  9. oracle重新编译失效对像

    重新编译失效对像可执行utlrp.sql文件: SQL> @?/rdbms/admin/utlrp.sql TIMESTAMP --------------------------------- ...

随机推荐

  1. java基础|自定义java线程池

    线程池创建的参数 在创建线程的各种方式中我们有讲到过通过创建线程池来完成异步操作,但实际上jdk提供的Executors来创建线程池都还有些缺陷,线程池有以下几个参数: 代码节选自源码ThreadPo ...

  2. C# Task TaskFactory 异步线程/异步任务

    Task是.NetFramework3.0出现的,线程是基于线程池,然后提供了丰富的API TaskFactory  提供对创建和计划 Task 对象的支持 创建和启动异步任务 1.Task task ...

  3. Prometheus学习系列(九)之Prometheus 联盟、迁移

    前言 本文来自Prometheus官网手册 和 Prometheus简介 FEDERATION 允许Prometheus服务器从另一台Prometheus服务器抓取选定的时间序列. 一,用例 联盟有不 ...

  4. C# get folder's Md5 generated by file's and filename's md5. get dictionary md5

    C# get dictionary md5 static string GetDicMD5(string dirFullName) { logBuilder = new StringBuilder() ...

  5. .Net Core 项目发布到Linux - CentOS 7(一)

    由于项目的需求,需要发布到Linux服务器上,在这里记录一下我发布的过程. 安装Linux 安装liunx系统很简单,网上也有很多教程,我是直接使用阿里云的CentOS 7.7 64位 部署环境 Li ...

  6. Linux - CentOS 7 通过Yum源安装 Nginx

    添加源 sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.no ...

  7. DevExpress Applications<3>

    Project Template Project Template Information Template Name Template Description Controls and Compon ...

  8. CentOS 安装nginx服务

    安装nginx服务 sudo yum install nginx 启动nginx systemctl start nginx 加入启动项 systemctl enable nginx 测试nginx服 ...

  9. netty解决粘包半包问题

    前言:开发者用到TCP/IP交互时,偶尔会遇到粘包或者半包的数据,这种情况有时会对我们的程序造成严重的影响,netty框架为解决这种问题提供了若干框架 1. LineBasedFrameDecoder ...

  10. urllib模块使用笔记

    文中所有python代码均使用的是python2.7实现,与python3并不兼容. UrlLib模块 urllib模块是适用于一个简单的网络数据获取和处理(不能处理有关验证和cookie等功能),官 ...