diff options
author | zedshaw <zedshaw@19e92222-5c0b-0410-8929-a290d50e31e9> | 2006-11-25 19:03:45 +0000 |
---|---|---|
committer | zedshaw <zedshaw@19e92222-5c0b-0410-8929-a290d50e31e9> | 2006-11-25 19:03:45 +0000 |
commit | 306fb3d83248559e3c49635518c9901ebd8da320 (patch) | |
tree | 3de443a5c45de298d0e16d44c93622fe471fae0d /lib/mongrel.rb | |
parent | edd6dae41bf73b49b2a2bf6e8e2aebf2d01dd46e (diff) | |
download | unicorn-306fb3d83248559e3c49635518c9901ebd8da320.tar.gz |
git-svn-id: svn+ssh://rubyforge.org/var/svn/mongrel/trunk@432 19e92222-5c0b-0410-8929-a290d50e31e9
Diffstat (limited to 'lib/mongrel.rb')
-rw-r--r-- | lib/mongrel.rb | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/lib/mongrel.rb b/lib/mongrel.rb index d2d66f1..7a2d0f3 100644 --- a/lib/mongrel.rb +++ b/lib/mongrel.rb @@ -661,10 +661,17 @@ module Mongrel end def configure_socket_options - if /linux/ === RUBY_PLATFORM + case RUBY_PLATFORM + when /linux/ # 9 is currently TCP_DEFER_ACCEPT - $tcp_defer_accept_opts = [9,1] - $tcp_cork_opts = [3,1] + $tcp_defer_accept_opts = [Socket::SOL_TCP, 9, 1] + $tcp_cork_opts = [Socket::SOL_TCP, 3, 1] + when /freebsd/ + # Use the HTTP accept filter if available. + # The struct made by pack() is defined in /usr/include/sys/socket.h as accept_filter_arg + unless `/sbin/sysctl -nq net.inet.accf.http`.empty? + $tcp_defer_accept_opts = [Socket::SOL_SOCKET, Socket::SO_ACCEPTFILTER, ['httpready', nil].pack('a16a240')] + end end end @@ -675,13 +682,13 @@ module Mongrel configure_socket_options - @socket.setsockopt(Socket::SOL_TCP, $tcp_defer_accept_opts[0], $tcp_defer_accept_opts[1]) if $tcp_defer_accept_opts + @socket.setsockopt(*$tcp_defer_accept_opts) if $tcp_defer_accept_opts @acceptor = Thread.new do while true begin client = @socket.accept - client.setsockopt(Socket::SOL_TCP, $tcp_cork_opts[0], $tcp_cork_opts[1]) if $tcp_cork_opts + client.setsockopt(*$tcp_cork_opts) if $tcp_cork_opts worker_list = @workers.list |