我正在使用daemonsgem在Ruby中创建一个守护进程。我想将守护进程的输出添加到日志文件中。我想知道将puts从控制台重定向到日志文件的最简单方法是什么。 最佳答案 如果您需要同时捕获STDERR和STDOUT并且不想求助于日志记录:$stdout.reopen("my.log","w")$stdout.sync=true$stderr.reopen($stdout)恢复:$stdout=STDOUT 关于ruby-将"puts"命令输出重定向到日志文件,我们在StackOverf
我有一个不断增长的日志文件。我如何通过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方法你
我在amd-64平台上运行ubuntu9.10服务器。一切都非常标准,我已经在ruby1.8安装上运行了Sinatra0.94。我想安装passenger以便轻松配置ssl。问题是,它找不到安装程序。我跑sudogeminstallpassenger或sudogeminstall-rpassenger然后是下一行,passenger-install-nginx-module或passenger-install-apache2-module都失败了,因为找不到路径。我在这里忘记了什么吗?一旦安装了gem,它不应该直接工作吗? 最佳答案
我们最近开始在我们公司插入合规性,并且需要保留对我们当前在Rails应用程序中管理的数据更改的完整历史记录。我们已经获准将每个操作的描述性内容简单地推送到日志文件,这是一种相当不引人注目的方式。我倾向于在ApplicationController中做这样的事情:around_filter:set_logger_usernamedefset_logger_usernameThread.current["username"]=current_user.login||"guest"yieldThread.current["username"]=nilend然后创建一个看起来像这样的观察者:c
我正在尝试使用“puts”来测试托管在Heroku上的Sinatra应用程序的一些内容。有趣的是,输出似乎排队并且仅在重新启动Herokudyno时显示。我尝试过使用“Thin”和“Webrick”,但遇到了同样的问题。有什么想法吗? 最佳答案 正如您在herokudocs上看到的那样:将此添加到您的config.ru:$stdout.sync=true不要忘记stdout之前的$否则它不会工作。 关于ruby-"puts"输出未显示在Sinatra应用程序的Heroku日志中,我们在S
我正在尝试在Rails中调试模型,因此我使用了以下代码:logger.debug('asasd')但是,我正在跟踪日志文件development.log,但我没有看到它添加到此文件中。我确定这个模块正在运行我已确认运行时错误正在记录到此文件中,并且我在tail时看到了它们。我如何让它工作? 最佳答案 确保您已将日志级别设置为在environments/appropriate_env_file.rb中进行调试:config.log_level=:debug并确保您根据运行环境跟踪正确的日志文件。
问题我在两台服务器上安装了Rails3.2.15和机架1.4.5。第一个服务器是服务于静态Assets的nginx代理。第二台服务器是为Rails应用程序提供服务的unicorn。在Railsproduction.log中,我总是看到nginxIP地址(10.0.10.150)而不是我的客户端IP地址(10.0.10.62):StartedGET"/"for10.0.10.150at2013-11-2113:51:05+0000我想在日志中有真实的客户端IP。我们的设置HTTPheaderX-Forwarded-For和X-Real-IP在nginx中设置正确,我已经定义了10.0.1
当我通过本地主机访问我的Webrick服务器时,或者当我运行railsmigrations时,我的development.log被正确写入。但是,当我使用“railsc”启动我的rails控制台,然后尝试创建一个新的数据库对象并通过“user.save”之类的命令保存它时,我在控制台中看到了SQL语句,但没有写入任何内容开发日志。大多数人在回答与此类似的问题时会说“检查以确保配置设置为正确的环境”。我已经这样做了,并且可以在我的系统上说这发生在一个全新的Rails应用程序上。如有任何帮助,我们将不胜感激。谢谢! 最佳答案 rails
一台服务器nginx绑定多个域名,多个域名规则写一个配置文件里,也可又分别建立多个域名配置文件,为了管理方便,每个域名建一个文件,有些同类域名也可又写在一个总的配置文件里。 一: 每个域名一个文件的写法 首先打开nginx域名配置文件存放目录:/usr/local/nginx/conf/servers,如要绑定域名www.itblood.com则在此目录建一个文件:www.itblood.com.conf然后在此文件中写规则,如: server{ listen80; server_namewww.itblood.com;#绑定域名 indexindex.htmindex.ht
在服务器端使用带有streamblock的Sinatra。get'/stream',:provides=>'text/event-stream'dostream:keep_opendo|out|connections在客户端:vares=newEventSource('/stream');es.onmessage=function(e){$('#chat').append(e.data+"\n")};当我通过http://localhost:9292/直接使用应用程序时,一切正常。连接是持久的,所有消息都传递给所有客户端。但是,当它通过Nginx时,http://chat.dev,连接