Rom*_*man 7 ruby linux thin sinatra
我有一个非常基本的测试应用程序.当我执行此命令时,服务器忽略我指定的端口并在端口4567上运行Thin.为什么我指定的端口被忽略?
$ruby xxx.rb start -p 8000
== Sinatra/1.3.3 has taken the stage on 4567 for production with backup from Thin
>> Thin web server (v1.4.1 codename Chromeo)
>> Maximum connections set to 1024
>> Listening on 0.0.0.0:4567, CTRL+C to stop
Run Code Online (Sandbox Code Playgroud)
xxx.rb文件
require 'Thin'
rackup_file = "config.ru"
argv = ARGV
argv << ["-R", rackup_file ] unless ARGV.include?("-R")
argv << ["-e", "production"] unless ARGV.include?("-e")
puts argv.flatten
Thin::Runner.new(argv.flatten).run!
Run Code Online (Sandbox Code Playgroud)
config.ru文件
require 'sinatra'
require 'sinatra/base'
class SingingRain < Sinatra::Base
get '/' do
return 'hello'
end
end
SingingRain.run!
Run Code Online (Sandbox Code Playgroud)
mat*_*att 14
你的问题在于:
SingingRain.run!
Run Code Online (Sandbox Code Playgroud)
这是Sinatra的run方法,它告诉Sinatra默认启动自己的Web服务器,该服务器在端口4567上运行.这是在你的config.ru文件中,但config.ru只是Ruby,所以这行就像在任何其他.rb文件中一样运行.这就是为什么你看到Sinatra在那个港口启动的原因.
使用CTRL-C停止此服务器时,Thin将尝试继续加载config.ru文件以确定要运行的应用程序.你实际上没有在你的应用中指定一个应用config.ru,所以你会看到类似的东西:
^C>> Stopping ...
== Sinatra has ended his set (crowd applauds)
/Users/matt/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/builder.rb:129:in `to_app': missing run or map statement (RuntimeError)
from config.ru:1:in `<main>'
...
Run Code Online (Sandbox Code Playgroud)
此错误只是告诉您实际上没有指定要在配置文件中运行的应用程序.
而不是SingingRain.run!,使用:
run SingingRain
Run Code Online (Sandbox Code Playgroud)
run是一种Rack方法,用于指定要运行的应用程序.你也可以这样做run SingingRain.new--Sinatra采取措施让你在这里只使用类本身或实例.
现在的输出应该只是:
>> Thin web server (v1.4.1 codename Chromeo)
>> Maximum connections set to 1024
>> Listening on 0.0.0.0:8000, CTRL+C to stop
Run Code Online (Sandbox Code Playgroud)
您没有收到== Sinatra/1.3.2 has taken the stage on 4567 for production with backup from Thin消息,因为Sinatra没有运行其内置服务器,它只是您配置它的瘦服务器.
| 归档时间: |
|
| 查看次数: |
7797 次 |
| 最近记录: |