linux中hive启动异常,最详细解决方法

 报错结果如下:

Casue by:Unable to instantiate org.apache.hadoop.hive.ql.metadata.SessionHiveMetaStoreClient

Casue by:javax.jdo.JDOFatalDataStoreException: Unable to open a test connection to the given database. JDBC url = jdbc:mysql://localhost:3306/hive?createDatabaseIfNotExist=true, username = hive. Terminating connection pool (set lazyInit to true if you expect to start your database after your app). Original Exception: ------
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

Casue by:javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)

 原因分析:

寻找了许多资料后发现是以下问题

1、hdfs安全模式未退出

首先检查hdfs是否进入了安全模式,如果先前有过hive异常退出,就是没有关闭hive然后强制关闭计算机的情况,那么就有可能使得hdfs中的文件产生异常错误,通过关闭安全模式就可以正常进入hive。

开启安全模式
hdfs dfsadmin -safemode enter
关闭安全模式
hdfs dfsadmin -safemode leave
获取安全模式的状态
hdfs dfsadmin -safemode get
等待安全模式关闭
hdfs dfsadmin -safemode wait
查看受损模块
hdfs fsck / -delete

如果处于关闭状态后还是无法启动报错,那么就是以下第二种问题。

 2、java调用ssl启动hive导致出现异常(最麻烦)

在Java8及高版本以上的版本在调用ssl时会出现javax.net.ssl.SSLHandshakeException: No appropriate protocol的异常

解决方法如下:

  • 修改jre/lib/security/java.security中的disabledAlgorithms,删除SSLv3, TLSv1, TLSv1.1。

jdk.tls.disabledAlgorithms=RC4, DES, MD5withRSA, \
    DH keySize < 1024, EC keySize < 224, 3DES_EDE_CBC, anon, NULL, \
    include jdk.disabled.namedCurves

 这里比较麻烦因为linux默认保护这里的程序因此需要先将文件的权限进行改写,才可以修改保存,指令如下:

cd java.sercurity所在的目录

进入该目录后输入

sudo chmod 777 java.security 

 以下为修改后的结果

然后就可以打开该文件完成修改了

修改前:

 

修改后:

 

  • 将conf/hive-site.xml中的内容更换为:
<property>
    <name>javax.jdo.option.ConnectionURL</name>
    <value>jdbc:mysql://localhost:3306/hive?createDatabaseIfNotExist=true&amp;useSSL=false</value>
    <description>JDBC connect string for a JDBC metastore</description>
</property>

 然后就可以正常启动了。

别忘记修改回去文件的权限,以免后续出现什么问题。

 

3、数据库服务没有打开

通常来说,在系统启动之后数据库服务就会自动打开,但是不排除意外。

这里以mysql数据库举例,可以使用以下指令检查数据库服务是否启动正常

service mysql status 检查状态

service mysql start

service mysql stop

service mysql restart 重启服务

 如果是绿灯就表示正常了

问题解决hive启动成功了

最后最好每次都关闭hdfs集群再关机,不然很可能出现异常错误。

./sbin/stop-dfs.sh

 

  • 23
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值