У меня есть рабочий процесс oozie, который будет вызывать файл оболочки, файл Shell дополнительно вызовет класс драйвера задания mapreduce. Теперь я хочу отобразить мою работу oozieId в Mapreduce jobId для последующего процесса. Есть ли способ получить oozie jobId в файле workflow, чтобы я мог передавать то же, что и аргумент в свой класс драйвера для сопоставления.Как получить oozie jobId в рабочем процессе oozie?
Ниже мой пример workflow.xml файл
<workflow-app xmlns="uri:oozie:workflow:0.4" name="test">
<start to="start-test" />
<action name='start-test'>
<shell xmlns="uri:oozie:shell-action:0.2">
<job-tracker>${jobTracker}</job-tracker>
<name-node>${nameNode}</name-node>
<configuration>
<property>
<name>mapred.job.queue.name</name>
<value>${queueName}</value>
</property>
</configuration>
<exec>${jobScript}</exec>
<argument>${fileLocation}</argument>
<argument>${nameNode}</argument>
<argument>${jobId}</argument> <!-- this is how i wanted to pass oozie jobId -->
<file>${jobScriptWithPath}#${jobScript}</file>
</shell>
<ok to="end" />
<error to="kill" />
</action>
<kill name="kill">
<message>test job failed
failed:[${wf:errorMessage(wf:lastErrorNode())}]</message>
</kill>
<end name="end" />
Ниже мой сценарий оболочки.
hadoop jar testProject.jar testProject.MrDriver $1 $2 $3
Спасибо, друг. Оно работает. – Vijayakumar