Sha256: 41668b66cd84ae055a77a10cdbddfd29d37d055c6c1c40425617f0cc32f13a05

Contents?: true

Size: 1.6 KB

Versions: 37

Compression:

Stored size: 1.6 KB

Contents

require 'ostruct'
require 'thread'

module Protobuf
  module Rpc
    class ZmqRunner
      include ::Protobuf::Logging

      def initialize(options)
        @options = case
                   when options.is_a?(OpenStruct) then
                     options.marshal_dump
                   when options.respond_to?(:to_hash) then
                     options.to_hash.symbolize_keys
                   else
                     fail "Cannot parser Zmq Server - server options"
                   end
      end

      def run
        @server = ::Protobuf::Rpc::Zmq::Server.new(@options)
        register_signals
        @server.run do
          yield if block_given?
        end
      end

      def running?
        @server.try :running?
      end

      def stop
        @server.try :stop
      end

      private

      def register_signals
        trap(:TRAP) do
          ::Thread.list.each do |thread|
            logger.info do
              <<-THREAD_TRACE
                #{thread.inspect}:
                  #{thread.backtrace.try(:join, $INPUT_RECORD_SEPARATOR)}"
              THREAD_TRACE
            end
          end
        end

        trap(:TTIN) do
          @server.add_worker
          logger.info { "Increased worker size to: #{@server.total_workers}" }
        end

        trap(:TTOU) do
          logger.info { "Current worker size: #{@server.workers.size}" }
          logger.info { "Current busy worker size: #{@server.busy_worker_count}" }
        end
      end
    end
  end
end

module Protobuf
  module Rpc
    module Servers # bad file namespacing
      ZmqRunner = ::Protobuf::Rpc::ZmqRunner
    end
  end
end

Version data entries

37 entries across 37 versions & 3 rubygems

Version Path
protobuf-3.10.9 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.8 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.7 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.6 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.5 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.4 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-cucumber-3.10.8 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-cucumber-3.10.7 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-cucumber-3.10.6 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-cucumber-3.10.5 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-cucumber-3.10.4 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.3 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.2 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.1 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.0 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.10.0.pre0 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.9.0 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.9.0.pre2 lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.9.0.pre lib/protobuf/rpc/servers/zmq_runner.rb
protobuf-3.8.5 lib/protobuf/rpc/servers/zmq_runner.rb