关于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-错误。

最后如果没问题,证明这些组件都已经成功安装,重启数据库。

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2014-03-31

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨建荣的学习笔记

利用shell脚本生成动态sql(67天)

在一些分布式环境中,可能涉及到的数据库有很多,相关的数据库用户也不少,有些看似简单的变更可能需要在不同的库,不同的用户间要进行复杂的操作。 现在我们有3套环境,...

2727
来自专栏乐沙弥的世界

Oracle 10.2.0.1 升级到 10.2.0.4

数据库升级并不难,只要遵循其步骤,一般问题不大。但是升级失败的情况也是屡见不鲜,尤其是生产数据库的升级,搞不定的时候甚至要创建SR。

823
来自专栏杨建荣的学习笔记

关于ora-02391问题的总结(r6笔记第40天)

关于ORA问题的分析和解决其实是一个很好的学习思路,抓住一个每一个ORA错误,然后进一步分析一些原因,总结,总会有不一样的收获,还是那句话,任何问题背后都是有原...

2204
来自专栏跟着阿笨一起玩NET

SQL将本地图片文件插入到数据库

562
来自专栏杨建荣的学习笔记

10g升级至11g后数据库无法启动的问题解决

今天升级数据库碰到一个很郁闷的问题,把10g的数据库升级到11g以后,结果有一个改动,需要重启数据库,就敲了shutdown immediate,结果再star...

3426
来自专栏乐沙弥的世界

Oracle cloud control 12c 如何修改sysman密码

    前阵子在虚拟机部署了Oracle Cloud Control 12c,事别几日,竟然忘记了登陆密码。主要是因为现在的Oracle有关的Software...

551
来自专栏杨建荣的学习笔记

ORA-00439的解决(笔记93天)

今天用gc配置了stream后,重启数据库后发现有以下的问题 SQL> startup ORA-00439: feature not enabled: Real...

27210
来自专栏散尽浮华

git review报错一例

在线上修改代码,最后使用git review提交代码审核的时候出现报错如下: [wangshibo@115~]$ vim testfile           ...

1637
来自专栏杨建荣的学习笔记

手工创建/删除数据库的步骤

今天和大家分享下数据库的创建和删除的步骤,里面有很多细节需要大家考虑。创建数据库不只是一个create database语句。删除数据库 drop databa...

3016
来自专栏个人分享

Spark工程开发常用函数与方法(Scala语言)

import org.apache.spark.{SparkContext, SparkConf} import org.apache.spark.sql.{S...

612

扫描关注云+社区