Oracle 12c CC安装碰见的认证问题

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> Oracle 12c CC安装碰见的认证问题

维护的系统增加,导致对应需要维护的开发数据库环境也增加了,为了简化管理和监控,搭建图形化管理平台,是一种不错的解决方案,我们知道,11g就有了GC(Grid Control),发展到现在,已经有了12c CC和13c CC(Cloud Control)。

这两篇文章,介绍了安装12c CC的整个流程。

这次要说的是,由于机房搬迁,需要用新的机器来搭建,但即使安装步骤,和之前一样,运行到62%的时候,总是会出错,
Oracle 12c CC安装碰见的认证问题

看下日志,报的是未连接Node Manager,还有一些General SSLEngine problem的错误,

……
Connecting to Node Manager …
This Exception occurred at Thu Jul 13 14:33:03 CST 2017.
javax.net.ssl.SSLHandshakeException: General SSLEngine problem
Thu Jul 13 14:33:03 CST 2017
Node Manager is not running
……
Jul 13, 2017 2:33:04 PM oracle.sysman.omsca.util.CoreOMSConfigAssistantUtil execCommand
INFO: error messages of the command :
SEVERE: Exception: during Admin Server start
Name of Exception: main.WLSTException
Code of Exception: Error occured while performing nmConnect : Cannot connect to Node Manager. : General SSLEngine problem
Use dumpStack() to view the full stacktrace
traceback object at  87
SEVERE: Exception: during create_em_infra
Name of Exception: exceptions.SystemExit
Code of Exception: 5
traceback object at  88
SEVERE: Exception: during stop of admin server
Name of Exception: main.WLSTException
Code of Exception: Error occured while performing nmConnect : Cannot connect to Node Manager. : General SSLEngine problem
Use dumpStack() to view the full stacktrace
traceback object at  89
……
Jul 13, 2017 2:33:04 PM oracle.sysman.omsca.adapter.wls.OMSWLSAdapter adapterCreateInfra
FINE: Done Executing the command…5
Jul 13, 2017 2:33:04 PM oracle.sysman.omsca.adapter.wls.OMSWLSAdapter adapterCleanup
SEVERE: OMSWLSAdapter::Unable to backup the instance home log files
java.io.FileNotFoundException: /DATA/app/oracle/gc_inst/em/null (No such file or directory)
        at java.io.FileInputStream.open(Native Method)
        at java.io.FileInputStream.init(FileInputStream.java:146)
        at oracle.sysman.omsca.util.CoreOMSConfigAssistantUtil.copy(CoreOMSConfigAssistantUtil.java:505)
        at oracle.sysman.omsca.util.CoreOMSConfigAssistantUtil.copyDir(CoreOMSConfigAssistantUtil.java:2626)
        at oracle.sysman.omsca.adapter.wls.OMSWLSAdapter.adapterCleanup(OMSWLSAdapter.java:4412)
        at oracle.sysman.omsca.framework.OMSCAFreshInstall.execute(OMSCAFreshInstall.java:137)
        at oracle.sysman.omsca.framework.OMSConfigAssistantDriver.main(OMSConfigAssistantDriver.java:240)
        at oracle.sysman.omsca.framework.OMSCAFreshInstall.execute(OMSCAFreshInstall.java:137)
        at oracle.sysman.omsca.framework.OMSConfigAssistantDriver.main(OMSConfigAssistantDriver.java:240)

Connecting to Node Manager …

javax.net.ssl.SSLHandshakeException: General SSLEngine problem

Node Manager is not running

Jul 13, 2017 2:33:04 PM oracle.sysman.omsca.util.CoreOMSConfigAssistantUtil execCommand

SEVERE: Exception: during Admin Server start

Code of Exception: Error occured while performing nmConnect : Cannot connect to Node Manager. : General SSLEngine problem

traceback object at  87

Name of Exception: exceptions.SystemExit

traceback object at  88

Name of Exception: main.WLSTException

Use dumpStack() to view the full stacktrace

……

FINE: Done Executing the command…5

SEVERE: OMSWLSAdapter::Unable to backup the instance home log files

        at java.io.FileInputStream.open(Native Method)

        at oracle.sysman.omsca.util.CoreOMSConfigAssistantUtil.copy(CoreOMSConfigAssistantUtil.java:505)

        at oracle.sysman.omsca.adapter.wls.OMSWLSAdapter.adapterCleanup(OMSWLSAdapter.java:4412)

        at oracle.sysman.omsca.framework.OMSConfigAssistantDriver.main(OMSConfigAssistantDriver.java:240)

        at oracle.sysman.omsca.framework.OMSConfigAssistantDriver.main(OMSConfigAssistantDriver.java:240)

使用ps可以看出Node Manager的进程存在,之前的准备工作,未报任何错误。

无论是从MOS,还是互联网,未找到非常针对性的一些资料和建议,于是乎就在OTN上发了一个帖子,非常感谢handat和Martien两位的协助,虽然问题不是直接解决,但还是workaround解决了,问题完整版,可参考https://community.oracle.com/thread/4062966?start=0&tstart=0

以下是一些主要回复信息,

handat首先建议确认,安装前是否设置了ORACLE_HOSTNAME参数,确保hostname可以解析为需要连接Node Manager和OEM WLS所在机器IP。

Martien指出了可能有权限问题,

But the hostname that it tries to connect to should match the certificate, because of the hostname validation in the SSL handshake.

同时说了ORACLE_HOSTNAME不是安装的必要前提,确实如此。

multi-homed is a networking definition for when your machine has more than one network address: https://en.wikipedia.org/wiki/Multihoming Don’t confuse it with multiple ORACLE_HOMEs. ORACLE_HOSTNAME isn’t mandatory to be set prior to installation, but the installer will just pick the first network interface it finds and use that. If you are lucky, it might pick the right one and all goes well. However, in some cases, you might want to tell it which one to use in which case you set the ORACLE_HOSTNAME environment variable before you run the installer. In your case, you want to do it since the installer picked the wrong one.

排除了HOSTNAME问题,handat接着问了使用的jdk版本,因为certificate_unknown错误意味着使用cipher的认证,不再被支持,什么鬼。。。

A certificate_unknown error could mean that the certificate is using a cipher that is not supported anymore. You might need to use a older JDK that allows those ciphers or change the java policy file to allow it. Refer to this for more info: https://www.java.com/en/configure_crypto.html

Martien补充了下,

Or add the unlimited strengths policies: Java Cryptography Extension (JCE) Unlimited Strength Jurisdiction Policy Files for JDK/JRE 8 Download(http://www.oracle.com/technetwork/java/javase/downloads/jce8-download-2133166.html?printOnly=1)

这里我用的jdk 1.7.0_79这个版本。于是乎下载针对jdk 1.7的JCE文件,http://www.oracle.com/technetwork/java/javase/downloads/jce-7-download-432124.html,

Oracle 12c CC安装碰见的认证问题

根据JCE说明,需要备份US_export_policy.jar和local_policy.jar这两个本地jar,然后用下载包中的这两个文件,替换一下,路径是JAVA_HOME/lib/security文件夹,

Install the unlimited strength policy JAR files.
    In case you later decide to revert to the original “strong” but
    limited policy versions, first make a copy of the original JCE
    policy files (US_export_policy.jar and local_policy.jar). Then
    replace the strong policy files with the unlimited strength
    versions extracted in the previous step.
    The standard place for JCE jurisdiction policy JAR files is:
        java-home/lib/security           [Unix]
        java-homelibsecurity           [Windows]

但是重新安装,报错,

Oracle 12c CC安装碰见的认证问题 Oracle 12c CC安装碰见的认证问题

和之前一样,无法连接Node Manager,提示certificate_unknown错误。

handat指出,需要替换java.security文件中两个位置,

You need to update java.security and do the following changes:

replace: jdk.certpath.disabledAlgorithms=MD2, MD5, RSA keySize 1024 jdk.tls.disabledAlgorithms=SSLv3, MD5withRSA, DH keySize 768 with: jdk.certpath.disabledAlgorithms=MD2, RSA keySize 1024 jdk.tls.disabledAlgorithms=SSLv3, RC4, DH keySize 768

看了下我的文件,原始配置如下,

Oracle 12c CC安装碰见的认证问题 Oracle 12c CC安装碰见的认证问题

改为(第二行未变),

Oracle 12c CC安装碰见的认证问题 Oracle 12c CC安装碰见的认证问题

和之前一样,继续报错,handat说明如下,并指出应该用-D参数来启动Node Manager,

Your node manager it most likely misconfigured (the out of the box config is wrong since it defaults to the Certicom provider instead of JSSE for handling SSL/TLS) so unless the OEM installer changes it during the install, then it won’t be able to handshake which is what you are getting.
Assuming there is a retry option where it failed, try making the node manager use JSSE and restart it and click on retry so it can reattempt to handshake with the node manager.
I would try to see if there is a patch or later release which has a better installer.

I can't remember which one, but one of them will make the node manager use JSSE: -Dweblogic.ssl.JSSEEnabled=true -Dweblogic.security.SSL.enableJSSE=true Adding both should work, but one of them will be ignored.

但实际我的Node Manager启动的时候,已经带了-D参数,

Oracle 12c CC安装碰见的认证问题

奇怪的是,之前我用旧机器,就可以安装,这次步骤相同,就报错了?handat的解释非常到位,虽然相同的OS版本,但patch补丁可能不同,针对CVE(Common Vulnerabilities & Exposure),可能需要新的SSL库,新的更严格的安全标准,

You may had had the same OS version, but the patch level is probably different, the SSL libraries back then were much more lenient, while the newer SSL libraries after all the patching for the CVEs, will enforce the new security standards much more strictly and new sha1 certificates were rejected after December.

以上一系列方法,均未能解决,只能尝试大招,换一下jdk版本,用了最新的jdk 1.8版本,安装顺利完成了,可以使用12c CC来集成不同库,通过GUI做一些管理和监控工作,

Oracle 12c CC安装碰见的认证问题

总结:

  1. 12c CC的安转过程,即使操作系统版本相同,一些patch补丁不同,都有可能由于需要新的SSL库,或者新的认证方式,导致安装失败,因此保证软件环境的更新(jdk),是非常重要。

  2. 对于Oracle任何组件的安装,相应的日志,记录的错误信息,是我们排查问题的关键,一般会比较详细,当然碰见一些冷门错误,解决起来就需要一番周折。

如果您觉得此篇文章对您有帮助,欢迎关注微信公众号:bisal的个人杂货铺,您的支持是对我最大的鼓励!共同学习,共同进步:)

Oracle 12c CC安装碰见的认证问题

Android和IOS用户,可以激情赏赞,

Oracle 12c CC安装碰见的认证问题
本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> Oracle 12c CC安装碰见的认证问题


 上一篇
Linux运维必会的100道MySql面试题之(一) Linux运维必会的100道MySql面试题之(一)
写此文章的由来,源于老男孩老师在群里发的一篇文章 **  “Linux运维班MySQL必会面试题100道”** 因此,民工哥将题抄录下来,然后在线下环境将答案逐一验证,并写出来分享给需要的小伙伴,因答案纯属个人观点,难免会有不正之处,还望小
下一篇 
json格式值班表解析 json格式值班表解析
扯了两天的足球闲片了,今儿该说一说技术话题了,碰巧了有一个比较实际的问题,聊一聊如何用技术方法解决,开发上我不是大牛,写得不好的,请大牛指出。 这几天因为一些特殊原因,网站值班表不能用,一旦出现问题,找相应系统的值班人员,就比较困难了,但通