Vagrant安装和使用
下载并安装程序
- 下载并安装virtualbox
https://www.virtualbox.org/wiki/Downloads - 下载并安装vagrant
https://www.vagrantup.com/downloads.html - 下载ubuntu/xenial64的box(注意选择的是Ubuntu 16.04 LTS 64位系统镜像,不要搞错了,后面换源的时候如果一个14.04的box使用16.04的源,会报错的
W: Unknown Multi-Arch type 'no' for package 'compiz-core'
的错误的,血的教训)- 访问https://app.vagrantup.com/ubuntu/boxes/xenial64
- 点击最新的版本,得到链接https://app.vagrantup.com/ubuntu/boxes/xenial64/versions/20180510.0.0
- 在尾部手动添加/providers/virtualbox.box补全下载链接,使用迅雷下载(更快)
https://app.vagrantup.com/ubuntu/boxes/xenial64/versions/20180510.0.0/providers/virtualbox.box
新建项目目录
vagrant
(随便啦,就是用来开发的项目目录),并将下载的box文件复制进来(不一定需要,只是为了方便后面操作的说明),之后的命令都是在这个目录下进行的
添加box
vagrant box add u14evm xenial-server-cloudimg-amd64-vagrant.box
命令
vagrant box add <boxName> <boxFilePath>
中:
<boxName>
为自己指定的box名字(默认为base)
<boxFilePath>
为下载的box文件本地路径
其他相关命令:
- 查看box列表:
vagrant box list
- 删除box:
vagrant box remove <boxName>
vagrant初次安装
- 初始化vagrant:
vagrant init u14evm
(u14evm
为<boxName>
),生成Vagrantfile
- 安装并启动虚拟机:
vagrant up
(第一次才是安装,之后就只是启动) - 登录:
vagrant ssh
这里第二步:
image.pngvagrant up
可能会出现Warning: Remote connection disconnect. Retrying...
或Warning: Authentication failure. Retrying...
这个错误,可能是自动登不上虚拟机。
打开virtualbox,看看安装的虚拟机的运行情况
image.png
发现是正常启动的,说明已经安装好了,只是无法自动登录。点击上图上面的显示,查看虚拟机的终端,如下图,需要登录
image.png
账号和密码都输入vagrant
,如下可以正常登录并使用了
image.png解决办法:改用私钥登录
vagrant ssh
默认通过vagrant
账号(密码也是vagrant
)登录虚拟机(查看virtualbox确保虚拟机是启动状态的)ssh-keygen -t rsa
生成rsa公私钥
image.pngcat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
将公钥添加到authorized_keys
文件里面
image.pngcat .ssh/id_rsa
查看私钥,并在目录新建一个文件id_rsa
将私钥复制进来
image.pngconfig.ssh.private_key_path = 'id_rsa'
编辑目录下的Vagrantfile
配置文件,加入此配置logout
登出虚拟机后,重新vagrant ssh
登录,可以正常登录了vagrant reload
重启,可以看到正常启动的状态了
image.png
如果上面第一步
image.pngvagrant ssh
没有密码登录,而是出现publickey密钥错误如下
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开发环境搭建
- 配置
Vagrantfile
# -*- 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
- 重启:
vagrant reload
- 执行脚本:
vagrant provision
其中setup.sh
脚本做了以下几件事:
- 换源
- 安装依赖
- 配置相应服务器软件 supervisor nginx redis 等
- 重启相应服务器软件 supervisor nginx 等
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地址,局域网的其他电脑可以通过这个地址访问虚拟机,如下
因为已经安装了nginx,默认是开启的,在主机的浏览器输入192.168.1.14
,即可访问到nginx服务