报错
DBeaver连接Apache Hive数据仓库后,执行DDL语句,报错:org.apache.hadoop.security.AccessControlException等
原因
DBeaver连接Apache Hive用户权限问题,之前连接Apache Hive时,没有使用具体的用户就直接连接了,没有权限导致无法执行HQL的DDL语句;
解决方法
解决方法1
将连接Apache Hive的用户名修改为root,即与服务器上运行hadoop的用户一致;
这里不用输入密码也可以连接
解决方法2
修改hadoop的配置文件:conf/hdfs-core.xml,添加或者修改 dfs.permissions 的值为 false。
解决方法3
在非hadoop运行的用户下进行写入hdfs文件系统中时,由于对"/"目录没有写入权限,所以导致异常的发生。解决方法即开放hadoop中的HDFS目录的权限,命令如下:hadoop fs -chmod 777 /
解决方法4
在系统环境变量中增加HADOOP_USER_NAME,其值为root;
或者 通过java程序动态添加,如下:
System.setProperty(“HADOOP_USER_NAME”, “root”);
文章转载于:https://blog.youkuaiyun.com/weixin_30681615/article/details/96364642?ops_request_misc=&request_id=&biz_id=102&utm_term=org.apache.hadoop.security.Acc&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduweb~default-2-96364642.142v94insert_down28v1&spm=1018.2226.3001.4187