JDBC访问Hive失败 & beenline连接Hive 和导入文件 时提示anonymous用户权限不够

前言

    最近项目中有跟hive交互的部分,在测试环境用JDBC方式和beenline方式访问hive server时访问失败,下面来记录下问题的解决过程;

正文

JDBC访问hive server2失败

    程序中关于hive配置信息写在了application.yaml文件中
在这里插入图片描述
    用postman测试访问hive 相关接口,响应结果为空!
     因为JDBC的访问基于beenline(它是基于SQLLine CLI的JDBC客户端),所以想要弄清楚缘由还是用beenline 去访问hive server2 ( 远程模式);

beenline 访问hive 和 导入txt文件到hive 中显示权限不足

# 访问hive命令
 ./beeline -u jdbc:hive2://:10000
# 提示信息 
ERROR : Job Submission failed with exception 'org.apache.hadoop.security.AccessControlException
#  用户为anonymous ,没有权限访问!
(Permission denied: user=anonymous, access=WRITE, inode="/user":hdfs:supergroup:drwxr-xr-x
	at org.apache.hadoop.hdfs.server.namenode.DefaultAuthorizationProvider.checkFsPermission(DefaultAuthorizationProvider.java:279)
	at org.apache.hadoop.hdfs.server.namenode.DefaultAuthorizationProvider.check(DefaultAuthorizationProvider.java:260)
	

HDFS方式导入txt文件数据到hive中

在这里插入图片描述

问题分析与解决

     通过日志发现是匿名用户访问权限不足的原因,那么解决权限问题就可以啦!

  • 使用jdbc方式连接hive没有提供用户名,hive认为请求者为anonymous 用户;
  • 默认情况下,是不允许远程以匿名用户访问的,如果访问会提示权限不足;
         提升权限
  • JDBC : 在配置文件中写上超级管理员的用户名
#hive 数据仓库配置
hive:
  datasource:
    url: jdbc:hive2://IP:10000
    driver-class-name: org.apache.hive.jdbc.HiveDriver
    type: com.alibaba.druid.pool.DruidDataSource
    # username依据hadoop生态系统而定
    username: hdfs 
    password:
  • beenline: 在连接hive时使用-n 用户名参数指定访问的用户身份
beeline -n hdfs -u jdbc:hive2://IP:10000

总结

     问题越早出现越好,在试错中不断成长,加油!

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奔跑的大白啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值