草庐IT

网站日志

全部标签

ruby - 哪个查询去了哪个数据库的 ActiveRecord 日志

在与不同数据库有多个连接的ActiveRecord应用程序中,日志中没有任何内容表明哪个查询去了哪个数据库。这些查询分离数据库:Base1.connection.select_value("select*fromfoo")Base2.connection.select_value("select*fromfoo")发出这些日志条目:D,[2017-03-13T09:27:11.844395#22112]DEBUG--:(0.6ms)select*fromfooD,[2017-03-13T09:27:11.844539#22112]DEBUG--:(0.1ms)select*fromfo

ruby - 静态网站生成

我需要一种简单的方法来生成静态网页,以便我可以使用Apache或Nginx为它们提供服务。目前我正在使用SproutCore的构建工具(Abbot)来生成静态页面,但这有点麻烦,因为它是为构建SproutCore应用程序而不是非SproutCoreHTML页面而设计的。这是我的要求:必须合并和压缩Javascript必须合并CSS文件每个图像/CSS/JavascriptAssets都必须有唯一的URL以便更好地缓存(查询字符串不够)AssetsURL只有在真正发生变化时才应该不同本地化支持全面的HTML、CSS、Javascript和图像文件带有布局、部分等的漂亮模板引擎。以下是我找

ruby-on-rails - Ruby on Rails - 如何以彩色打印日志消息

我很惊讶我已经无法在SO上找到它了。我希望能够为输出到控制台的日志输出中的特定字符串段着色。所以像这样:"ThispartofthemessageinGreen:ThispartinBlue"可能是这样写的:Rails.logger.debug("ThispartofthemessageinGreen:".green+"ThispartinBlue".blue) 最佳答案 基本上,您要做的是将颜色的ANSI转义序列嵌入到调试字符串中,就像您在常规Ruby程序中所做的那样。有几种方法可以解决这个问题:使用rainbowgem,它允许你

ruby-on-rails - 在日志消息之前添加当前时间

我为我的应用程序创建了一个自定义记录器,称为CRON_LOG,只需将这段代码添加到config/environment.rbCRON_LOG=Logger.new("#{Rails.root}/log/cron.log")CRON_LOG.level=Logger::INFO然后,当我想记录一些东西时,就这样做:CRON_LOG.info"something"它工作正常,但我想在每条日志消息之前添加当前时间戳。当然,我可以将Time.now添加到我的日志消息中,但我想知道是否有一种方法可以将它作为默认值添加到每条日志消息中。我该怎么做?谢谢。 最佳答案

ruby - 将 "puts"命令输出重定向到日志文件

我正在使用daemonsgem在Ruby中创建一个守护进程。我想将守护进程的输出添加到日志文件中。我想知道将puts从控制台重定向到日志文件的最简单方法是什么。 最佳答案 如果您需要同时捕获STDERR和STDOUT并且不想求助于日志记录:$stdout.reopen("my.log","w")$stdout.sync=true$stderr.reopen($stdout)恢复:$stdout=STDOUT 关于ruby-将"puts"命令输出重定向到日志文件,我们在StackOverf

ruby - 观看/阅读不断增长的日志文件

我有一个不断增长的日志文件。我如何通过Ruby脚本查看和解析它?脚本将解析写入文件的每个新行,并在新行包含字符串'ERROR'时将内容输出到屏幕 最佳答案 defwatch_for(file,pattern)f=File.open(file,"r")f.seek(0,IO::SEEK_END)whiletruedoselect([f])line=f.getsputs"Foundit!#{line}"ifline=~patternendendwatch_for("g.txt",/ERROR/)感谢ezpz的想法,使用select方法你

ruby - 使用 Ruby 脚本通过 https 登录网站

好吧,事情是这样的:我正在开发一个Ruby应用程序,它将从网站获取数据,并将该数据聚合到一个XML文件中。我需要取数据的网站没有我可以使用的API,所以我唯一能想到的就是登录网站,顺序加载有我需要的数据的页面(在这个case,PMs;我想归档它们),然后解析返回的HTML。但是,问题是我不知道有什么方法可以编程模拟登录session。有没有人有任何建议,或者知道我可以用来成功登录到https页面,然后使用来自登录的临时cookiesession以编程方式从站点加载页面的任何行之有效的方法?它不一定是一个仅限Ruby的解决方案——我只是想知道我如何才能真正做到这一点。如果有帮助的话,有问

ruby-on-rails - 如何在 Rails 中为每个表创建完整的审计日志?

我们最近开始在我们公司插入合规性,并且需要保留对我们当前在Rails应用程序中管理的数据更改的完整历史记录。我们已经获准将每个操作的描述性内容简单地推送到日志文件,这是一种相当不引人注目的方式。我倾向于在ApplicationController中做这样的事情:around_filter:set_logger_usernamedefset_logger_usernameThread.current["username"]=current_user.login||"guest"yieldThread.current["username"]=nilend然后创建一个看起来像这样的观察者:c

ruby - "puts"输出未显示在 Sinatra 应用程序的 Heroku 日志中

我正在尝试使用“puts”来测试托管在Heroku上的Sinatra应用程序的一些内容。有趣的是,输出似乎排队并且仅在重新启动Herokudyno时显示。我尝试过使用“Thin”和“Webrick”,但遇到了同样的问题。有什么想法吗? 最佳答案 正如您在herokudocs上看到的那样:将此添加到您的config.ru:$stdout.sync=true不要忘记stdout之前的$否则它不会工作。 关于ruby-"puts"输出未显示在Sinatra应用程序的Heroku日志中,我们在S

ruby-on-rails - logger.debug 不写入 Rails 中的日志文件

我正在尝试在Rails中调试模型,因此我使用了以下代码:logger.debug('asasd')但是,我正在跟踪日志文件development.log,但我没有看到它添加到此文件中。我确定这个模块正在运行我已确认运行时错误正在记录到此文件中,并且我在tail时看到了它们。我如何让它工作? 最佳答案 确保您已将日志级别设置为在environments/appropriate_env_file.rb中进行调试:config.log_level=:debug并确保您根据运行环境跟踪正确的日志文件。