草庐IT

架构篇-怎么构建健壮的分布式系统?

全部标签

ruby-on-rails - Capistrano 部署到系统范围的 RVM 看不到已安装的 Rubies

我在我的服务器上使用系统范围的Ruby安装,并尝试部署到RVMgemset(比如rvmuse1.9.2@gemset_name)当我运行我的Cap文件时,Cap呕吐并说没有安装Ruby。但是,实际上安装了Ruby。(部署用户是rvm组的一部分,可以在命令行上手动rvmuse。)我可能做错了什么?Capfile相关部分$:.unshift(File.expand_path('./lib',ENV['rvm_path']))#AddRVM'slibdirectorytotheloadpath.require"bundler/capistrano"require"rvm/capistrano

ruby-on-rails - 构建一个集成我的 rails 环境的 ruby​​ 守护进程

我需要构建一个将使用freeswitcher的ruby​​守护进程freeswitch的eventmachine库。几天以来,我一直在网上寻找构建ruby​​守护程序的最佳解决方案,该守护程序将集成我的Rails环境,特别是我的事件记录模型。我看过优秀的RyanBates截屏视频(第129集自定义守护程序),但我不确定这是否仍然是一个实际的解决方案。我如何以好的方式做到这一点? 最佳答案 我一直在为我的Rails环境构建守护进程。守护进程gem确实完成了所有工作。作为示例,这是从我最新的Rails应用程序(script/yourda

ruby - 我可以覆盖 Ruby 中的系统时区吗?

我在Ubuntu12.04上,我可以看到:$cat/etc/timezoneAmerica/Phoenix相应地,Time将返回一个非UTC时区的时间:$irb>Time.now=>2013-03-2713:44:49-0700>Time.at0=>1969-12-3117:00:00-0700我可以使用TZ环境变量覆盖系统时区:$TZ=UTCirb>Time.now=>2013-03-2720:47:19+0000>Time.at0=>1970-01-0100:00:00+0000无论如何,我可以在Ruby进程中以编程方式进行此更改吗? 最佳答案

ruby-on-rails - 是否有针对 Rails、Ruby、Erb 的 Xcode 语法着色?如果没有,我怎么能自己写一个?

Xcode的语法着色充其量只是很差,而textmate看起来不错,但我喜欢Xcode,因为我也用C++编程。我想将所有内容都放在一个地方并利用其他Xcode功能。有没有人已经这样做过或者有没有简单的方法来做到这一点? 最佳答案 你可以去Editor>SyntaxColoring>CheckHTMLanddoitagainforRuby 关于ruby-on-rails-是否有针对Rails、Ruby、Erb的Xcode语法着色?如果没有,我怎么能自己写一个?,我们在StackOverflo

ruby - 如何使用 Ruby 将键盘和鼠标命令发送到底层操作系统?

是否有操作系统中立的方式让Ruby将键盘和鼠标事件发送到底层操作系统?(对我而言)一个明显的方法是使用Ruby/Java绑定(bind)并使用java.awt.Robot,但这看起来很愚蠢。 最佳答案 对于Mac:geminstallrb-appscript然后你可以用这样的脚本来测试它:require"rubygems"require"appscript"includeAppscriptapp("TextEdit").activateapp("SystemEvents").keystroke("LookMa,keystrokes!

ruby - 数组的所有可能分布,来自一个数字

我不太确定如何表达这一点,所以我只是举个例子。如果我写:some_method(["a","b"],3)我希望它返回某种形式的[{"a"=>0,"b"=>3},{"a"=>1,"b"=>2},{"a"=>2,"b"=>1},{"a"=>3,"b"=>0}]如果我传入some_method(%w(abc),2)期望的返回值应该是[{"a"=>2,"b"=>0,"c"=>0},{"a"=>1,"b"=>1,"c"=>0},{"a"=>1,"b"=>0,"c"=>1},{"a"=>0,"b"=>2,"c"=>0},{"a"=>0,"b"=>1,"c"=>1},{"a"=>0,"b"=>0,"

ruby - 为什么要使用 SQL 构建器? Arel 诉 Sequel 诉 T-SQL

我正在尝试了解通过面向对象的构建器DSL构建SQL与参数化原始SQL字符串相比的优势。在以三种方式研究/实现相同的查询之后,我注意到原始SQL是迄今为止最容易阅读的。这就引出了一个问题,“为什么要跳过一个箍?”为什么不直接声明和使用原始SQL?这是我想出的:首先,我猜它使SQL更具可移植性,因为它可以被任何带有适配器的数据库使用。我猜这是大人物,对吧?尽管如此,难道大多数T-SQL不是大多数数据库都能理解的吗?其次,它提供了一个可以重复使用的查询对象——作为其他查询、命名范围链接等的基础。通过构建SQL而不是声明SQL,您实现的主要投资返回是什么?definstances_of_sql

ruby - Jekyll 默认使用系统 Ruby 版本而不是 RVM 版本

我已经查看了数十篇关于此的帖子,但仍然不太明白/没有找到相同的情况。基本上,我有默认设置为Ruby2.0.0的RVM,但是当我使用我的Jekyll页面进入目录并运行时jekyllserve结果是/Library/Ruby/Site/1.8/rubygems/dependency.rb:298:in`to_specs':Couldnotfind'jekyll'(>=0)among5totalgem(s)(Gem::LoadError)from/Library/Ruby/Site/1.8/rubygems/dependency.rb:309:in`to_spec'from/Library/

ruby - 如何等待系统命令结束

我正在使用Ruby中的系统命令转换XLS2CSV文件。转换后我正在处理CSV文件,但是当程序要处理文件时转换仍在运行,所以那时它们不存在。谁能告诉我是否可以让Ruby等待系统命令完成的正确时间?现在我正在使用:sleep20但是如果一次要花更长的时间,那当然是不对的。我具体做的是这样的:#Callontheprogramtoconvertxlscommand="C:/Development/Tools/xls2csv/xls2csv.exeC:/TDLINK/file1.xls"system(command)do_stuffdefdo_stuff#Thisiswhereiusefile

ruby-on-rails - Capistrano:不知道如何构建任务 'deploy:new_release_path'

我是第一次部署到DigitalOceanUbuntudroplet。我已经配置了所有内容并执行了所有步骤,现在我正在执行命令:capproductiondeploy:initial。对于此命令,我收到此错误消息:capaborted!Don'tknowhowtobuildtask'deploy:new_release_path'(see--tasks)/Users/Christopher/.rbenv/versions/2.3.1/lib/ruby/gems/2.3.0/gems/rake-12.0.0/lib/rake/task_manager.rb:58:in`[]'/Users/