我已经编写了一个Oozie工作流,它运行一个BASH shell脚本来执行一些hive查询并对结果执行一些操作。脚本运行,但在访问某些HDFS数据时抛出权限错误。提交Oozie工作流的用户有权限,但脚本是以yarn用户身份运行的。
是否可以让Oozie以提交工作流的用户身份执行脚本?配置单元和Java操作都是以提交的用户身份执行的,只是shell的行为不同。
下面是我的Oozie行动的大致轮廓
<action name="start_action"
retry-max="12"
retry-interval="600">
<shell xmlns="uri:oozie:shell-action:0.1">
<job-tracker>${jobTracker}</job-tracker>
<name-node>${nameNode}</name-node>
<job-xml>${WorkflowRoot}/hive-site.xml</job-xml>
<exec>script.sh</exec>
<file>${WorkflowRoot}/script.sh</file>
<capture-output />
</shell>
<ok to="next_action"/>
<error to="send_email"/>
</action>我运行的是Oozie 4.1.0和HDP 2.1。
发布于 2015-09-29 09:07:52
在使用简单安全配置的所有群集中都会出现此问题。您可以选择覆盖默认配置。在shell脚本的开头包含以下语句将解决此问题。
export HADOOP_USER_NAME=<Name of submitted user>;https://stackoverflow.com/questions/31752959
复制相似问题