草庐IT

检测与记录

全部标签

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

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

51单片机(郭天祥版)——键盘检测原理及应用实现

实验中我们使用的是52单片机目录前言一、单片机是什么?二、实验步骤1.独立键盘检测1.2代码如下(示例):1.3图片1.4视频2.矩阵键盘检测2.2代码如下(示例):2.3图片2.4视频总结:以上就是今天要讲的内容,本文仅仅简单介绍了单片机键盘检测的应用实现,而单片机键盘检测相关理论可以参考教材进行学习前言文章内主要概念引自郭天祥老师《新概念51单片机C语言版》一书主要展示郭天祥老师书中第四章键盘检测原理及应用实现。分为仿真、实体两部分。一、单片机是什么?单片机就是在一块硅片上集成了微处理器、存储器及各种输入/输出接口的芯片,这样一块芯片就具有了计算机的属性,因而被成为单片微型计算机,简称单片

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

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

ruby - 检测安装的 CPU 数量

我已经通过cat/proc/cpuinfo找到了“大多数unix”的解决方案,但是纯Ruby解决方案会更好。 最佳答案 从Ruby版本2.2.3开始,etcRuby标准库中的模块提供了一个nprocessors返回处理器数量的方法。需要注意的是,如果ruby​​被降级为CPU内核的一个子集,Etc.nprocessors将只返回Ruby可以访问的内核数。此外,作为seanlinsley指出,这只会返回虚拟内核而不是物理内核,这可能会导致预期值出现差异。require'etc'pEtc.nprocessors#=>4

ruby-on-rails - 加载常量时自动加载常量时检测到循环依赖

首先:我用谷歌搜索并使用了此处的搜索,找到了相同错误的答案,但设置不同。也许我打破了一些不同的地方;)错误:RuntimeErrorat/admin/usersCirculardependencydetectedwhileautoloadingconstantAdmin::UsersController结构是:App=>controllers=>admin=>users_controller.rb路线:namespace:admindoresources:stuffresources:usersend用户Controller:classUsersController管理基础Contro

ruby-on-rails - 在 Rails 4.1 中,如何通过枚举符号查找记录?

假设我有这个模型:classConversation如何在不使用枚举的数值或不必遍历每个对话的情况下找到所有事件对话?我尝试执行Conversation.where(status::active),但没有产生任何结果。想到的唯一解决方案是遍历所有对话并选择事件对话,但这看起来不是一个好的解决方案。Conversation.all.select{|conversation|conversation.active?}我能做些什么吗? 最佳答案 ActiveRecord::Enum提供基于其值的范围。试试看:Conversation.ac

ruby - 如何使用 yardoc 列出未记录的模块/类/常量/方法?

我有一个小型代码库,我正在用YARD记录这些代码.当我运行yardoc命令时,它告诉我:Files:40Modules:14(0undocumented)Classes:39(0undocumented)Constants:21(4undocumented)Methods:239(31undocumented)88.82%documented与其费力地遍历我的所有代码来查找未记录的常量和方法,我希望它简单地列出未记录的项目。有人知道怎么做吗? 最佳答案 您可以使用--list-undoc选项专门列出所有未记录的对象(及其文件位置)。

ruby-on-rails - 我如何在具有事件记录的 Rails 中使用两个不同的数据库?

我需要在不同的Rails模型中使用不同的数据库连接。有没有一种不太hacky的方法来做到这一点?任何链接或搜索关键字都很棒:) 最佳答案 将新部分添加到您的database.yml例如other_development:adapter:mysqldatabase:otherdb_developmentusername:rootpassword:host:localhostother_production:adapter:mysqldatabase:otherdb_productionusername:rootpassword:hos

ruby-on-rails - 如何检测导致 Rake 弃用警告的原因

当我执行bundleexecrake-T(或bundleexecrake)时,我收到弃用警告:Andrews-Air:nabuagrimm$bundleexecrake--trace-T[DEPRECATION]`last_comment`isdeprecated.Pleaseuse`last_description`instead.[DEPRECATION]`last_comment`isdeprecated.Pleaseuse`last_description`instead.[DEPRECATION]`last_comment`isdeprecated.Pleaseuse`las

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

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