在rails中我想在一个不同的日志文件中记录一些信息,而不是标准的development.log或production.log.我想从模型类中进行日志记录.
我们希望有一组控制器,我们将记录器输出从所有操作和下游方法路由到单独的日志文件.这是一个Rails 3项目.在Rails 2中,我们通过重新定义"logger"方法来实现这一点,但在Rails 3中,记录的方式是使用"Rails.logger".我尝试过
Rails::logger = Logger.new(File.join(Rails.root, 'log', "reports_controller.log"), 10, 1000000)
Run Code Online (Sandbox Code Playgroud)
在控制器的顶部,但只有在操作中专门使用Rails.logger的特定情况才会发送到指定的日志文件,控制器的所有默认日志输出仍然路由到主日志文件.
我们如何将特定控制器的所有日志输出路由到特定日志文件以包含所有默认控制器输出?
默认情况下,控制器输出,我指的是从入站请求的最开始处开始的所有消息
Started POST "/api/v1/reports.json" for 10.XXX.XX.XX at 2015-03-07 01:30:22 +0000
Processing by Api::V1::ReportsController#create as JSON
Parameters: {"report"=>{"cloud_file_path"=>"report.zip", "company_id"=>nil, "created_at"=>"2015-03-07T01:30:17Z", "type_id"=>"2", "updated_at"=>"2015-03-07T01:30:17Z", "master"=>"1"}}
Run Code Online (Sandbox Code Playgroud)
以及控制器中的入站请求和出站响应可能跟随的所有日志输出.
基本上我希望报告控制器的所有日志记录都在reports_controller.log中,我不希望报告控制器的任何消息显示在主日志中(即生产中的production.log)
更新:
感谢@ mudasobwa对他的回答和聊天的帮助,我能够使用中间件解决这个问题,因为他的答案描述了(尽管我必须将我的insert_before更改为Rails :: Rack :: Logger之前)
他为我解决了这个问题的修改后的答案就在下面而且它还存在 config/initializers/logger_middleware.rb
module MyApp
class LoggerMiddleware
REPORTS_API_CONTROLLER_PATH = %r|\A/api/v.*/reports/.*|
REPORTS_API_CONTROLLER_LOGFILE = "reports_controller.log"
def initialize(app)
@app, @logger = app, Rails::logger.instance_variable_get(:@logger).instance_variable_get(:@log)
@reports_api_controller_logger = Logger.new(Rails.root.join('log', REPORTS_API_CONTROLLER_LOGFILE), 10, 1000000)
end
def call(env)
Rails::logger
.instance_variable_get(:@logger)
.instance_variable_set(:@log,
case env['PATH_INFO']
when REPORTS_API_CONTROLLER_PATH then …Run Code Online (Sandbox Code Playgroud)