我一定真的遗漏了一些明显的东西,但我在我的Ruby应用程序中对Log4r的一般使用遇到了麻烦。我可以毫无问题地登录,但是按照我的设置方式,开销似乎很笨重。我基本上是将完整路径传递给文件名以登录我的应用程序中的每个类。被调用的ruby脚本从ARGV中的一个参数中提取日志文件,然后将其传递并设置在我在ruby中调用的每个类中。在每个类中,我都使用patternFormatter将类/文件名插入到日志语句中。有没有更好的方法来完成这项工作?感觉无论我想到什么,都需要将一些东西传递给我的ruby应用程序中的每个类。我可以改为在yaml配置文件中设置日志文件,但这样我也会将配置文件传
为了帮助跟踪用户操作以进行调试,我们正在考虑将session的登录用户ID添加到每条日志消息之前(如果适用)。我们的堆栈由Rails和Authlogic组成。我尝试了几种不同的路线,但到目前为止还没有100%成功。由于Authlogic不会在session数据中以明文形式存储用户ID,所以我们必须等待它被初始化。只有在ApplicationController初始化并设置为事件的AuthlogicController之后才会发生这种情况。因此,我们不能依赖config/application.rb中的代码。在我看来,唯一的解决方案是稍后更换记录器。我尝试通过子类化Logger并覆盖ad
上下文:在一个Rails3项目中,我想自定义(大量)来自ActionController的“Processing”和“Completedin”日志行的格式和内容。这是为了让它们与旧版Rails2.3应用程序的(也是自定义的)格式相匹配,从而允许重复使用各种分析工具。使它们成为固定字段(通过在必要时使用占位符)还可以更容易地使用(比如)awk对它们进行临时查询,或者将它们加载到数据库或splunk中而无需智能解析。我通过forkrails和patching快速而严厉地实现了这个目标有问题的LogSubscriber,但我现在希望以正确的方式做到这一点。这是我认为我想做的事情:创建一个Lo
对于Rails3.1(很快将是3.2),我有非常详细的日志,其中包含大量额外的工作人员信息。我通常会得到数GB的development.log文件。我看到过一些关于轮换生产日志的讨论,但是我没有发现任何似乎适用于development.log轮换的内容。您如何在每100.megabytes左右轮换您的development.log?或者我更喜欢实际截断文件头,以便只有最近的项目保留在日志中,最近的条目最多100MB。我已经玩了一点,并且越来越多地认为目前不存在这样的东西,也许我应该实现一些将以某种方式使用rubyFile.truncate的东西,但是我到目前为止,我还不确定它在文件
我想更改应用程序(ruby)的日志记录级别。require'logger'config={:level=>'Logger::WARN'}log=Logger.newSTDOUTlog.level=Kernel.const_getconfig[:level]好吧,irb对此并不满意,并向我抛出“NameError:错误的常量名称Logger::WARN”。啊!我被侮辱了。我可以在某些情况下/何时解决这个问题,或者做log.level=1,但必须有更优雅的方法!有没有人有什么想法?-丹尼尔 最佳答案 为什么不直接在config哈希中使用
ruby记录器的默认样式是:SeverityID,[DateTimemSec#pid]SeverityLabel--ProgName:message#=>D,[2013-11-25T13:31:03.451024#38180]DEBUG--:我想让它看起来像:SeverityLabel[DateTimemSec#pid]:message#=>DEBUG[2013-11-25T13:31:03.451024#38180]:我知道我可以这样格式化它:logger.formatter=procdo|severity,datetime,progname,msg|"severity[#{date
我需要将所有请求(包括HTTPheader、正文等)记录到某个url。我试过这段代码:defindexglobal_request_loggingendprivatedefglobal_request_logginghttp_request_header_keys=request.headers.keys.select{|header_name|header_name.match("^HTTP.*")}http_request_headers=request.headers.select{|header_name,header_value|http_request_header_key
Rails在标准库中与Ruby的logger类捆绑在一起。可用的日志级别是::debug、:info、:warn、:error和:致命的。我想知道如果我在我的Rails应用程序中添加大量日志记录并将日志级别设置为:debug用于开发和测试,在生产中运行时关闭日志记录或设置在更高级别,例如config.log_level=:fatal? 最佳答案 简短的回答是,日志记录总是会对性能产生影响,尤其是在记录到磁盘时。但是,有一些微妙之处。首先,使用:debug级别将比:fatal有更大的性能损失,因为正在评估和写入日志输出的字符串数量要多
默认的RubySequel行为是在INFO级别记录所有数据库查询(不同于在DEBUG级别记录的ActiveRecord)。我该如何更改? 最佳答案 以前,使用代理记录器对象相当简单,但是有足够多的人要求我实现它。使用Sequel的gitmaster分支,您现在可以:DB.sql_log_level=:debug这将在记录查询时使用调试方法而不是信息方法。 关于ruby-如何将RubySequel日志记录设置为DEBUG级别?,我们在StackOverflow上找到一个类似的问题:
我这样使用ruby记录器:$logger=Logger.newMultiIO.new($stdout,log_file)MultiIO是我从thisanswer得到的一个类.这在大多数情况下效果很好,但我正在使用'colored'rubygem在终端上提供彩色输出。不幸的是,这也最终出现在日志文件中,因为ANSI转义看起来像[32mPASS[0m或一些类似的不可打印字符垃圾。清理日志文件字符串同时保持tty字符串颜色的最佳方法是什么?我不介意猴子修补Logger或MultiIO,但我绝对不希望对日志文件和屏幕进行两次不同的调用。 最佳答案