Sha256: 05c0f82351afbe66ab0936722a484a4a39c15096bf59c6b22a1e771579c3ccd1

Contents?: true

Size: 1.38 KB

Versions: 5

Compression:

Stored size: 1.38 KB

Contents

module Elasticity

  class HiveStep

    include JobFlowStep

    attr_accessor :name
    attr_accessor :script
    attr_accessor :variables
    attr_accessor :action_on_failure

    def initialize(script)
      @name = "Elasticity Hive Step (#{script})"
      @script = script
      @variables = { }
      @action_on_failure = 'TERMINATE_JOB_FLOW'
    end

    def to_aws_step(job_flow)
      args = %w(s3://elasticmapreduce/libs/hive/hive-script --run-hive-script --args)
      args.concat(['-f', @script])
      @variables.keys.sort.each do |name|
        args.concat(['-d', "#{name}=#{@variables[name]}"])
      end
      {
        :name => @name,
        :action_on_failure => @action_on_failure,
        :hadoop_jar_step => {
          :jar => 's3://elasticmapreduce/libs/script-runner/script-runner.jar',
          :args => args
        }
      }
    end

    def self.requires_installation?
      true
    end

    def self.aws_installation_step
      {
        :action_on_failure => 'TERMINATE_JOB_FLOW',
        :hadoop_jar_step => {
          :jar => 's3://elasticmapreduce/libs/script-runner/script-runner.jar',
          :args => [
            's3://elasticmapreduce/libs/hive/hive-script',
              '--base-path',
              's3://elasticmapreduce/libs/hive/',
              '--install-hive'
          ],
        },
        :name => 'Elasticity - Install Hive'
      }
    end

  end

end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
elasticity-2.3 lib/elasticity/hive_step.rb
elasticity-2.2 lib/elasticity/hive_step.rb
elasticity-2.1.1 lib/elasticity/hive_step.rb
elasticity-2.1 lib/elasticity/hive_step.rb
elasticity-2.0 lib/elasticity/hive_step.rb