jjzjj

ruby - Ruby 的 stdlib Logger 类是线程安全的吗?

简单来说就是标准库LoggerRuby中的线程安全类?Google发现的唯一有用信息是论坛上有人说它“似乎”是线程安全的。而且我不想花时间测试记录器来弄清楚它是否正确。目前我正在使用log4r这是线程安全的,但如果标准库已经做到了,那就太过分了。 最佳答案 快速查看logger.rb会发现如下代码:defwrite(message)@mutex.synchronizedoif@shift_ageand@dev.respond_to?(:stat)begincheck_shift_logrescueraiseLogger::Shift

ruby - Rails 控制台未将 SQL 语句输出到我的开发日志

当我通过本地主机访问我的Webrick服务器时,或者当我运行railsmigrations时,我的development.log被正确写入。但是,当我使用“railsc”启动我的rails控制台,然后尝试创建一个新的数据库对象并通过“user.save”之类的命令保存它时,我在控制台中看到了SQL语句,但没有写入任何内容开发日志。大多数人在回答与此类似的问题时会说“检查以确保配置设置为正确的环境”。我已经这样做了,并且可以在我的系统上说这发生在一个全新的Rails应用程序上。如有任何帮助,我们将不胜感激。谢谢! 最佳答案 rails

ruby-on-rails - 如何像调试 Rails 应用程序一样调试 Sinatra 应用程序?

在我的主SinatraController中,我想在从表单发布后调试参数散列。我已经添加了:putsparams.inspect和set:logging,:true如果一切顺利,params.inspect会起作用。但是,如果在执行Controller之前发生错误,我不会像默认情况下在Rails中那样获得有关错误的任何信息。获取有用调试信息的最佳方式是什么?Thisexample根本不起作用(在我添加此代码后应用程序甚至无法启动):configuredoLog=Logger.new("sinatra.log")Log.level=Logger::INFOend其次是:Log.info"

ruby - 如何记录在 Ruby 程序中调用的每个方法?

我继承了一大堆Ruby代码,坦率地说,对于像我这样的凡人来说,这些代码几乎无法理解。它实际上是Rspec单元测试代码,但结构“非常不寻常”说得好听。我想做的是运行代码,并在某处记录以下信息:每个被调用的方法,包括定义该方法的类的名称,以及定义被调用方法的文件名(是的,我们在多个不同的文件中定义了相同的类/方法,并且它是很难知道调用的是哪个)(可选)传递给调用的每个方法的参数这样,我就可以开始尝试重构它了。没有它,由于代码库的大小(20k+单元测试用例),理顺它将是一项非常困难的任务。我无法承担对正在运行的代码进行大规模编辑的费用,因为即使您在其周围使用苛刻的语言(即经常),它也会中断。

ruby-on-rails - rails : Logging for code in the lib directory?

为保存在lib目录中的代码配置日志记录的最佳/最简单方法是什么? 最佳答案 有两种方法:假设您的库是独立的并且有一个模块,您可以将logger属性添加到您的模块并在您的库代码中的任何地方使用它。moduleMyLibrarymattr_accessor:loggerend然后,您可以使用config/initializers/中的初始化程序,或使用config/environment.rb中的config.after_initializeblock来初始化你的记录器,像这样:require'mylibrary'MyLibrary.l

ruby-on-rails - 如何使用默认的 Rails 记录器记录 Ruby 异常的整个回溯?

我正在从事rails项目,我正在尝试将异常记录到rails日志文件中。我知道我可以调用logger.error$!将异常的第一行记录到文件中。但是,我也想记录整个跟踪堆栈。如何使用默认的Rails记录器记录异常的整个回溯? 最佳答案 logger.error$!.backtrace还有,别忘了你可以rescueErrorType=>error_name为您的错误指定一个不同于默认$!的变量名。 关于ruby-on-rails-如何使用默认的Rails记录器记录Ruby异常的整个回溯?,我

ruby-on-rails - 在 rails 3 中设置记录器

我正在尝试弄清楚如何将记录器与Rails3一起使用。我需要记录到控制台中没有的文件,但我只是不知道如何设置它,然后如何设置向该日志写入内容。我尝试了Rails文档,但他们并没有真正说清楚。 最佳答案 默认情况下,Rails应该将日志记录到项目的log目录中的特定于环境的日志文件中。它将被称为test.log、development.log或production.log,具体取决于您在哪个环境中运行。您可以使用Rails.logger对象直接记录到Rails的记录器:Rails.logger.info"Myinfomessage"Ra

ruby-on-rails - 登录 delayed_job?

我无法从delayed_job获得任何日志输出,而且我不确定我的作业是否开始。这是我的Procfile:web:bundleexecrailsserverworker:bundleexecrakejobs:workworker:bundleexecclockworkapp/clock.rb这是工作:classScanningJobdefperformlogger.info"loggingfromdelayed_job"enddefafter(job)Rails.logger.info"loggingfromafterdelayed_job"endend我看到发条输出到系统输出,我可以看

Ruby - 在模块/类之间共享记录器实例

正在编写一个小的Ruby脚本,该脚本可以访问网络并抓取各种服务。我有一个模块,里面有几个类:moduleCrawlerclassRunnerclassOptionsclassEngineend我想在所有这些类中共享一个记录器。通常我只是将它放在模块中的常量中并像这样引用它:Crawler::LOGGER.info("Hello,world")问题是在我知道输出的去向之前我无法创建我的记录器实例。您通过命令行启动爬虫,此时您可以告诉它您想要在开发(日志输出到STDOUT)或生产(日志输出到文件crawler.log)中运行:crawler--environment=production我

ruby - 登录 Sinatra?

我无法弄清楚如何使用Sinatra记录消息。我不是要记录请求,而是要在我的应用程序的某些点上自定义消息。例如,在获取URL时,我想记录"Fetching#{url}"。这是我想要的:指定日志级别的能力(例如:logger.info("Fetching#{url}"))在开发和测试环境中,消息将写入控制台。在生产中,只写出与当前日志级别匹配的消息。我猜这可以在config.ru中轻松完成,但我不能100%确定要启用哪个设置,以及是否必须手动创建一个Logger我自己的对象(此外,要使用哪个类的Logger:Logger、Rack::Logger或Rack::CommonLogger).(