jjzjj

ruby - Puma 登录到哪里

我一直在使用Thin来运行我的ruby​​Sinatra应用程序,但我现在切换到Puma。Thin创建了我自己使用的日志log/thin.log。我注意到Puma没有生成日志文件(我看不到)。我已经尝试用谷歌搜索有关此的文档,但没有真正找到任何东西。我想知道您是否/如何在Puma中指定日志路径。如有任何帮助,我们将不胜感激。亚历克斯 最佳答案 检查示例config.rb按照repo协议(protocol)的建议README.如图所示:#RedirectSTDOUTandSTDERRtofilesspecified.The3rdpar

ruby - 如何将自定义日志级别添加到 ruby​​ 中的记录器?

我需要为ruby​​logger添加自定义日志级别,如“verbose”或“traffic”,怎么办? 最佳答案 您自己的记录器只需要覆盖Logger#format_severity方法,如下所示:classMyLogger 关于ruby-如何将自定义日志级别添加到ruby​​中的记录器?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2281490/

ruby - 我可以禁用 ruby​​ 记录器的日志 header 吗?

我目前遇到了一些问题。您可能知道,ruby记录器会在每个新创建的日志文件的顶部添加一个记录header。"#Logfilecreatedon%sby%s\n"%[Time.now.to_s,Logger::ProgName]我正在记录CSV文件以便稍后将它们导入仓库,通常我只是跳过带有标题的第一行。记录器中似乎存在错误,因为有时日志记录header出现不止一次,就在日志文件的中间。所以我决定简单地离开那个标题。令我惊讶的是,我没有发现任何可以在创建记录器时通过的论据。我想到了这样的事情:Logger.new"info.log",:skip_header=>true但它就是不存在。我搜索

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G

ruby-on-rails - 如何将特定请求详细信息记录到 Rails 服务器日志

我通常不喜欢在不了解正在发生的事情的情况下直接询问如何做某事,但我对Rails还很陌生,我很难做到这一点。基本上,我需要在单个日志语句中为每个请求捕获以下信息(如果可能的话)日志条目日期日志录入时间HTTP方法请求的URL港口请求者IP地址请求者的用户代理引用网址HTTP响应码主机名自定义日志格式的首选方式是什么?是否可以只修改现有日志并将此信息传递给它?或者我是否需要扩展和覆盖我需要的行为?我不需要将其保存到不同的日志文件或任何其他文件中,只需在每次请求时输出到STDOUT。如有任何帮助,我们将不胜感激。谢谢! 最佳答案 我知道这

ruby - 是否有适用于 Ruby 的异步日志记录库?

同步日志记录会导致很大的性能损失,因为它可能会阻塞。是否有一个独立的Ruby库可以进行异步日志记录(log4r似乎没有)?我可以修改标准库记录器以异步记录吗?我正在寻找类似log4j的AsyncAppender的东西-但最好是使用Ruby的代码块将尽可能多的工作转移到后台线程的实现。 最佳答案 我知道你不应该真正回答你自己的问题,但在ruby​​中似乎一切都很简单:require'thread'require'singleton'require'delegate'require'monitor'classAsyncincludeSi

ruby-on-rails - Rake:记录任何正在执行的任务

如何在不更改任务源的情况下为每个rake任务创建数据库日志记录?我需要存储日期时间、任务名称、参数。是否有某种观察者等? 最佳答案 你可以覆盖application.rb中的Rake::Task#invoke方法:#application.rbmoduleRakeclassTaskalias_method:origin_invoke,:invokeifmethod_defined?(:invoke)definvoke(*args)logger=Logger.new('rake_tasks_log.log')logger.info"#

ruby - Ruby 的 stdlib Logger 类能否安全地处理来自多个进程的编写器?

我正在开发一个需要进行日志记录的Ruby库。理想情况下,我希望多个工作进程能够登录同一个文件。查看来自Ruby标准库的Logger类的源代码,我看到努力从多个线程同步写入日志(正如对IsRuby'sstdlibLoggerclassthread-safe?的回答中所指出的)。当多个进程写入同一个日志文件时,似乎存在类似的问题:根据底层决定缓冲/拆分写入的方式,每个日志消息可能无法保持其完整性。那么,有没有一种方法可以使用标准的Logger类来允许多个进程安全地记录到一个文件中?如果不是,这在Ruby项目中通常是如何完成的?这就是我所说的“安全”的意思:每个日志行都是“原子的”——在下一

ruby - 禁用来自 webrick 的回显

如何禁止将来自webrick的消息回显到终端?对于出现在开头的INFO消息,我可以通过设置Logger参数来禁用它:s=WEBrick::HTTPServer.new(Port:3000,BindAddress:"localhost",Logger:WEBrick::Log.new("/dev/null"),)但我还想禁用如下所示的消息:localhost--[17/Jun/2011:10:01:38EDT]"GET....HTTP/1.1"2000http://localhost:3000/->.....当从网络浏览器发出请求时。 最佳答案

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend