Hadoop Jar Launch Using Luigi Piano

I need to run hadoop jar job using Luigi from python. I searched and found examples of writing a cartographer and gearbox in Luigi, but nothing gave a direct Hadoop banner.

I need to run a Hadoop jar compiled directly. How should I do it?

+4
source share
1 answer

You need to use the package luigi.contrib.hadoop_jar( code ).

In particular, you need to expand HadoopJarJobTask. For example, for example:

from luigi.contrib.hadoop_jar import HadoopJarJobTask
from luigi.contrib.hdfs.target import HdfsTarget

class TextExtractorTask(HadoopJarJobTask):
    def output(self):
        return HdfsTarget('data/processed/')

    def jar(self):
        return 'jobfile.jar'

    def main(self):
        return 'com.ololo.HadoopJob'

    def args(self):
        return ['--param1', '1', '--param2', '2']

You can also include jar file creation with maven in the workflow:

import luigi
from luigi.contrib.hadoop_jar import HadoopJarJobTask
from luigi.contrib.hdfs.target import HdfsTarget
from luigi.file import LocalTarget

import subprocess
import os

class BuildJobTask(luigi.Task):
    def output(self):
        return LocalTarget('target/jobfile.jar')

    def run(self):
        subprocess.call(['mvn', 'clean', 'package', '-DskipTests'])

class YourHadoopTask(HadoopJarJobTask):
    def output(self):
        return HdfsTarget('data/processed/')

    def jar(self):
        return self.input().fn

    def main(self):
        return 'com.ololo.HadoopJob'

    def args(self):
        return ['--param1', '1', '--param2', '2']

    def requires(self):
        return BuildJobTask()
+3
source

Source: https://habr.com/ru/post/1584055/


All Articles