Vagrant安装和使用

2018-05-11  本文已影响1779人  u14e

下载并安装程序


新建项目目录vagrant(随便啦,就是用来开发的项目目录),并将下载的box文件复制进来(不一定需要,只是为了方便后面操作的说明),之后的命令都是在这个目录下进行的

添加box


vagrant box add u14evm xenial-server-cloudimg-amd64-vagrant.box

image.png

命令vagrant box add <boxName> <boxFilePath>中:
<boxName>为自己指定的box名字(默认为base)
<boxFilePath>为下载的box文件本地路径

其他相关命令:

vagrant初次安装


这里第二步:vagrant up
可能会出现Warning: Remote connection disconnect. Retrying...Warning: Authentication failure. Retrying...这个错误,可能是自动登不上虚拟机。

image.png

打开virtualbox,看看安装的虚拟机的运行情况

image.png
发现是正常启动的,说明已经安装好了,只是无法自动登录。点击上图上面的显示,查看虚拟机的终端,如下图,需要登录
image.png
账号和密码都输入vagrant,如下可以正常登录并使用了
image.png

解决办法:改用私钥登录

  1. vagrant ssh 默认通过vagrant账号(密码也是vagrant)登录虚拟机(查看virtualbox确保虚拟机是启动状态的)
  2. ssh-keygen -t rsa 生成rsa公私钥
    image.png
  3. cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys 将公钥添加到authorized_keys文件里面
    image.png
  4. cat .ssh/id_rsa 查看私钥,并在目录新建一个文件id_rsa将私钥复制进来
    image.png
  5. config.ssh.private_key_path = 'id_rsa' 编辑目录下的Vagrantfile配置文件,加入此配置
  6. logout 登出虚拟机后,重新vagrant ssh登录,可以正常登录了
  7. vagrant reload重启,可以看到正常启动的状态了
    image.png

如果上面第一步vagrant ssh没有密码登录,而是出现publickey密钥错误如下

image.png
vagrant ssh-config查看配置,
image.png
是读取D:/vagrant/.vagrant/machines/default/virtualbox/private_key的私钥,但是根据https://github.com/hashicorp/vagrant/issues/9433上面说的,是因为没有那个文件的权限,以及win10系统ssh二进制包的问题,可以试试使用cmder试试。
如果还是不可以的话,那就只能先通过virtualbox使用vagrant账户登录,然后在里面生成公私钥,和前面2、3步一样配一下虚拟机的公钥,将私钥git push到远端,主机这边从远端拉下私钥,执行5、7步就可以了。
总之就是自己定义公私钥,然后想法设法让主机和虚拟机通过自己的公私钥交流

其他相关命令:
启动虚拟机:vagrant up(第一次是)
删除虚拟机:vagrant destroy
暂停虚拟机:vagrant suspend(推荐)
关闭虚拟机:vagrant halt (耗时不推荐)
恢复被暂停的虚拟机:vagrant resume
重启虚拟机:vagrant reload(每次改了Vagrantfile配置文件记得重启)
查看虚拟机状态:vagrant status
执行shell命令:vagrant provision(用于执行一键部署)

Vagrantfile把下面的shell脚本注释去掉,添加echo "hello world",保存并执行vagrant provision测试是否能够正常使用

config.vm.provision "shell", inline: <<-SHELL
    echo "hello world"
  SHELL
image.png

vagrant开发环境搭建

# -*- mode: ruby -*-
# vi: set ft=ruby :

Vagrant.configure("2") do |config|

  # 虚拟机名字<boxName>
  config.vm.box = "u14evm"

  # 指定私钥文件路径
  config.ssh.private_key_path = 'id_rsa'
  
  # 桥接网络
  config.vm.network "public_network"

  # 映射文件夹
  config.vm.synced_folder "./web/", "/var/www/web"

  # shell脚本
  config.vm.provision "shell", inline: <<-SHELL
    # 切换为root用户运行
    sudo su
    bash -ex /var/www/web/setup.sh
  SHELL
end

其中setup.sh脚本做了以下几件事:

setup.sh脚本

# 换源
ln -f -s /var/www/web/misc/sources.list /etc/apt/sources.list
mkdir -p /root/.pip
ln -f -s /var/www/web/misc/pip.conf /root/.pip/pip.conf

# 装依赖
apt-get update
apt-get -y install nginx

echo 'succsss'
echo 'ip'
hostname -I

misc/sources.list下写入ubuntu源(注意虚拟机的版本和源的版本一致)

# 默认注释了源码镜像以提高 apt update 速度,如有需要可自行取消注释
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-updates main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-updates main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-backports main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-backports main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-security main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-security main restricted universe multiverse

# 预发布软件源,不建议启用
# deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-proposed main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial-proposed main restricted universe multiverse

misc/pip.conf(清华的pip源)

[global]
index-url = https://pypi.tuna.tsinghua.edu.cn/simple/

通过setup.sh最后的hostname -I可以查看当前虚拟机的ip地址,局域网的其他电脑可以通过这个地址访问虚拟机,如下

image.png

因为已经安装了nginx,默认是开启的,在主机的浏览器输入192.168.1.14,即可访问到nginx服务

image.png

参考链接


上一篇下一篇

猜你喜欢

热点阅读