关于oracle invalid components问题的解决(28天)
时间:2022-05-04
本文章向大家介绍关于oracle invalid components问题的解决(28天),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
升级生产的DB,有一些预检查条件,这些需要提前修复,以便在升级的时候不会成为影响进度的绊脚石。
生产中的components有一些显示是invalid状态,从dba_registry中可以查到。
select comp_id,comp_name,status,version from dba_Registry;
还有一些显示是loading.
COMP_ID COMP_NAME VERSION STATUS
------------------------------ -------------------- ------------------------------ -----------
CATALOG Oracle Database Cata 10.2.0.1.0 VALID
log Views
CATPROC Oracle Database Pack 10.2.0.1.0 VALID
ages and Types
JAVAVM JServer JAVA Virtual LOADING
Machine
让我百思不得其解。
如果显示是Loading,很可能是安装JVM的时候失败。我上次的日志如下。安装没有成功。
PL/SQL procedure successfully completed.
SQL>
SQL>
SQL> -- Prevent the script. from continuing in the case where create java system
SQL> -- detects existing java classes or there is any other kind of error.
SQL> whenever sqlerror exit;
SQL>
SQL> -- Load all the Java classes
SQL> begin if initjvmaux.startstep('CREATE_JAVA_SYSTEM') then
2 initjvmaux.rollbacksetup;
3 commit;
4 initjvmaux.rollbackset;
5 initjvmaux.exec('create or replace java system');
6 commit;
7 initjvmaux.rollbackcleanup;
8 initjvmaux.endstep;
9 end if; end;
10 /
create or replace java system
begin if initjvmaux.startstep('CREATE_JAVA_SYSTEM') then
*
ERROR at line 1:
ORA-01653: unable to extend table SYS.IDL_UB1$ by 1024 in tablespace SYSTEM
ORA-06512: at "SYS.INITJVMAUX", line 23
ORA-06512: at line 5
SQL> col comp_name format a20
SQL> /
COMP_ID COMP_NAME VERSION STATUS
------------------------------ -------------------- ------------------------------ -----------
CATALOG Oracle Database Cata 10.2.0.1.0 VALID
log Views
CATPROC Oracle Database Pack 10.2.0.1.0 VALID
ages and Types
JAVAVM JServer JAVA Virtual LOADING
Machine
生产环境中有的组件显示是invalid,有的组件显示是loading.
对于这种情况,联系之前的系统迁移,原因是之前系统在Unix下,迁移到linux的时候,先用传输表空间(sys下的Objects就没有导出),在迁移后就留下了隐患。尽管之后又用goldengate来做同步,但是那部分objects还是没法同步导致的。
现在来修复一下这个问题,对于invalid,loaded,loading的修复如下:
SQL> select count(*),owner,status from all_objects where object_Type like 'JAVA%' group by owner,status;
COUNT(*) OWNER STATUS
---------- ------------------------------ -------
11999 SYS VALID
--这个数据明显和预计的差别很大。
需要卸载重新安装。
步骤如下:
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> spool full_rmjvm.log
SQL> set echo on
SQL> startup mount
ORACLE instance started.
Total System Global Area 369098752 bytes
Fixed Size 1219448 bytes
Variable Size 83887240 bytes
Database Buffers 276824064 bytes
Redo Buffers 7168000 bytes
Database mounted.
SQL> alter system set "_system_trig_enabled"=false scope=memory;
System altered.
SQL> alter system enable restricted session;
System altered.
SQL> alter database open;
Database altered.
run below scripts:
@?/rdbms/admin/catnoexf.sql --如果跑错,可以忽略。
@?/rdbms/admin/catnojav.sql --和java packages有关
@?/xdk/admin/rmxml.sql ---和xdk,xml component
@?/javavm/install/rmjvm.sql
and truncate $java$jvm$status;
SQL> select *from obj$ where obj#=0 and type#=0;
no rows selected
SQL> delete from obj$ where obj#=0 and type#=0;
0 rows deleted.
SQL> commit;
Commit complete.
SQL> select comp_id,comp_name,status,version from dba_registry;
COMP_ID COMP_NAME STATUS VERSION
------------------------------ -------------------------------------------------- ----------- ------------------------------
CATALOG Oracle Database Catalog Views VALID 10.2.0.1.0
CATPROC Oracle Database Packages and Types VALID 10.2.0.1.0
JAVAVM JServer JAVA Virtual Machine REMOVED
spool off;
查看日志,看有没有其他的错误。如果没有继续下面的步骤。
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> set echo on
SQL> spool full_jvminst.log
SQL> startup mount
ORACLE instance started.
Total System Global Area 369098752 bytes
Fixed Size 1219448 bytes
Variable Size 83887240 bytes
Database Buffers 276824064 bytes
Redo Buffers 7168000 bytes
Database mounted.
SQL> alter system set "_system_trig_enabled"=false scope=memory;
System altered.
SQL> alter database open;
Database altered.
SQL> @?/javavm/install/initjvm.sql
。。。。。。。很多日志。。。。。
SQL>@?/xdk/admin/initxml.sql
。。。。。。。很多日志。。。。
SQL> @?/rdbms/admin/catjava.sql
在执行的时候会耗费一些时间,开另外一个窗口查询dba_registry,就能够看到状态的变化。
SQL> /
COMP_ID COMP_NAME STATUS VERSION
------------------------------ -------------------------------------------------- ----------- ------------------------------
CATALOG Oracle Database Catalog Views VALID 10.2.0.1.0
CATPROC Oracle Database Packages and Types VALID 10.2.0.1.0
JAVAVM JServer JAVA Virtual Machine VALID 10.2.0.1.0
XML Oracle XDK VALID 10.2.0.1.0
CATJAVA Oracle Database Java Packages LOADING
SQL> /
COMP_ID COMP_NAME STATUS VERSION
------------------------------ -------------------------------------------------- ----------- ------------------------------
CATALOG Oracle Database Catalog Views VALID 10.2.0.1.0
CATPROC Oracle Database Packages and Types VALID 10.2.0.1.0
JAVAVM JServer JAVA Virtual Machine VALID 10.2.0.1.0
XML Oracle XDK VALID 10.2.0.1.0
CATJAVA Oracle Database Java Packages LOADED 10.2.0.1.0
COMP_ID COMP_NAME STATUS VERSION
------------------------------ -------------------------------------------------- ----------- ------------------------------
CATALOG Oracle Database Catalog Views VALID 10.2.0.1.0
CATPROC Oracle Database Packages and Types VALID 10.2.0.1.0
JAVAVM JServer JAVA Virtual Machine VALID 10.2.0.1.0
XML Oracle XDK VALID 10.2.0.1.0
CATJAVA Oracle Database Java Packages VALID 10.2.0.1.0
--最后执行
SQL> @?/rdbms/admin/catexf.sql
--成功执行后,查看状态,
COMP_ID COMP_NAME STATUS VERSION
------------------------------ -------------------------------------------------- ----------- ------------------------------
CATALOG Oracle Database Catalog Views VALID 10.2.0.1.0
CATPROC Oracle Database Packages and Types VALID 10.2.0.1.0
JAVAVM JServer JAVA Virtual Machine VALID 10.2.0.1.0
XML Oracle XDK VALID 10.2.0.1.0
CATJAVA Oracle Database Java Packages VALID 10.2.0.1.0
EXF Oracle Expression Filter VALID 10.2.0.1.0
6 rows selected.
--sanity check for component installation
SQL> select count(*),status,owner from all_objects where object_type like '%JAVA%' group by status,owner;
COUNT(*) STATUS OWNER
---------- ------- ------------------------------
15505 VALID SYS
42 VALID EXFSYS
SQL> select owner,object_type,count(*)from all_objects where object_type like '%JAVA%' and status <>'VALID' group by owner,object_type;
no rows selected
check spool log . 看有没有关联的ora-错误。
最后如果没问题,证明这些组件都已经成功安装,重启数据库。
- Oracle BIEE (Business Intelligence) 11g 11.1.1.6.0 学习(2)RPD资料档案库创建
- Oracle BIEE (Business Intelligence) 11g 11.1.1.6.0 学习(3)创建一个简单的分析
- 请查收!这里有一封信鸽传给您的信
- Oracle BIEE (Business Intelligence) 11g 11.1.1.6.0 学习(4)创建多维钻取分析
- silverlight:RadMaskedTextBox设置MaskType="Numeric"及Mask="n"时的一个bug
- 微信里面最神秘的功能,你知道吗?
- 以大数据之名,变身!——In big data we trust
- 90%家长都不知道关于少儿编程的这些疑题!
- 常用SQL语句和语法汇总
- Python学习笔记1——斐波那契数列
- 视觉传感器几大技术要点详解!
- Spark之搜狗日志查询实战
- 区块链与数字货币是什么关系呢?
- 保存数据到MySql数据库——我用scrapy写爬虫(二)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Android性能之冷启动优化详析
- Android自定义View实现地铁显示牌效果
- Android自定义控件实现望远镜效果
- Android自定义View实现点赞控件
- Android自定义View实现投票进度条
- 国外Reservo一款非常棒的商业图床程序
- 详解Android v1、v2、v3签名(小结)
- Android Studio项目适配AndroidX(Android 9.0)的方法步骤
- Android自定义View实现微信语音界面
- Android仿微信录音功能(录音后的raw文件转mp3文件)
- Android基于腾讯云实时音视频仿微信视频通话最小化悬浮
- Android自定义View之RadioGroup实现跨多行显示
- Android RadioGroup多行显示效果 解决单选问题
- RadioGroup实现单选框的多行排列
- Android实现悬浮窗全系统版本