这是earlier question的后续问题。我使用了相同的Vagrant文件,但已经注释掉了我认为不必要的两行。
我试图在不使用vagrant ssh
的情况下进入我的Vagrant盒子。下面是我的Vagrantfile和ssh配置信息:
Vagrantfile:
Vagrant.configure(2) do |config|
config.vm.provider "virtualbox" do |v|
v.memory = 6144
v.cpus = 2
v.name = "mb_vagrant"
end
config.vm.box = "ubuntu/trusty64"
config.vm.network :private_network, ip: "192.168.33.10"
config.ssh.forward_agent = true
# config.vm.provision :shell, path: "bootstrap.sh"
# config.vm.network :forwarded_port, host: 8001, guest: 8001
end
vagrant ssh-config
的输出:
Host default
HostName 127.0.0.1
User vagrant
Port 2222
UserKnownHostsFile /dev/null
StrictHostKeyChecking no
PasswordAuthentication no
IdentityFile "/Users/mbigras/Google Drive/tmp/chef-repo/.vagrant/machines/default/virtualbox/private_key"
IdentitiesOnly yes
LogLevel FATAL
ForwardAgent yes
我已使用以下命令尝试ssh
进入我的机器:
$ ssh -i "/Users/mbigras/Google Drive/tmp/chef-repo/.vagrant/machines/default/virtualbox/private_key" -p 2222 vagrant@192.168.33.10
ssh: connect to host 192.168.33.10 port 2222: Connection refused
另外,根据another answer中描述的解决方案,我尝试在尝试连接之前删除~/.ssh/known_hosts
;但是,它也不起作用:
$ rm ~/.ssh/known_hosts
$ ssh -i "/Users/mbigras/Google Drive/tmp/chef-repo/.vagrant/machines/default/virtualbox/private_key" -p 2222 vagrant@192.168.33.10
ssh: connect to host 192.168.33.10 port 2222: Connection refused
我在这里缺少什么?
答案 0 :(得分:3)
Ssh服务绑定到来宾计算机(即: 127.0.0.1 )端口 2222 ,但在VM中仍在侦听端口22(如默认端口)。 因此,您应该在 127.0.0.1 上的 192.168.33.10 或 2222 上连接 22 端口。即:
$ ssh -i "<vagranfile-path>/.vagrant/machines/default/virtualbox/private_key" \
-p 22 vagrant@192.168.33.10
或
$ ssh -i "<vagranfile-path>/.vagrant/machines/default/virtualbox/private_key" \
-p 2222 vagrant@127.0.0.1
此外,不需要删除~/.ssh/known_hosts
文件。添加以下选项将避免主机指纹检查:-o UserKnownHostsFile=/dev/null