zoukankan      html  css  js  c++  java
  • 记一次生产环境presto删表失败的问题

    场景,开发用java程序连接presto创建一个表,这个表在hdfs的权限为:

    然后用presto去删除这个表

    报错,没有权限删除,查看上一级目录权限,发现权限正常

    直连hive删表

    发现正常. 然后使用developer直连hive 创建表,用presto删除还是报错没有权限。

    连接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;

    查看表的属主  select OWNER ,TBL_NAME  from TBLS  where TBL_NAME="t_5d550e8bce6a1952f8a8af7c" ;

    再次用presto(jmx.configure

    )创建表

     发现 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" ;

  • 相关阅读:
    项目工程化之git提交规范以及 CHANGELOG生成
    移动端 弹窗-内容可滚动,背景不动
    项目readme文件目录生成工具 treer
    css animation动画
    【网络】从套接字到Web服务器
    【网络】图解HTTP-1
    【MySQL】搞懂ACID原则和事务隔离级别
    【MySQL】备份与恢复
    【MySQL】索引
    【Redis】主从复制原理
  • 原文地址:https://www.cnblogs.com/ZFBG/p/10951211.html
Copyright © 2011-2022 走看看