Sha256: 804c25c76a36f79d3609d62b310c9a6dcefe1e16c0ef1ad8f667fac6b58d065f
Contents?: true
Size: 1.4 KB
Versions: 1
Compression:
Stored size: 1.4 KB
Contents
module Elasticity class HiveStep include Elasticity::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 --base-path s3://elasticmapreduce/libs/hive/ --hive-versions latest --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 => %w(s3://elasticmapreduce/libs/hive/hive-script --base-path s3://elasticmapreduce/libs/hive/ --install-hive --hive-versions latest) }, :name => 'Elasticity - Install Hive' } end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
elasticity-2.5.1 | lib/elasticity/hive_step.rb |