add log_duration system to add time spend in database
This commit is contained in:
parent
6ab02373ea
commit
84c8e7cae2
@ -87,6 +87,7 @@ module Mongo
|
|||||||
@db, @name = db, name
|
@db, @name = db, name
|
||||||
@connection = @db.connection
|
@connection = @db.connection
|
||||||
@logger = @connection.logger
|
@logger = @connection.logger
|
||||||
|
@log_duration = @connection.log_duration
|
||||||
@cache_time = @db.cache_time
|
@cache_time = @db.cache_time
|
||||||
@cache = Hash.new(0)
|
@cache = Hash.new(0)
|
||||||
unless pk_factory
|
unless pk_factory
|
||||||
@ -264,8 +265,8 @@ module Mongo
|
|||||||
# @return [OrderedHash, Nil]
|
# @return [OrderedHash, Nil]
|
||||||
# a single document or nil if no result is found.
|
# a single document or nil if no result is found.
|
||||||
#
|
#
|
||||||
# @param [Hash, ObjectId, Nil] spec_or_object_id a hash specifying elements
|
# @param [Hash, ObjectId, Nil] spec_or_object_id a hash specifying elements
|
||||||
# which must be present for a document to be included in the result set or an
|
# which must be present for a document to be included in the result set or an
|
||||||
# instance of ObjectId to be used as the value for an _id query.
|
# instance of ObjectId to be used as the value for an _id query.
|
||||||
# If nil, an empty selector, {}, will be used.
|
# If nil, an empty selector, {}, will be used.
|
||||||
#
|
#
|
||||||
@ -413,7 +414,7 @@ module Mongo
|
|||||||
# @option opts [Boolean] :upsert (+false+) if true, performs an upsert (update or insert)
|
# @option opts [Boolean] :upsert (+false+) if true, performs an upsert (update or insert)
|
||||||
# @option opts [Boolean] :multi (+false+) update all documents matching the selector, as opposed to
|
# @option opts [Boolean] :multi (+false+) update all documents matching the selector, as opposed to
|
||||||
# just the first matching document. Note: only works in MongoDB 1.1.3 or later.
|
# just the first matching document. Note: only works in MongoDB 1.1.3 or later.
|
||||||
# @option opts [Boolean] :safe (+false+)
|
# @option opts [Boolean] :safe (+false+)
|
||||||
# If true, check that the save succeeded. OperationFailure
|
# If true, check that the save succeeded. OperationFailure
|
||||||
# will be raised on an error. Note that a safe check requires an extra
|
# will be raised on an error. Note that a safe check requires an extra
|
||||||
# round-trip to the database. Safe options provided here will override any safe
|
# round-trip to the database. Safe options provided here will override any safe
|
||||||
@ -906,12 +907,12 @@ module Mongo
|
|||||||
if [Mongo::ASCENDING, Mongo::DESCENDING, Mongo::GEO2D, Mongo::GEOHAYSTACK].include?(f[1])
|
if [Mongo::ASCENDING, Mongo::DESCENDING, Mongo::GEO2D, Mongo::GEOHAYSTACK].include?(f[1])
|
||||||
field_spec[f[0].to_s] = f[1]
|
field_spec[f[0].to_s] = f[1]
|
||||||
else
|
else
|
||||||
raise MongoArgumentError, "Invalid index field #{f[1].inspect}; " +
|
raise MongoArgumentError, "Invalid index field #{f[1].inspect}; " +
|
||||||
"should be one of Mongo::ASCENDING (1), Mongo::DESCENDING (-1) or Mongo::GEO2D ('2d')."
|
"should be one of Mongo::ASCENDING (1), Mongo::DESCENDING (-1) or Mongo::GEO2D ('2d')."
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
raise MongoArgumentError, "Invalid index specification #{spec.inspect}; " +
|
raise MongoArgumentError, "Invalid index specification #{spec.inspect}; " +
|
||||||
"should be either a string, symbol, or an array of arrays."
|
"should be either a string, symbol, or an array of arrays."
|
||||||
end
|
end
|
||||||
field_spec
|
field_spec
|
||||||
|
@ -43,6 +43,7 @@ module Mongo
|
|||||||
@collection = collection
|
@collection = collection
|
||||||
@connection = @db.connection
|
@connection = @db.connection
|
||||||
@logger = @connection.logger
|
@logger = @connection.logger
|
||||||
|
@log_duration = @connection.log_duration
|
||||||
|
|
||||||
# Query selector
|
# Query selector
|
||||||
@selector = opts[:selector] || {}
|
@selector = opts[:selector] || {}
|
||||||
@ -199,7 +200,7 @@ module Mongo
|
|||||||
# This method overrides any sort order specified in the Collection#find
|
# This method overrides any sort order specified in the Collection#find
|
||||||
# method, and only the last sort applied has an effect.
|
# method, and only the last sort applied has an effect.
|
||||||
#
|
#
|
||||||
# @param [Symbol, Array] key_or_list either 1) a key to sort by or 2)
|
# @param [Symbol, Array] key_or_list either 1) a key to sort by or 2)
|
||||||
# an array of [key, direction] pairs to sort by. Direction should
|
# an array of [key, direction] pairs to sort by. Direction should
|
||||||
# be specified as Mongo::ASCENDING (or :ascending / :asc) or Mongo::DESCENDING (or :descending / :desc)
|
# be specified as Mongo::ASCENDING (or :ascending / :asc) or Mongo::DESCENDING (or :descending / :desc)
|
||||||
#
|
#
|
||||||
|
@ -25,14 +25,15 @@ module Mongo
|
|||||||
|
|
||||||
# Execute the block and log the operation described by name and payload.
|
# Execute the block and log the operation described by name and payload.
|
||||||
def instrument(name, payload = {}, &blk)
|
def instrument(name, payload = {}, &blk)
|
||||||
|
time_elapse = @log_duration ? Time.now : nil
|
||||||
res = yield
|
res = yield
|
||||||
log_operation(name, payload)
|
log_operation(name, payload, time_elapse)
|
||||||
res
|
res
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def log_operation(name, payload)
|
def log_operation(name, payload, time_elapse=nil)
|
||||||
@logger ||= nil
|
@logger ||= nil
|
||||||
return unless @logger
|
return unless @logger
|
||||||
msg = "#{payload[:database]}['#{payload[:collection]}'].#{name}("
|
msg = "#{payload[:database]}['#{payload[:collection]}'].#{name}("
|
||||||
@ -40,7 +41,11 @@ module Mongo
|
|||||||
msg += ".skip(#{payload[:skip]})" if payload[:skip]
|
msg += ".skip(#{payload[:skip]})" if payload[:skip]
|
||||||
msg += ".limit(#{payload[:limit]})" if payload[:limit]
|
msg += ".limit(#{payload[:limit]})" if payload[:limit]
|
||||||
msg += ".sort(#{payload[:order]})" if payload[:order]
|
msg += ".sort(#{payload[:order]})" if payload[:order]
|
||||||
@logger.debug "MONGODB #{msg}"
|
if time_elapse
|
||||||
|
@logger.debug "MONGODB (#{Time.now - time_elapse}s) #{msg}"
|
||||||
|
else
|
||||||
|
@logger.debug "MONGODB #{msg}"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -137,6 +137,15 @@ class TestConnection < Test::Unit::TestCase
|
|||||||
assert output.string.include?("admin['$cmd'].find")
|
assert output.string.include?("admin['$cmd'].find")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_logging_duration
|
||||||
|
output = StringIO.new
|
||||||
|
logger = Logger.new(output)
|
||||||
|
logger.level = Logger::DEBUG
|
||||||
|
connection = standard_connection(:logger => logger, :log_duration => true).db(MONGO_TEST_DB)
|
||||||
|
assert output.string.index(/\(0.\d+s\)/)
|
||||||
|
assert output.string.include?("admin['$cmd'].find")
|
||||||
|
end
|
||||||
|
|
||||||
def test_connection_logger
|
def test_connection_logger
|
||||||
output = StringIO.new
|
output = StringIO.new
|
||||||
logger = Logger.new(output)
|
logger = Logger.new(output)
|
||||||
|
Loading…
Reference in New Issue
Block a user