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
42
43
44
45
46
47
48
49
|
# File 'lib/reifier/server.rb', line 8
def start
Thread.abort_on_exception = true
Signal.trap 'SIGINT' do
puts "\nCleaning up nothing for now..."
exit
end
server = TCPServer.new(@options[:Host], @options[:Port])
threads = @options[:Threads] || 5
pool = Concurrent::FixedThreadPool.new(@options[:Threads] || 5)
puts "# Environment: #{@options[:environment]}"
puts "# Listening on tcp://#{@options[:Host]}:#{@options[:Port]}"
puts "# PID: #{Process.pid}"
puts "# Number of Threads used: #{threads}"
loop do
socket = server.accept
socket.setsockopt(Socket::IPPROTO_TCP, Socket::TCP_NODELAY, 1)
pool.post do
begin
request = Request.new(@options)
response = Response.new
request.handle(socket)
response.protocol = request.protocol
response << @app.call(request.rack_env)
response.handle(socket)
log_request request, response if development?
rescue Exception => e
log "\nError: #{e.class}\nMessage: #{e.message}\n\nBacktrace:\n\t#{e.backtrace.join("\n\t")}" if development?
socket.close
end
end
end
end
|