场景,开发用java程序链接presto建立一个表,这个表在hdfs的权限为:java
而后用presto去删除这个表测试
报错,没有权限删除,查看上一级目录权限,发现权限正常3d
直连hive删表rest
发现正常. 而后使用developer直连hive 建立表,用presto删除仍是报错没有权限。blog
链接hive 元数据MySQL 开发
select t.OWNER, p.PRINCIPAL_NAME, count(1) from TBLS t join TBL_PRIVS p on p.TBL_ID=t.TBL_ID group by t.OWNER, p.PRINCIPAL_NAME;class
查看表的属主 select OWNER ,TBL_NAME from TBLS where TBL_NAME="t_5d550e8bce6a1952f8a8af7c" ;配置
再次用presto(jmx.configure select
)建立表权限
发现 common对应的count增长了,可是developer的没有增长。
问题就明了了。 presto默认是以启动presto的用户来作hive元数据的也就是这里的common用户, 可是存储用户是以jmx.configure 里面配置的用户来设定的。因此 在presto里面(developer用户进入)删除这个表会提示权限不够
解决方法修改 jmx.config
而后以common用户启动presto
最新结论
presto 有两个用户配置
第一个是 这个配置影响的是数据 在hdfs里面写入的属主
第二个是
这个配置目前测试并无什么用!!!
另外 java程序的配置文件 以及你本地链接presto用的是什么用户 那么这个用户就是 hive里面建立的表的元数据的属主。
查看表的属主 select OWNER ,TBL_NAME from TBLS where TBL_NAME="t_5d550e8bce6a1952f8a8af7c" ;