我正在首次测试Vagrant中的共享选项,而我正在Windows 7 Ultimate SP1 32-bit
主机上的新Laravel Homestead VM配置的Virtualbox提供程序上进行测试。
我使用MINGW32
作为shell,我禁用了Windows防火墙(域,本地和公共),以确保不会影响我的操作。
Vagrant无法自动找到HTTP端口,所以我指定它
如果我运行以下命令一切顺利:
MINGW32 ~/Vagrant/Homestead ((v6.2.2))
$ vagrant share --http 8000
Vagrant Share now defaults to using the `ngrok` driver.
The `classic` driver has been deprecated.
For more information about the `ngrok` driver, please
refer to the documentation:
https://www.vagrantup.com/docs/share/
==> homestead-7: Detecting network information for machine...
homestead-7: Local machine address: 127.0.0.1
homestead-7:
homestead-7: Note: With the local address (127.0.0.1), Vagrant Share can only
homestead-7: share any ports you have forwarded. Assign an IP or address to your
homestead-7: machine to expose all TCP ports. Consult the documentation
homestead-7: for your provider ('virtualbox') for more information.
homestead-7:
homestead-7: Local HTTP port: 8000
homestead-7: Local HTTPS port: disabled
homestead-7: Port: 2222
homestead-7: Port: 27017
homestead-7: Port: 33060
homestead-7: Port: 44300
homestead-7: Port: 54320
homestead-7: Port: 8000
homestead-7: Port: 8025
==> homestead-7: Creating Vagrant Share session...
==> homestead-7: HTTP URL: http://3bbh648b.ngrok.io
==> homestead-7:
但是以下命令失败:
MINGW32 ~/Vagrant/Homestead ((v6.2.2))
$ vagrant share --http 8000 --ssh
Vagrant Share now defaults to using the `ngrok` driver.
The `classic` driver has been deprecated.
For more information about the `ngrok` driver, please
refer to the documentation:
https://www.vagrantup.com/docs/share/
==> homestead-7: Detecting network information for machine...
homestead-7: Local machine address: 127.0.0.1
homestead-7:
homestead-7: Note: With the local address (127.0.0.1), Vagrant Share can only
homestead-7: share any ports you have forwarded. Assign an IP or address to your
homestead-7: machine to expose all TCP ports. Consult the documentation
homestead-7: for your provider ('virtualbox') for more information.
homestead-7:
==> homestead-7: Generating new SSH key...
homestead-7: Please enter a password to encrypt the key:
Error! Your console doesn't support hiding input. We'll ask for
input again below, but we WILL NOT be able to hide input. If this
is a problem for you, ctrl-C to exit and fix your stdin.
homestead-7: Please enter a password to encrypt the key: test
homestead-7: Repeat the password to confirm:
Error! Your console doesn't support hiding input. We'll ask for
input again below, but we WILL NOT be able to hide input. If this
is a problem for you, ctrl-C to exit and fix your stdin.
homestead-7: Repeat the password to confirm: test
homestead-7: Inserting generated SSH key into machine...
homestead-7: Local HTTP port: 8000
homestead-7: Local HTTPS port: disabled
homestead-7: SSH Port: 2222
homestead-7: Port: 2222
homestead-7: Port: 27017
homestead-7: Port: 33060
homestead-7: Port: 44300
homestead-7: Port: 54320
homestead-7: Port: 8000
homestead-7: Port: 8025
==> homestead-7: Creating Vagrant Share session...
C:/Program Files/HashiCorp/Vagrant/embedded/mingw32/lib/ruby/2.3.0/socket.rb:61:in `connect_internal': A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond. - user specified timeout (Errno::ETIMEDOUT)
from C:/Program Files/HashiCorp/Vagrant/embedded/mingw32/lib/ruby/2.3.0/socket.rb:139:in `connect'
from C:/Program Files/HashiCorp/Vagrant/embedded/mingw32/lib/ruby/2.3.0/socket.rb:636:in `block in tcp'
from C:/Program Files/HashiCorp/Vagrant/embedded/mingw32/lib/ruby/2.3.0/socket.rb:231:in `each'
from C:/Program Files/HashiCorp/Vagrant/embedded/mingw32/lib/ruby/2.3.0/socket.rb:231:in `foreach'
from C:/Program Files/HashiCorp/Vagrant/embedded/mingw32/lib/ruby/2.3.0/socket.rb:626:in `tcp'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-share-1.1.9/lib/vagrant-share/activate.rb:304:in `acquire_port'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-share-1.1.9/lib/vagrant-share/activate.rb:312:in `acquire_port'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-share-1.1.9/lib/vagrant-share/activate.rb:2360:in `block in start_share'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-2.0.0/lib/vagrant/plugin/v2/command.rb:235:in `block in with_target_vms'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-2.0.0/lib/vagrant/plugin/v2/command.rb:229:in `each'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-2.0.0/lib/vagrant/plugin/v2/command.rb:229:in `with_target_vms'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-share-1.1.9/lib/vagrant-share/activate.rb:2273:in `start_share'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-share-1.1.9/lib/vagrant-share/activate.rb:2967:in `execute'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-2.0.0/lib/vagrant/cli.rb:42:in `execute'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-2.0.0/lib/vagrant/environment.rb:308:in `cli'
from C:/Program Files/HashiCorp/Vagrant/embedded/gems/gems/vagrant-2.0.0/bin/vagrant:138:in `<main>'
我的Homestead.yml
文件是:
---
ip: "192.168.10.10"
memory: 2048
cpus: 1
provider: virtualbox
authorize: ~/.ssh/id_rsa.pub
keys:
- ~/.ssh/id_rsa
folders:
- map: ~/Documents/web/laravel
to: /home/vagrant/Code
sites:
- map: homestead.app
to: /home/vagrant/Code/blog/public
databases:
- homestead
# blackfire:
# - id: foo
# token: bar
# client-id: foo
# client-token: bar
# ports:
# - send: 50000
# to: 5000
# - send: 7777
# to: 777
# protocol: udp
我可以ping 192.168.10.10
我正在使用Vagrant version 2.0.0
和Virtualbox version 5.1.28 r117968 (Qt5.6.2)
。
我试图转到文件C:/Program Files/HashiCorp/Vagrant/embedded/mingw32/lib/ruby/2.3.0/socket.rb
的第61行,值local_addrinfo
的输出为空。我也尝试增加变量timeout
的值,但我没有运气
你能帮我解决一下这个问题吗?我不确定它是否依赖于Windows,MINGW32,Vagrant,Virtualbox或Laravel Homestead。
答案 0 :(得分:1)
修改 - 看起来Windows上当前版本的vagrant share
存在一个错误。尝试扫描开放端口以进行共享时,Vagrant会抛出问题中的错误:当测试每个端口时,Vagrant会尝试打开套接字连接,并且因为没有任何内容侦听可用端口,所以Ruby会尽职尽责地抛出错误。
解决方法 - 我们可以手动调用 ngrok ,这是Vagrant用来配置共享的工具:
ngrok authtoken <your-token>
ngrok tcp 2222
(其中2222
是您的VM的转发SSH端口)ssh -p <ngrok-port> vagrant@<ngrok-hostname>
为了说明,如果隧道URL看起来像 tcp://0.tcp.ngrok.io:55555 ,我们将使用以下SSH命令:
ssh -p 55555 vagrant@0.tcp.ngrok.io