Heroku rake任务使用字符串参数无法使用Sinatra app

时间:2013-01-03 00:59:12

标签: ruby heroku sinatra rake

我刚刚将一个Sinatra应用程序部署到heroku,该应用程序包含两个rake任务:

task :create_db , [:db_id , :db_name]
task :destroy_db , [:db_id, :token] 

当我跑步时

heroku run rake -T

在控制台中,Heroku打印出以下响应:

(in /app)
rake create_db[db_id,db_name]  # Creation count database task
rake destroy_db[db_id,token]   # Destroy database task

但是当我跑步时:

heroku run rake create_db['test', 'test database']

它响应以下错误:

(in /app)
rake aborted!
Don't know how to build task 'create_db[test,'
/usr/local/lib/ruby/1.9.1/rake.rb:1720:in `[]'
/usr/local/lib/ruby/1.9.1/rake.rb:2040:in `invoke_task'
/usr/local/lib/ruby/1.9.1/rake.rb:2019:in `block (2 levels) in top_level'
/usr/local/lib/ruby/1.9.1/rake.rb:2019:in `each'
/usr/local/lib/ruby/1.9.1/rake.rb:2019:in `block in top_level'
/usr/local/lib/ruby/1.9.1/rake.rb:2058:in `standard_exception_handling'
/usr/local/lib/ruby/1.9.1/rake.rb:2013:in `top_level'
/usr/local/lib/ruby/1.9.1/rake.rb:1992:in `run'
/usr/local/bin/rake:31:in `<main>'

我不太清楚为什么会失败,但我的猜测是它与字符串参数有关。正如您在上面所看到的,它表示“不知道如何构建任务'create_db [test,'测试显示没有字符串。

知道如何从命令行运行此任务吗?

3 个答案:

答案 0 :(得分:16)

来自Rake docs

  

rake任务名称及其参数需要是rake的单个命令行参数。这通常意味着没有空间。如果需要空格,则应引用整个rake +参数字符串。像这样:

     
rake "name[billy bob, smith]"
     

(操作系统和shell之间的引用规则各不相同,因此请务必查阅适用于您的操作系统/ shell的文档)。

另请注意,您无需引用各个参数。

在你的情况下,这应该有效:

rake "create_db[test, test database]"

这也有效:

rake create_db[test,'test database']

请注意,引用了第二个参数,但逗号和引号之间没有空格,因此shell将整个事件视为单个参数。

On Heroku

使用heroku run时这不起作用,因为在这种情况下,命令会被shell 解释两次,一次由你自己解释,再一次在Heroku Dyno上,所以你需要确保Heroku运行的命令具有正确的引号。

您需要转义引号:

heroku run rake \"create_db[test, test database]\"

以便在Dyno上运行的命令为rake "create_db[test, test database]";或引用引号:

heroku run rake "create_db[test,'test database']"

以便运行的命令为rake create_db[test,'test database']

答案 1 :(得分:2)

原因

  

$ heroku run rake create_db ['test','test database']

不起作用是由于参数之间/内部的空间。以下是可行的。

  

$ heroku run rake“create_db ['test','test database']”

答案 2 :(得分:1)

对我来说这很有效

heroku run rake "namespace:task['var1','var2']"