博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HiveServer2 Impersonation
阅读量:7137 次
发布时间:2019-06-28

本文共 669 字,大约阅读时间需要 2 分钟。

CDH4.2.0开始支持hiveserver2impersonation,只需要设置参数hive.server2.enable.impersonation(该参数在Hive里是HIVE_SERVER2_KERBEROS_IMPERSONATION,容易被误会和kerberos一起使用)true即可,这样可以使得提交的HQL以提交用户来运行MAPREDUCE而不是运行HiveserverUser,那么具体是如何实现的呢:

当通过ThriftCliService开启一个Session时,如果开启了上面的参数,则会调用CliServiceopenSessionWithImpersonation方法进而SessionManager就会生成一个HiveSession的动态代理HiveSessionImplwithUGI,并把用户的UGI传入进去:

session = (HiveSession)HiveSessionProxy.getProxy(hiveSessionUgi,hiveSessionUgi.getSessionUgi());

hiveSessionUgi.setProxySession(session);

每次执行方法的时候都是通过ShimLoader.getHadoopShims().doAs执行,如果没有指定该参数则是以运行Hiveserver的用户执行.

本文转自MIKE老毕 51CTO博客,原文链接:http://blog.51cto.com/boylook/1311584,如需转载请自行联系原作者

你可能感兴趣的文章
Java volatile 关键字
查看>>
http 头信息详解
查看>>
计算机图形学(OpenGL版)-OpenGL基本几何图元
查看>>
Oracle 12C 新特性之表分区带 异步全局索引异步维护(一次add、truncate、drop、spilt、merge多个分区)...
查看>>
Mybatis动态SQL生成
查看>>
javascript 正则表达式学习
查看>>
关于Asp.Net中避免用户连续多次点击按钮,重复提交表单的处理
查看>>
js页面刷新一次
查看>>
坑人的运算符
查看>>
spring security custom-filter with java configuration 验证码验证
查看>>
01、BootstrapperShell
查看>>
Automation Test in Maya Plugin Development
查看>>
DRM 简介
查看>>
idea编译时JDK版本变化
查看>>
搭建LoadRunner中的场景(一) 创建场景
查看>>
蓄水池算法
查看>>
POJ2049
查看>>
** turtle模块和random模块
查看>>
javaScript-进阶篇(一)
查看>>
介绍SmartUpload很好的网站
查看>>