fix log debug level detect
* reason there hardcodes DEBUG_LEVEL in logging.rb: DEBUG_LEVEL = defined?(Logger) ? Logger::DEBUG : 0 this could cause some incompatibility between different logger tools for Logger, DEBUG/0 < INFO/1 < WARN/2 < ERROR/3 < FATAL/4, for Log4r, ALL/0 < DETAIL/1 < DEBUG/2 < INFO/3 < WARN/4 < ERROR/5 < FATAL/6. anyway, it is not in good pattern. * suggestion logger.debug { ... } if current level is greater than DEBUG, the block will not be evaluated. it is also efficient. following is also supported by most loggers. logger.info { ... } logger.warn { ... } logger.error { ... } ...
This commit is contained in:
parent
52cbaa689f
commit
56968e8ad3
@ -1,48 +1,43 @@
|
|||||||
module Mongo
|
module Mongo
|
||||||
module Logging
|
module Logging
|
||||||
|
|
||||||
DEBUG_LEVEL = defined?(Logger) ? Logger::DEBUG : 0
|
|
||||||
|
|
||||||
def write_logging_startup_message
|
def write_logging_startup_message
|
||||||
if @logger && (@logger.level == DEBUG_LEVEL)
|
|
||||||
log(:debug, "Logging level is currently :debug which could negatively impact " +
|
log(:debug, "Logging level is currently :debug which could negatively impact " +
|
||||||
"client-side performance. You should set your logging level no lower than " +
|
"client-side performance. You should set your logging level no lower than " +
|
||||||
":info in production.")
|
":info in production.")
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
# Log a message with the given level.
|
# Log a message with the given level.
|
||||||
def log(level, msg)
|
def log(level, msg)
|
||||||
return unless @logger
|
return unless @logger
|
||||||
case level
|
case level
|
||||||
when :fatal then
|
when :fatal then
|
||||||
@logger.fatal "MONGODB [FATAL] #{msg}"
|
@logger.fatal { "MONGODB [FATAL] #{msg}" }
|
||||||
when :error then
|
when :error then
|
||||||
@logger.error "MONGODB [ERROR] #{msg}"
|
@logger.error { "MONGODB [ERROR] #{msg}" }
|
||||||
when :warn then
|
when :warn then
|
||||||
@logger.warn "MONGODB [WARNING] #{msg}"
|
@logger.warn { "MONGODB [WARNING] #{msg}" }
|
||||||
when :info then
|
when :info then
|
||||||
@logger.info "MONGODB [INFO] #{msg}"
|
@logger.info { "MONGODB [INFO] #{msg}" }
|
||||||
when :debug then
|
when :debug then
|
||||||
@logger.debug "MONGODB [DEBUG] #{msg}"
|
@logger.debug { "MONGODB [DEBUG] #{msg}" }
|
||||||
else
|
else
|
||||||
@logger.debug "MONGODB [DEBUG] #{msg}"
|
@logger.debug { "MONGODB [DEBUG] #{msg}" }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# 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 = {})
|
||||||
start_time = Time.now
|
start_time = Time.now
|
||||||
res = yield
|
res = yield
|
||||||
if @logger && (@logger.level == DEBUG_LEVEL)
|
|
||||||
log_operation(name, payload, start_time)
|
log_operation(name, payload, start_time)
|
||||||
end
|
|
||||||
res
|
res
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def log_operation(name, payload, start_time)
|
def log_operation(name, payload, start_time)
|
||||||
|
@logger && @logger.debug do
|
||||||
msg = "MONGODB "
|
msg = "MONGODB "
|
||||||
msg << "(#{((Time.now - start_time) * 1000).to_i}ms) "
|
msg << "(#{((Time.now - start_time) * 1000).to_i}ms) "
|
||||||
msg << "#{payload[:database]}['#{payload[:collection]}'].#{name}("
|
msg << "#{payload[:database]}['#{payload[:collection]}'].#{name}("
|
||||||
@ -50,8 +45,8 @@ 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]
|
||||||
|
msg
|
||||||
@logger.debug(msg)
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user