diff options
author | Eric Wong <normalperson@yhbt.net> | 2011-05-19 23:54:59 -0700 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2011-05-20 08:32:39 +0000 |
commit | 90af18f6884857704d72fd6b2bb91718aad72117 (patch) | |
tree | 3aad09eaac6d20d8f158d1fd7b1caad53f27ce2f /lib/rainbows/epoll | |
parent | 5e4f790847198e1267b2fbd5decfa09e5cc3d618 (diff) | |
download | rainbows-90af18f6884857704d72fd6b2bb91718aad72117.tar.gz |
There's less logic in the server this way and easier to potentially share code this way.
Diffstat (limited to 'lib/rainbows/epoll')
-rw-r--r-- | lib/rainbows/epoll/client.rb | 18 | ||||
-rw-r--r-- | lib/rainbows/epoll/response_pipe.rb | 2 | ||||
-rw-r--r-- | lib/rainbows/epoll/server.rb | 12 |
3 files changed, 24 insertions, 8 deletions
diff --git a/lib/rainbows/epoll/client.rb b/lib/rainbows/epoll/client.rb index 0d6a8c0..e23d4e7 100644 --- a/lib/rainbows/epoll/client.rb +++ b/lib/rainbows/epoll/client.rb @@ -11,7 +11,8 @@ module Rainbows::Epoll::Client KATO = {} KATO.compare_by_identity if KATO.respond_to?(:compare_by_identity) Rainbows.config!(self, :keepalive_timeout) - EP = Rainbows::Epoll::EP + EP = Rainbows::EP + ReRun = [] @@last_expire = Time.now def self.expire @@ -23,6 +24,19 @@ module Rainbows::Epoll::Client @@last_expire = now end + def self.loop + begin + EP.wait(nil, 1000) { |_, obj| obj.epoll_run } + while obj = ReRun.shift + obj.epoll_run + end + expire + rescue Errno::EINTR + rescue => e + Rainbows::Error.listen_loop(e) + end while Rainbows.tick || Server.nr > 0 + end + # only call this once def epoll_once @wr_queue = [] # may contain String, ResponsePipe, and StreamFile objects @@ -100,7 +114,7 @@ module Rainbows::Epoll::Client end def want_more - Rainbows::Epoll::ReRun << self + ReRun << self end def on_deferred_write_complete diff --git a/lib/rainbows/epoll/response_pipe.rb b/lib/rainbows/epoll/response_pipe.rb index 56d9a47..64b1547 100644 --- a/lib/rainbows/epoll/response_pipe.rb +++ b/lib/rainbows/epoll/response_pipe.rb @@ -5,7 +5,7 @@ class Rainbows::Epoll::ResponsePipe attr_reader :io alias to_io io RBUF = Rainbows::EvCore::RBUF - EP = Rainbows::Epoll::EP + EP = Rainbows::EP def initialize(io, client, body) @io, @client, @body = io, client, body diff --git a/lib/rainbows/epoll/server.rb b/lib/rainbows/epoll/server.rb index 58e7653..ab5a49f 100644 --- a/lib/rainbows/epoll/server.rb +++ b/lib/rainbows/epoll/server.rb @@ -2,16 +2,14 @@ # :enddoc: module Rainbows::Epoll::Server @@nr = 0 - Rainbows::Epoll.nr_clients = lambda { @@nr } IN = SleepyPenguin::Epoll::IN | SleepyPenguin::Epoll::ET MAX = Rainbows.server.worker_connections THRESH = MAX - 1 LISTENERS = Rainbows::HttpServer::LISTENERS - EP = Rainbows::Epoll::EP + EP = Rainbows::EP - def self.run - LISTENERS.each { |sock| EP.add(sock.extend(self), IN) } - Rainbows::Epoll.loop + def self.nr + @@nr end # rearms all listeners when there's a free slot @@ -19,6 +17,10 @@ module Rainbows::Epoll::Server THRESH == (@@nr -= 1) and LISTENERS.each { |sock| EP.set(sock, IN) } end + def self.extended(sock) + EP.set(sock, IN) + end + def epoll_run return EP.delete(self) if @@nr >= MAX while io = kgio_tryaccept |