Sha256: 2c1a48af91a2c8a479417cecaf10b1640593915e30ed7fbf0415328d55842d96

Contents?: true

Size: 1.55 KB

Versions: 13

Compression:

Stored size: 1.55 KB

Contents

# The server tracker uses the database to keep a list of all active servers (or
# console, runners, etc...).  When an server instance starts, it registers with
# the database, then reads the list of all other active servers.

require 'socket'

module Volt
  module MessageBus
    class ServerTracker
      UPDATE_INTERVAL = 10
      def initialize(volt_app, server_id, port)
        @volt_app = volt_app
        @server_id = server_id
        @port = port

        @main_thread = Thread.new do
          # Continually update the database letting the server know the server
          # is active.
          loop do
            begin
              register
            rescue Exception => e
              puts "MessageBus Register Error: #{e.inspect}"
            end
            sleep UPDATE_INTERVAL
          end
        end
      end

      def stop
        @main_thread.kill
      end

      # Register this server as active with the database
      def register
        instances = @volt_app.store.active_volt_instances
        instances.where(server_id: @server_id).first.then do |item|
          ips = local_ips.join(',')
          time = Time.now.to_i
          if item
            item.assign_attributes(ips: ips, time: time, port: @port)
          else
            instances << {server_id: @server_id, ips: ips, port: @port, time: time}
          end
        end
      end

      def local_ips
        addr_infos = Socket.ip_address_list

        ips = addr_infos.select do |addr|
          addr.pfamily == Socket::PF_INET
        end.map(&:ip_address)
      end
    end
  end
end

Version data entries

13 entries across 13 versions & 1 rubygems

Version Path
volt-0.9.6 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.6.pre3 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.6.pre2 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.6.pre1 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre12 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre11 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre9 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre8 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre7 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre6 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre5 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb
volt-0.9.5.pre4 lib/volt/server/message_bus/peer_to_peer/server_tracker.rb