被这个OracleDBconsole服务无法启动的问题折磨了两个星期了,今天很幸运,在网上无意间看到了一位大侠的思路,虽然错误的情况并不完全相同,但他的思路完全可以搬过来用。
环境:Windows XP, 装Oracle 11g,装完数据库软件、新建一个数据库(数据库的SID为orcl20120825),但是无法进入网页版的企业管理器(EM),提示是“403,服务器拒绝了您的访问请求”。因为数据库的ID是orcl20120825,因此对应的Windows服务名为OracleDbConsoleorcl20120825,原因不多说了,想必遇到过这个问题的朋友都知道,就是这个服务没有启动,所以进不了企业管理器。尝试启动这个服务,提示“Windows 不能在 本地计算机 启动 OracleDBConsoleorcl。有关更多信息,查阅系统事件日志。如果这是非 Microsoft 服务,请与服务厂商联系,并参考特定服务错误代码 2。”
至于具体的原因,网上有很多人讨论,大概是计算机名改变、IP地址更改等情况,就不分别讨论了。具体的出错原因,只有计算机自己才能回答,所以,还是先问cmd吧~
       那就在cmd中启动企业管理器试试吧:
       1.C:\Documents and Settings\Administrator>emctl start dbconsole
        这是启动控制台的命令,它当然报错:
        Environment variable ORACLE_UNQNAME not defined. Please set ORACLE_UNQNAME to database unique name.
虽然并不十分清楚,但可以肯定的是,不能启动的原因一定和ID、SID之类的变量有关,也许是数据库的名称,也许是计算机的名称,也许是某个文件的名称。继续~
       2.既然cmd说要给数据库设置一个ORACLE_UNQNAME,于是在网上搜了一下,大概是这个命令:
         C:\Documents and Settings\Administrator>set ORACLE_UNQNAME=orcl20120825
         敲了回车没反应,额,,,于是再敲个分号,,,
         C:\Documents and Settings\Administrator>;
         还是没反应,,,算了,就当是已经设置过了吧,那么再尝试着启动一下企业管理器:
         C:\Documents and Settings\Administrator>emctl start dbconsole
         继续报错,不过这次的内容具体一点了:
         OC4J Configuration issue. E:\app\Administrator\product\11.2.0\dbhome_1/oc4j/j2ee /OC4J_DBConsole_180.111.140.106_orcl20120825 not found.
         很显然,是因为Oracle找不到提示的这个文件或文件夹而报错。那么理所当然得,可以去提示中给出的目录看一看,如下图:

果然,在这个目录下并没有OC4J_DBConsole_180.111.140.106_orcl20120825这个文件夹或者文件。但是,注意到该目录下有一个和提示中的文件名非常相似的文件夹
OC4J_DBConsole_localhost_orcl20120825,只有中间的部分不同。到这一步,情况开始明朗了。
很显然,180.111.140.106看上去是个外网地址,似乎是出现在动态分配IP的情况下,可以验证一下,重新开一个cmd,>ipconfig,如下图:

果然,这是个动态分配的本机IP地址。而上文目录中的OC4J_DBConsole_localhost_orcl20120825文件夹,中间的localhost也代表了本机,到这一步,基本可以得出EM不能启动的原因了,大概是因为Oracle默认会用localhost去标识一些变量或文件,但是在后来的某个操作中,因为电脑已经处在连上外网的状态,因此有了一个动态的IP,于是Oracle改用这个动态IP去标识一些变量或者文件,所以就造成了一些有关联的文件或者系统设置出现了文件名前后不一致的问题。
故障原因找到了,接下来开始解决。这里就要借用那位大侠的思路了:
       1.根据以往在Windows下折腾的经验,可以猜测OC4J_DBConsole_localhost_orcl20120825文件夹和OC4J_DBConsole_180.111.140.106_orcl20120825文件夹中的内容是一样的,只是文件夹的名称不同而已。那既然提示说要找这个名字的文件夹,那是不是可以直接把OC4J_DBConsole_localhost_orcl20120825文件夹重命名,把它文件名中的localhost改成180.111.140.106呢?也许可以,但为了保险起见,还是先复制一份,再重命名。如下图:

于是,该目录下就有了名为OC4J_DBConsole_180.111.140.106_orcl20120825的文件夹。接下来,在cmd中继续执行上一次的命令,尝试启动EM

C:\Documents and Settings\Administrator>emctl start dbconsole
虽然还是报错,并且和上一个报错信息很相似:
EM Configuration issue. E:\app\Administrator\product\11.2.0\dbhome_1/180.111.140.106_orcl20120825 not found.
同样是提示在某路径下找不到某文件的提示,那么重复上一步的做法,到这次提示的目录中去看一下,如下图:

同样地,在这个目录下果然没有提示中的180.111.140.106_orcl20120825文件夹,但是又出现了一个文件名极其相似的文件夹:localhost_orcl20120825,很显然也是前文所说的IP地址改变造成的文件命名前后不一致的原因。复制上一步的思路,猜测180.111.140.106_orcl20120825文件夹中的内容和localhost_orcl20120825中的内容是一样的,于是复制一个localhost_orcl20120825文件夹并重命名为180.111.140.106_orcl20120825,如下图:

于是,该目录下就有了名为180.111.140.106_orcl20120825的文件夹。接下来,在cmd中继续执行上一次的命令,尝试启动EM:
C:\Documents and Settings\Administrator>emctl start dbconsole
虽然还是报错,并且和上一个报错信息很相似:
Unable to determine local host vide E:\app\Administrator\product\11.2.0\dbhome_1/180.111.140.106_orcl20120825/sysman/config/emd.properties : No such file or directory
这次的提示更具体了,是在指定的目录下找不到指定的文件。那么,重复上一步的做法,到提示中给出的目录下去看一看,如下图:

这次情况稍微有点小复杂,180.111.140.106_orcl20120825/sysman/目录下只有一个opmn文件夹,并没有提示中的config文件夹,也没有和“config”名称相似的文件夹,怎么办呢?
举一反三!既然上文猜测180.111.140.106_orcl20120825文件夹和localhost_orcl20120825文件夹中的内容一致,那么自然而然就可以想到回上一步的localhost_orcl20120825文件夹中去看一看:如下图:

在localhost_orcl20120825中的sysman目录下,可以看到其实里面的内容和180.111.140.106_orcl20120825下sysman目录中的内容并不相同,但两者都有一个opmn文件夹,并且localhost_orcl20120825\sysman目录下多了四个文件夹,并且其中一个名为config,而上一步报错提示的路径中就有config目录,并且这个config文件夹中就有一个和上一步报错提示中同名的emd.properties的文件,于是类似地重复之前的思路,把localhost_orcl20120825\sysman目录下的config、emd、log、recv复制到180.111.140.106_orcl20120825\sysman目录下(因为opmn文件夹还不知道有什么用处,所以先不动它)。这样,180.111.140.106_orcl20120825\sysman下的目录结构就和localhost_orcl20120825\sysman下的目录结构相同了,如下图:

接下来,在cmd中继续执行上一次的命令,尝试启动EM:
C:\Documents and Settings\Administrator>emctl start dbconsole
额,,,貌似没报错:
Oracle Enterprise Manager 11g Database Control Release 11.2.0.1.0
Copyright (c) 1996, 2010 Oracle Corporation.  All rights reserved.
https://localhost:1158/em/console/aboutApplication
Starting Oracle Enterprise Manager 11g Database Control ...OracleDBConsoleorcl20
120825 服务正在启动 ...............................................
OracleDBConsoleorcl20120825 服务已经启动成功。
启动了!
再去Windows服务中看一下:

这个服务果然启动了!
不放心,再用浏览器进EM试试:


↓↓↓

↓↓↓

至此,解决了一块长久以来的心病!

OracleDBconsoleorcl服务无法启动的原因及解决思路的更多相关文章

  1. OracleDBConsoleorcl 服务无法启动:Agent process exited abnormally during initialization.

    OracleDBConsoleorcl 服务无法启动 在事件查看器里看到 Agent process exited abnormally during initialization.的记录.知道是因为 ...

  2. installshield制作的安装包卸载时提示重启动的原因以及解决办法

    原文:installshield制作的安装包卸载时提示重启动的原因以及解决办法 有时候卸载installshield制作的安装包程序,卸载完会提示是否重启电脑以完成所有卸载,产生这个提示的常见原因有如 ...

  3. S​Q​L​ ​S​e​r​v​e​r​ ​服务无法启动,错误1069解决办法

    刚刚接到公司服务器上的SQL Server服务无法启动的问题需要解决,在进入“SQL Server 配置管理器”启动MSSQLServer 服务时,启动过程异常缓慢预示着“异常”的存在.果然,系统给出 ...

  4. 安装ORACLE后,改变计算机名称,导致OracleDBConsoleOrcl服务无法启动

    错误信息: 启动oracledbconsoleorcl 服务提示 -- “--Windows不能再本地计算机启动oracledbconsoleorcl  有关更多信息,查阅系统事件日志,如果这是非Mi ...

  5. CentOS7下MySQL服务启动失败原因及解决方法

    在重启阿里的CentOS7服务器后,重启MySQL 出现错误 Starting mysqld (via systemctl): Job for mysqld.service failed becaus ...

  6. Docker无法正常启动的原因及解决办法

    一.Docker启动异常表现: 1.状态反复restaring,用命令查看 $docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS ...

  7. apple mobile device服务无法启动,错误1053 解决

    我不想安装iTunes,于是下了iTunes64安装包,解压后得到6个文件 安装完 AppleMobileDeviceSupport64.msi 发现服务启动不起来,提示错误1053,网上搜了下发现出 ...

  8. 使用net start mysql的时候出现服务名无效的原因及解决办法

    原因:mysql服务没有安装 解决办法:使用管理员权限,执行mysqld -install命令 然后以管理员身份net start mysql开启mysql服务 卸载mysql服务的方法 1.管理员权 ...

  9. tomcat8启动慢原因及解决办法

    tomcat8在linux下安装使用一段时间后启动非常慢,6分钟左右. 原因是一个随机数生成参数导致的. 处理如下: 修改catalina.sh .配置JRE使用非阻塞的Entropy Source ...

随机推荐

  1. BZOJ4372烁烁的游戏——动态点分治+线段树(点分树套线段树)

    题目描述 背景:烁烁很喜欢爬树,这吓坏了树上的皮皮鼠.题意:给定一颗n个节点的树,边权均为1,初始树上没有皮皮鼠.烁烁他每次会跳到一个节点u,把周围与他距离不超过d的节点各吸引出w只皮皮鼠.皮皮鼠会被 ...

  2. property装饰器

    # 需要了解的property的用法 class People: def __init__(self,name): self.__name=name @property def name(self): ...

  3. 一种HBase表数据迁移方法的优化

    1.背景调研: 目前存在的hbase数据迁移主要分如下几类: 根据上图,可以看出: 其实主要分为两种方式:(1)hadoop层:因为hbase底层是基于hdfs存储的,所以可以通过把hdfs上的数据拷 ...

  4. 【XSY2808】董先生的休闲方案 组合数学

    题目描述 有\(n\)个方案,编号为\(1\ldots n\). 最开始你不知道每个方案的编号. 你要按顺序提出这些方案. 每一个时刻你要做以下事情: 如果你阅读过下一个方案,就提出这个方案. 否则随 ...

  5. bzoj 1854: [Scoi2010]游戏 (并查集||二分图最大匹配)

    链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1854 写法1: 二分图最大匹配 思路:  将武器的属性对武器编号建边,因为只有10000种 ...

  6. MySQL中 如何查询表名中包含某字段的表

    查询tablename 数据库中 以"_copy" 结尾的表 select table_name from information_schema.tables where tabl ...

  7. 【hihocoder1167】高等理论计算机科学 (重链剖分 +树状数组)

    Descroption 原题链接给你一棵\(~n~\)个点的树和\(~m~\)条链,求两两相交的链有多少对,两条链相交当且仅当有至少一个公共点.\(~1 \leq n, m \leq 10 ^ 5~\ ...

  8. linux中$#,$0,$1,$2,$@,$*,$$,$?的含义

    $# 是传给脚本的参数个数$0 是脚本本身的文件名$1 是脚本后接的第一个参数$2 是脚本后接的第二个参数$@ 是传给脚本的所有参数列表,"$1" "$2" & ...

  9. Docker自动补全容器名

    Zsh Place the completion script in your /path/to/zsh/completion (typically ~/.zsh/completion/): 下载自动 ...

  10. P1972 HHのnecklace 离线+树状数组

    此题莫队可过 然而太难了...... 我在胡雨菲那看的解法,然后自己打了一波,调了一个错,上交,自信AC. 做法:离线,对于L排序. 每种颜色可能出现很多次,那么我们如何不算重复呢? 只需把[L,n] ...