Class: Hotdog::Commands::Down
- Inherits:
-
BaseCommand
- Object
- BaseCommand
- Hotdog::Commands::Down
- Defined in:
- lib/hotdog/commands/down.rb
Instance Attribute Summary
Attributes inherited from BaseCommand
#application, #logger, #options, #persistent_db_path
Instance Method Summary collapse
Methods inherited from BaseCommand
#execute, #fixed_string?, #initialize, #parse_options, #reload
Constructor Details
This class inherits a constructor from Hotdog::Commands::BaseCommand
Instance Method Details
#define_options(optparse, options = {}) ⇒ Object
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/hotdog/commands/down.rb', line 6 def (optparse, ={}) default_option(, :downtime, 86400) default_option(, :retry, 5) default_option(, :start, Time.new) optparse.on("--downtime DURATION") do |v| case v when /\A\s*(\d+)\s*(?:seconds?|sec|S)\s*\z/ [:downtime] = $1.to_i when /\A\s*(\d+)\s*(?:minutes?|min|M)\s*\z/ [:downtime] = $1.to_i * 60 when /\A\s*(\d+)\s*(?:hours?|H)\s*\z/ [:downtime] = $1.to_i * 60 * 60 when /\A\s*(\d+)\s*(?:days?|d)\s*\z/ [:downtime] = $1.to_i * 60 * 60 * 24 when /\A\s*(\d+)\s*(?:weeks?|w)\s*\z/ [:downtime] = $1.to_i * 60 * 60 * 24 * 7 when /\A\s*(\d+)\s*(?:months?|m)\s*\z/i [:downtime] = $1.to_i * 60 * 60 * 24 * 30 when /\A\s*(\d+)\s*(?:years?|y)\s*\z/i [:downtime] = $1.to_i * 60 * 60 * 24 * 365 when /\A\s*(\d+)\s*\z/ [:downtime] = $1.to_i else raise(OptionParser::InvalidArgument.new("downtime argument value is invalid: #{v}")) end end optparse.on("--retry NUM") do |v| [:retry] = v.to_i end optparse.on("--retry-delay SECONDS") do |v| [:retry_delay] = v.to_i end optparse.on("--start TIME") do |v| [:start] = Time.parse(v) end end |
#run(args = [], options = {}) ⇒ Object
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/hotdog/commands/down.rb', line 43 def run(args=[], ={}) scopes = args.map { |arg| if arg.index(":").nil? "host:#{arg}" else arg end } hosts = scopes.select { |scope| scope.start_with?("host:") }.map { |scope| scope.slice("host:".length, scope.length) } if 0 < hosts.length # Try reloading database after error as a workaround for nested transaction. with_retry(error_handler: ->(error) { reload }) do if open_db @db.transaction do sqlite_limit_compound_select = [:sqlite_limit_compound_select] || SQLITE_LIMIT_COMPOUND_SELECT hosts.each_slice(sqlite_limit_compound_select - 1) do |hosts| execute_db(@db, "DELETE FROM hosts_tags WHERE tag_id IN ( SELECT id FROM tags WHERE name = '@status' ) AND host_id IN ( SELECT id FROM hosts WHERE name IN (%s) );" % hosts.map { "?" }.join(", "), hosts) execute_db(@db, "UPDATE hosts SET status = ? WHERE name IN (%s);" % hosts.map { "?" }.join(", "), [STATUS_STOPPING] + hosts) end associate_tag_hosts(@db, "@status:#{application.status_name(STATUS_STOPPING)}", hosts) end end end end scopes.each do |scope| with_retry() do @source_provider.schedule_downtime(scope, ) end end end |