Hive的启动问题和解决办法

来源:互联网 发布:学游戏美工要多少钱 编辑:程序博客网 时间:2024/05/17 23:45

原文地址: http://blog.csdn.net/lxpbs8851/article/details/7991931

./hive 进入到hive 然后show tables 得到下面的错误信息。


hive> show tables;
FAILED: Error in metadata: javax.jdo.JDOFatalDataStoreException: Communications link failure
Last packet sent to the server was 0 ms ago.
NestedThrowables:com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
Last packet sent to the server was 0 ms ago.
FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask


问题定位:

mysql 里面配置文的设置

character_set_server = utf8
init_connect = 'SET NAMES utf8'

创建数据库的时候 数据库默认的字符集是utf8

但是 hive里面有个默认的表 字符集的长度 超过了这个限制。--,latin1 1000的长度,而utf8则最大是333


解决办法:

(当然hive-site.xml里面的配置要正确  检验的办法就是 用里面的配置参数在机器上面登录一下 可以登录的话 证明配置没错)

进入mysql 修改数据库的字符集类型:

mysql> alter database hive character set latin1;
Query OK, 1 row affected (0.00 sec)


然后再进hive  就成功了:

hive> show tables;
OK
Time taken: 3.854 seconds
hive>

 


 

原创粉丝点击