草庐IT

java - 在 shell 脚本中运行 Hadoop 命令

全部标签

ruby - 有没有办法用内存分配报告来分析 ruby​​ 1.9.2 脚本?

我的ruby​​应用程序遇到了瓶颈,但我无法弄清楚它在哪里变慢了。我找到了memprof,但它不支持1.9。我还发现ruby​​-prof似乎在1.9.2上运行良好,但内存分配需要修补的ruby​​解释器,我只能找到ruby​​1.8的补丁。是否有ruby​​分析器可以完成这项工作? 最佳答案 您是否尝试过分析GC?Ruby1.9.2包括GC::Profiler。GC::Profiler.enableGC.startputsGC::Profiler.report您可能还想查看ObjectSpace.count_objects。

脚本底部的 Ruby 方法?

我使用的是ruby​​1.8.7。我可以发誓我之前已经在脚本底部编写了我的函数并且运行良好。我必须将它们放在顶部吗?这似乎是他们现在唯一的工作方式。没什么大不了的。我只是更喜欢将它们放在底部,所以我想我会问。 最佳答案 您可以在一个或多个BEGINblock中执行初始化代码(继承自Perl,后者继承自awk)。can_i_do_this?#=>yesBEGIN{defcan_i_do_this?puts"yes"end}为了完整起见,还有ENDblock:END{can_i_do_this?#=>yes}defcan_i_do_th

css - gulp-ruby-sass - 'sass' 未被识别为内部或外部命令、可运行程序或批处理文件

我正在尝试在Windows上运行gulp-ruby-sass。我已经像这样安装了Ruby和Sass:$gem安装sass我的gulp.task看起来像这样:gulp.task('styles',function(){returnsass('src/scss/**/*.scss').on('error',sass.logError).pipe(gulp.dest('css'));});当我进入元素的根目录并运行$gulpstyles时,我明白了:[22:54:52]Usinggulpfilec:\wamp\www\wordpress\wp-content\themes\bootscore

ruby-on-rails - 在不使用屏幕的情况下在后台运行 ruby​​ 脚本

我在Rails环境中有两个必须全天候运行的脚本。我在远程服务器上工作,所以我需要使用ssh启动脚本,这意味着我需要一直打开ssh窗口。我正在寻找一种在后台运行这些脚本的简单方法,这样它们就不会在我关闭ssh连接后立即被取消。我不想使用屏幕。我认为必须有更简单的方法来处理这个问题。不是吗? 最佳答案 我认为最基本的解决方案是nohup:nohupmyscript&>/dev/null& 关于ruby-on-rails-在不使用屏幕的情况下在后台运行ruby​​脚本,我们在StackOver

ruby - 如何知道 FileUtils 命令是否成功?

我没有看到FileUtils命令的任何返回值。我想做这样的事情:really=(gets.chomp=="y")ifreallysuccess=FileUtils.rm_rf"./PROJECT_#{@name}"#doesnotworkendputs"./PROJECT_#{@name}deleted"ifsuccess我读了documentation对于FileUtils,还读取了“GettingexecutedcommandfromrubyFileUtils”,但我不知道如何使用答案。 最佳答案 根据文档(http://rub

ruby - 如何在 ruby​​ 中获得完整的命令行?

如何在ruby​​中获得完整的命令行?$railsc>$0=>"script/rails">ARGV[]>`ps-eo"%p|$|%a"|grep'^\\s*#{Process.pid}'`.strip.split("|$|")[1]=>"/home/sam/.rvm/rubies/ruby-1.9.3-p194-perf/bin/rubyscript/railsconsole"有什么比ninjaps更干净的方法可以得到相同的结果吗?澄清一下,以防混淆,我想要完全相同的输出:`ps-eo"%p|$|%a"|grep'^\\s*#{Process.pid}'`.strip.split("

ruby - 从从 stdin 读取的 Ruby 脚本调用时,Pry 不会停止

我创建了一个控制台Ruby脚本,它使用ARGF从文件或标准输入加载数据,然后调用Pry。当我在(Pry暂停)中传递一个文件但在我使用stdin传递我的数据时失败(Pry不停止并且只是退出Ruby)时,这非常有效。这很奇怪,有人知道为什么吗?我想通过stdin传递数据并让Pry暂停。看,一个示例脚本:require'rubygems'require'pry'defpry_it(str)binding.pryendpry_it(ARGF.read)当我使用ARGV中的文件调用此应用程序时,我得到了正确的响应-暂停%bundleexecrubypry_test.rbfile.txtFrom:

ruby - 如何限制同一 Ruby 脚本的并发实例?

在Ruby1.9.x中,不允许我的Ruby脚本再次运行或等待前一个实例完成的简单方法是什么?**我希望避免困惑的文件锁定或进程表检查。有没有类似globalmutex的东西或信号量已经在核心?我研究了原生Mutex但这似乎只适用于一个Ruby进程内的线程,而不适用于不同进程。**稍后我可能会添加超时功能,或者限制为N个实例,或者希望使用多个全局锁(每个系统范围的资源一个,最多只能有一个实例)。 最佳答案 这段非常短的代码将卡住在原地,直到/tmp中以您的脚本命名的锁定文件被独占锁定:File.open("/tmp/#{File.ba

ruby - 如何将 Rubymine IDE 调试器附加到 shell 进程?

我想使用Rubymine的IDE调试器来调试在命令shell中运行的ruby​​进程,因为它是生成的,例如通过“railsconsole”。在运行网络服务器(从Rubymine中)或测试套件(也从Rubymine中运行)时,我已经从调试器中获得了很大的收获。但是,如果该进程不是由Rubymine启动的,我不知道如何附加调试器。我在带有SunJava1.6.0_26、RubyREE1.8.7和最新调试gems的Ubuntu上使用Rubymine3.2.4版本:ruby-debug-base(0.10.4)ruby-debug-ide(0.4.17.beta8)想法?

ruby - 使用适当的参数转义从 ruby​​ 调用 shell 命令

我想安全地做以下事情system"echo'#{params[:message]}'>/dev/log"调用native命令时转义参数的正确方法是什么?(邪恶输入示例:';rm-Rf*;echo'我赢了。) 最佳答案 如果你这样做system"echo",params[:message]然后第二个参数,将作为参数发送,它不会被执行。 关于ruby-使用适当的参数转义从ruby​​调用shell命令,我们在StackOverflow上找到一个类似的问题: htt