Sha256: 7e12c4899e308d7513c8a0dae88406eb26ec3d687af0990ac0746517ff5210bf

Contents?: true

Size: 1.04 KB

Versions: 30

Compression:

Stored size: 1.04 KB

Contents

#!/usr/bin/env ruby
# encoding: utf-8

require "bundler"
Bundler.setup

$:.unshift(File.expand_path("../../../lib", __FILE__))

require 'amqp'


puts "=> Connection loss is detected and handled"
puts
AMQP.start(:port     => 5672,
           :vhost    => "amq_client_testbed",
           :user     => "amq_client_gem",
           :password => "amq_client_gem_password",
           :timeout    => 0.3,
           :heartbeat  => 1.0,
           :on_tcp_connection_failure => Proc.new { |settings| puts "Failed to connect, this was NOT expected"; EM.stop }) do |connection, open_ok|
    connection.on_tcp_connection_loss do |cl, settings|
      puts "tcp_connection_loss handler kicks in"
      cl.reconnect(false, 1)
    end


  show_stopper = Proc.new do
    $stdout.puts "Stopping..."
    connection.close { EventMachine.stop }
  end

  puts "Connected, authenticated. To really exercise this example, shut RabbitMQ down for a few seconds. If you don't it will exit gracefully in 30 seconds."

  Signal.trap "INT",  show_stopper
  EM.add_timer(60, show_stopper)
end

Version data entries

30 entries across 30 versions & 1 rubygems

Version Path
amqp-1.1.2 examples/error_handling/connection_loss_handler.rb
amqp-1.1.1 examples/error_handling/connection_loss_handler.rb
amqp-1.1.0 examples/error_handling/connection_loss_handler.rb
amqp-1.0.3 examples/error_handling/connection_loss_handler.rb
amqp-1.1.0.rc1 examples/error_handling/connection_loss_handler.rb
amqp-1.1.0.pre2 examples/error_handling/connection_loss_handler.rb
amqp-1.1.0.pre1 examples/error_handling/connection_loss_handler.rb
amqp-1.0.2 examples/error_handling/connection_loss_handler.rb
amqp-1.0.1 examples/error_handling/connection_loss_handler.rb
amqp-1.0.0 examples/error_handling/connection_loss_handler.rb