oozie使用(调用java外部类)

在Oozie的workflow上面调用jar包
workflow.xml






${jobTracker}
${nameNode}


mapreduce.job.queuename
${queueName}


mapred.job.queue.name
${queueName}


oozie.launcher.mapred.job.queue.name
${oozie_launcher_queue}


com.idata.Helloworld






shell


job.properties

nameNode=hdfs://namehaservice
jobTracker=namenode1:8032
queueName=default
oozie_launcher_queue=root.oozie
oozie.use.system.libpath=true
sdaRoot=sda
oozie.wf.application.path=${nameNode}/user/${user.name}/${sdaRoot}/shell

如果依赖外部包, 需要在项目文件下创建一个lib包,和项目文件一起put到HDFS上面去。

Paste_Image.png

否则会出现ClassNotFoundException。

Paste_Image.png

Oozie有个配置文件,会将job中的所有java文件引导到一个libpath下面:
Properties代码(可以不配置)

#use custom library
oozie.libpath=${namenode}/user/hadoop/share/lib

你可能感兴趣的:(oozie使用(调用java外部类))