minor: cleanup
This commit is contained in:
parent
a2a307c45d
commit
f224df45aa
@ -308,30 +308,33 @@ module Mongo
|
||||
def get_local_reader
|
||||
self.connections ||= {}
|
||||
self.connections[self.object_id] ||= {}
|
||||
self.connections[self.object_id][:reader] ||= checkout_reader
|
||||
socket = self.connections[self.object_id][:reader] ||= checkout_reader
|
||||
threads_to_sockets[Thread.current] ||= {}
|
||||
threads_to_sockets[Thread.current][:reader] = socket
|
||||
end
|
||||
|
||||
def get_local_writer
|
||||
self.connections ||= {}
|
||||
self.connections[self.object_id] ||= {}
|
||||
self.connections[self.object_id][:writer] ||= checkout_writer
|
||||
threads_to_sockets[Thread.current] ||= {}
|
||||
threads_to_sockets[Thread.current][:reader] = socket
|
||||
end
|
||||
|
||||
# Used to close, check in, or refresh sockets held
|
||||
# in thread-local variables.
|
||||
def local_socket_done(socket)
|
||||
puts "Done. Threads: #{Thread.list.size}, pool_size: #{self.pool_size}"
|
||||
if self.connections[self.object_id][:reader] == socket
|
||||
if self.read_pool.sockets_low?
|
||||
puts "***SOCKETS ARE LOW! READER****"
|
||||
if self.read_pool.sockets_low? ||
|
||||
self.read_pool != @sockets_to_pools[socket]
|
||||
checkin(socket)
|
||||
self.connections[self.object_id][:reader] = nil
|
||||
end
|
||||
end
|
||||
|
||||
if self.connections[self.object_id][:writer] == socket
|
||||
if self.primary_pool && self.primary_pool.sockets_low?
|
||||
puts "***SOCKETS ARE LOW! WRITER****"
|
||||
if self.primary_pool && (self.primary_pool.sockets_low? ||
|
||||
self.primary_pool != @sockets_to_pools[socket])
|
||||
checkin(socket)
|
||||
self.connections[self.object_id][:writer] = nil
|
||||
end
|
||||
@ -384,6 +387,8 @@ module Mongo
|
||||
close_socket(socket)
|
||||
end
|
||||
|
||||
@sockets_to_pools.delete(socket)
|
||||
|
||||
# Refresh synchronously every @refresh_interval seconds
|
||||
# if synchronous refresh mode is enabled.
|
||||
if @refresh_mode == :sync &&
|
||||
|
@ -235,31 +235,6 @@ module Mongo
|
||||
end
|
||||
end
|
||||
|
||||
def cleanup
|
||||
return unless @sockets.size > @size
|
||||
puts "-----CLEANUP*****"
|
||||
alive = {}
|
||||
Thread.list.each do |t|
|
||||
if t.alive?
|
||||
alive[t.object_id] = true
|
||||
end
|
||||
end
|
||||
|
||||
@checked_out.each do |socket|
|
||||
if !alive[@threads[socket]]
|
||||
@checked_out.delete(socket)
|
||||
if @sockets.size > @size
|
||||
puts "CLEANING: #{socket}"
|
||||
socket.close
|
||||
@sockets.delete(socket)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
end
|
||||
|
||||
# Check out an existing socket or create a new socket if the maximum
|
||||
# pool size has not been exceeded. Otherwise, wait for the next
|
||||
# available socket.
|
||||
|
Loading…
Reference in New Issue
Block a user