Class: DCell::Server

Inherits:
Object
  • Object
show all
Includes:
Celluloid::ZMQ
Defined in:
lib/dcell/server.rb

Overview

Servers handle incoming 0MQ traffic

Defined Under Namespace

Classes: InvalidMessageError

Instance Method Summary collapse

Constructor Details

#initializeServer

Bind to the given 0MQ address (in URL form ala tcp://host:port)



7
8
9
10
11
12
13
14
15
16
17
18
19
# File 'lib/dcell/server.rb', line 7

def initialize
  @addr   = DCell.addr
  @socket = PullSocket.new

  begin
    @socket.bind(@addr)
  rescue IOError
    @socket.close
    raise
  end

  run!
end

Instance Method Details

#decode_message(message) ⇒ Object

Decode incoming messages



50
51
52
53
54
55
56
57
58
59
# File 'lib/dcell/server.rb', line 50

def decode_message(message)
  if message[0..1].unpack("CC") == [Marshal::MAJOR_VERSION, Marshal::MINOR_VERSION]
    begin
      Marshal.load message
    rescue => ex
      raise InvalidMessageError, "invalid message: #{ex}"
    end
  else raise InvalidMessageError, "couldn't determine message format: #{message}"
  end
end

#finalizeObject

Shut down the server



27
28
29
# File 'lib/dcell/server.rb', line 27

def finalize
  @socket.close if @socket
end

#handle_message(message) ⇒ Object

Handle incoming messages



32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/dcell/server.rb', line 32

def handle_message(message)
  begin
    message = decode_message message
  rescue InvalidMessageError => ex
    Celluloid::Logger.warn("couldn't decode message: #{ex.class}: #{ex}")
    return
  end

  begin
    message.dispatch
  rescue Exception => ex
    Celluloid::Logger.crash("DCell::Server: message dispatch failed", ex)
  end
end

#runObject

Wait for incoming 0MQ messages



22
23
24
# File 'lib/dcell/server.rb', line 22

def run
  while true; handle_message @socket.read; end
end

#terminateObject

Terminate this server



62
63
64
65
# File 'lib/dcell/server.rb', line 62

def terminate
  @socket.close
  super
end