用户在其主目录中有 2 个 vagrant 项目。Mac 操作系统 10.8
第一个 vagrant 实例是几个月前创建的,当时用户运行的是旧版本 (1.1.x),第二个实例是使用 1.2.2 版本创建的。(因此 vagrant 文件语法略有不同)
问题是第一个实例(较旧的实例)启动,并在用户使用端口转发导航到 localhost:8080 时成功显示 apache 欢迎页面。http://docs.vagrantup.com/v2/networking/forwarded_ports.html
第二个实例不显示 apache 欢迎页面。
实例 1(工作)
Vagrant::Config.run do |config|
config.vm.box = "lucid32"
config.vm.provision :shell, :path => "bootstrap.sh"
config.vm.network :bridged
config.vm.forward_port 80, 8080
end
实例 2(不工作)
Vagrant.configure("2") do |config|
config.vm.box = "lucid32"
config.vm.network :forwarded_port, guest: 80, host: 8080
config.vm.network :public_network
config.vm.provision :puppet do |puppet|
puppet.manifests_path = "manifests"
puppet.manifest_file = "init.pp"
config.vm.hostname = 'salesforce'
end
end
我已经验证了以下内容:
两个实例都安装并运行了 apache2
我能够运行 curl localhost:8080 并检索 apache 测试页面的 html
我一次只运行 1 个实例以避免与端口 8080 冲突
两个实例都绑定到同一个网卡
什么可能会阻止端口转发在较新的 vagrant 实例上工作?
实例 1 被桥接,而另一个使用
:public_network
. 你能到达 :public_network 接口上的端口 22 吗?(我希望你删除了不安全的密钥和密码)。也许您还需要一个 :host_only 网络?
多亏了这个stackoverflow问题才弄明白。这是防火墙 https://stackoverflow.com/questions/5984217/vagrants-port-forwarding-not-working
验证是否在防火墙中为端口 80 打了一个洞(或者只是关闭 iptables)
验证 curl 是否能够从 vm 内部访问 apache 测试页面
最后验证Host是否可以通过curl访问页面