Class: Gt06Server::SessionSweeper
- Inherits:
-
Object
- Object
- Gt06Server::SessionSweeper
- Defined in:
- lib/gt06_server/session_sweeper.rb
Defined Under Namespace
Classes: SessionSweeperObserver
Constant Summary collapse
- DEFAULT_TIMEOUT =
60- DEFAULT_INTERVAL =
30
Instance Attribute Summary collapse
-
#info ⇒ Object
readonly
Returns the value of attribute info.
-
#interval ⇒ Object
readonly
Returns the value of attribute interval.
-
#logger ⇒ Object
readonly
Returns the value of attribute logger.
-
#sessions ⇒ Object
readonly
Returns the value of attribute sessions.
-
#timeout ⇒ Object
readonly
Returns the value of attribute timeout.
Instance Method Summary collapse
-
#initialize(sessions, timeout: DEFAULT_TIMEOUT, interval: DEFAULT_INTERVAL, logger: Logger.new(STDOUT)) ⇒ SessionSweeper
constructor
A new instance of SessionSweeper.
- #run ⇒ Object
Constructor Details
#initialize(sessions, timeout: DEFAULT_TIMEOUT, interval: DEFAULT_INTERVAL, logger: Logger.new(STDOUT)) ⇒ SessionSweeper
Returns a new instance of SessionSweeper.
13 14 15 16 17 18 19 |
# File 'lib/gt06_server/session_sweeper.rb', line 13 def initialize(sessions, timeout: DEFAULT_TIMEOUT, interval: DEFAULT_INTERVAL, logger: Logger.new(STDOUT)) @sessions = sessions @timeout = timeout @interval = interval @info = { killed: 0, live: 0, count: 0 } @logger = logger end |
Instance Attribute Details
#info ⇒ Object (readonly)
Returns the value of attribute info.
7 8 9 |
# File 'lib/gt06_server/session_sweeper.rb', line 7 def info @info end |
#interval ⇒ Object (readonly)
Returns the value of attribute interval.
7 8 9 |
# File 'lib/gt06_server/session_sweeper.rb', line 7 def interval @interval end |
#logger ⇒ Object (readonly)
Returns the value of attribute logger.
7 8 9 |
# File 'lib/gt06_server/session_sweeper.rb', line 7 def logger @logger end |
#sessions ⇒ Object (readonly)
Returns the value of attribute sessions.
7 8 9 |
# File 'lib/gt06_server/session_sweeper.rb', line 7 def sessions @sessions end |
#timeout ⇒ Object (readonly)
Returns the value of attribute timeout.
7 8 9 |
# File 'lib/gt06_server/session_sweeper.rb', line 7 def timeout @timeout end |
Instance Method Details
#run ⇒ Object
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 |
# File 'lib/gt06_server/session_sweeper.rb', line 21 def run timer = Concurrent::TimerTask.new(execution_interval: @interval) do @sessions.each_pair do |key, session| next unless expired_session?(session) unless session.socket.closed? session.socket.setsockopt(Socket::SOL_SOCKET, Socket::SO_LINGER, [1, 0].pack('ii')) session.socket.close end @info[:killed] += 1 @sessions.delete(key) @logger.debug "Session #{session.inspect} has been killed" end @info[:live] = @sessions.size @info[:count] += 1 @info end timer.add_observer(SessionSweeperObserver.new(@logger)) timer.execute end |