minor: cleanup and organization of Connection classes

This commit is contained in:
Kyle Banker 2010-12-15 12:36:43 -05:00
parent b8bb480c2c
commit 9ea8fe98b7
2 changed files with 67 additions and 27 deletions

View File

@ -35,8 +35,7 @@ module Mongo
STANDARD_HEADER_SIZE = 16
RESPONSE_HEADER_SIZE = 20
attr_reader :logger, :size, :nodes, :auths, :primary, :secondaries, :arbiters,
:safe, :primary_pool, :read_pool, :secondary_pools, :host_to_try
attr_reader :logger, :size, :auths, :primary, :safe, :primary_pool, :host_to_try
# Counter for generating unique request ids.
@@current_request_id = 0
@ -316,17 +315,6 @@ module Mongo
self["admin"].command(oh)
end
# Increment and return the next available request id.
#
# return [Integer]
def get_request_id
request_id = ''
@id_lock.synchronize do
request_id = @@current_request_id += 1
end
request_id
end
# Get the build information for the current connection.
#
# @return [Hash]
@ -346,7 +334,7 @@ module Mongo
#
# @return [Boolean]
def slave_ok?
@read_secondary || @slave_ok
@slave_ok
end
# Send a message to MongoDB, adding the necessary headers.
@ -446,7 +434,9 @@ module Mongo
set_primary(@host_to_try)
end
raise ConnectionFailure, "failed to connect to any given host:port" unless connected?
if !connected?
raise ConnectionFailure, "Failed to connect to a master node at #{@host_to_try[0]}:#{@host_to_try[1]}"
end
end
def connecting?
@ -467,33 +457,29 @@ module Mongo
end
# Checkout a socket for reading (i.e., a secondary node).
# Note: this is overridden in ReplSetConnection.
def checkout_reader
connect unless connected?
if @read_pool
@read_pool.checkout
else
checkout_writer
end
@primary_pool.checkout
end
# Checkout a socket for writing (i.e., a primary node).
# Note: this is overridden in ReplSetConnection.
def checkout_writer
connect unless connected?
@primary_pool.checkout
end
# Checkin a socket used for reading.
# Note: this is overridden in ReplSetConnection.
def checkin_reader(socket)
if @read_pool
@read_pool.checkin(socket)
else
checkin_writer(socket)
if @primary_pool
@primary_pool.checkin(socket)
end
end
# Checkin a socket used for writing.
# Note: this is overridden in ReplSetConnection.
def checkin_writer(socket)
if @primary_pool
@primary_pool.checkin(socket)
@ -616,6 +602,9 @@ module Mongo
apply_saved_authentication
end
## Low-level connection methods.
def receive(sock, expected_response)
begin
receive_header(sock, expected_response)
@ -727,6 +716,17 @@ module Mongo
request_id
end
# Increment and return the next available request id.
#
# return [Integer]
def get_request_id
request_id = ''
@id_lock.synchronize do
request_id = @@current_request_id += 1
end
request_id
end
# Low-level method for sending a message on a socket.
# Requires a packed message and an available socket,
#

View File

@ -111,6 +111,13 @@ module Mongo
@nodes_to_try = []
end
# Is it okay to connect to a slave?
#
# @return [Boolean]
def slave_ok?
@read_secondary || @slave_ok
end
private
def check_is_master(node)
@ -212,5 +219,38 @@ module Mongo
@nodes_to_try = new_nodes - @nodes_tried
end
# Checkout a socket for reading (i.e., a secondary node).
def checkout_reader
connect unless connected?
if @read_pool
@read_pool.checkout
else
checkout_writer
end
end
# Checkout a socket for writing (i.e., a primary node).
def checkout_writer
connect unless connected?
@primary_pool.checkout
end
# Checkin a socket used for reading.
def checkin_reader(socket)
if @read_pool
@read_pool.checkin(socket)
else
checkin_writer(socket)
end
end
# Checkin a socket used for writing.
def checkin_writer(socket)
if @primary_pool
@primary_pool.checkin(socket)
end
end
end
end