Vagrant上的Rails 4.2服务器端口转发不起作用
Posted
技术标签:
【中文标题】Vagrant上的Rails 4.2服务器端口转发不起作用【英文标题】:Rails 4.2 Server port forwarding on Vagrant does not work 【发布时间】:2015-03-04 03:43:54 【问题描述】:我有一个安装了 Rails 的 Vagrant VM 和示例应用程序。虚拟机配置为将端口 3000(Rails Webrick 服务器的)转发到我的主机 3000 端口。
config.vm.network "forwarded_port", guest: 3000, host: 3000
所有的配置都如许多示例所示。
但是,当我尝试访问 http://localhost:3000
时,什么也没有发生。我也尝试转发到其他随机端口,如 8081、25600,但没有成功。执行 curl 请求也不会得到任何东西(只是 Connection reset by peer 消息),并且 VM 内部的 curl 请求可以完美运行(如预期的那样)。
我的 PC 和我的虚拟机都运行 Ubuntu 12.04。我正在使用 Ruby 2.2.0 和 Rails 4.2.0。
重要的一点是 Apache 可以正常工作。我将端口 80 转发到端口 8080,一切正常。似乎问题出在 Rails 服务器上,即使我使用其他端口(例如rails server -p 4000
)
【问题讨论】:
【参考方案1】:在这里找到非常好的解释:Rails 4.2.0.beta2 - Can't connect to LocalHost?
我遇到了完全相同的问题,只是我的 PC 是 Mac 机器。我已经使用这个 vagrantfile 来让它工作(使用 virtualbox 4.3.36)
# -*- mode: ruby -*-
# vi: set ft=ruby :
VAGRANTFILE_API_VERSION = "2"
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
# Use Ubuntu 14.04 Trusty Tahr 64-bit as our operating system
config.vm.box = "ubuntu/trusty64"
# Configurate the virtual machine to use 2GB of RAM
config.vm.provider :virtualbox do |vb|
vb.customize ["modifyvm", :id, "--memory", "2048"]
end
config.vm.provision "shell", inline: <<-SHELL
## Install necessary dependencies
sudo apt-get --assume-yes install libsqlite3-dev libcurl4-openssl-dev git
## Install GPG keys and download rvm, ruby and rails
curl -sSL https://rvm.io/mpapis.asc | gpg --import -
curl -L https://get.rvm.io | bash -s stable --ruby
curl -L https://get.rvm.io | bash -s stable --rails
echo "[[ ls \"$HOME/.rvm/scripts/rvm\" ]] && . \"$HOME/.rvm/scripts/rvm\"" >> ~/.profile
## Adding vagrant user to the group that can access rvm
usermod -G rvm vagrant
SHELL
# Forward the Rails server default port to the host
config.vm.network :forwarded_port, guest: 3000, host: 3000
end
在虚拟机启动并运行后,我将在我的项目存储库中运行bundle install
,然后运行rails server -b 0.0.0.0
。
正如上面链接的答案中指出的那样:
127.0.0.1:3000 将只允许来自该地址在端口 3000 上的连接,而 0.0.0.0:3000 将允许来自任何地址的连接 端口 3000。
由于 Rails 4.2 默认只接受来自 localhost 的连接, 您只能从本地主机访问服务器(例如,在虚拟机内部); 来自另一台机器(例如 VM 的主机)的连接将无法正常工作。
【讨论】:
【参考方案2】:使用:
rails s -b 0.0.0.0
或
添加到config/boot.rb
:
require 'rails/commands/server'
module Rails
class Server
new_defaults = Module.new do
def default_options
default_host = Rails.env == 'development' ? '0.0.0.0' : '127.0.0.1'
super.merge( Host: default_host )
end
end
# Note: Module#prepend requires Ruby 2.0 or later
prepend new_defaults
end
end
并与rails s
合作
【讨论】:
您的第二个解决方案很棒,谢谢!使用 Rails 5.0.1【参考方案3】:您可以使用别名,在 Ubuntu 上将其放入 ~/.bash_aliases
我使用:alias rs="rails server -b 0.0.0.0"
您必须重新加载终端才能使用它
【讨论】:
【参考方案4】:在特定端口上运行:
rails server -b 0.0.0.0 -p 8520
【讨论】:
【参考方案5】:Rails 4.2 现在默认绑定到127.0.0.1
,而不是0.0.0.0
。
使用bin/rails server -b 0.0.0.0
启动服务器,它应该对其进行排序。
【讨论】:
我会的!在 VM 内时,每台服务器都应该使用 0.0.0.0 吗?我不知道... 不,这不是最安全的方法。 0.0.0.0 只是意味着监听任何地址。更改意味着它将仅响应来自 VM 的请求,而不是您的主机。这对开发来说很好,不要在生产中这样做。 我也遇到了同样的问题。您对设置生产环境有什么建议?是否应该绑定特定的 IP 轨道? 你不应该在生产中使用 webbrick,它只是为开发而设计的。 谢谢!使用 php Cake 3.X 有这个问题,这个解决了!以上是关于Vagrant上的Rails 4.2服务器端口转发不起作用的主要内容,如果未能解决你的问题,请参考以下文章