报错结果如下:
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 failureCasue 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&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