黑马王子就是我! 技术认证:系统分析师,网络规划设计师,网络工程师,信息系统监理师,系统集成项目管理师,初级程序员,MCSE,MCDBA,CCNA 目前主攻虚拟化技术,VPN,系统架构,集群和高可用性等。
全部博文(515)
分类: 服务器与存储
2019-08-09 10:21:44
新建项目目录vagrant(随便啦,就是用来开发的项目目录),并将下载的box文件复制进来(不一定需要,只是为了方便后面操作的说明),之后的命令都是在这个目录下进行的
vagrant box add u14evm xenial-server-cloudimg-amd64-vagrant.box
命令vagrant box add
中:
为自己指定的box名字(默认为base)
为下载的box文件本地路径
其他相关命令:
这里第二步:vagrant up
可能会出现Warning: Remote connection disconnect. Retrying...或Warning: Authentication failure. Retrying...这个错误,可能是自动登不上虚拟机。
打开virtualbox,看看安装的虚拟机的运行情况
发现是正常启动的,说明已经安装好了,只是无法自动登录。点击上图上面的显示,查看虚拟机的终端,如下图,需要登录
账号和密码都输入vagrant,如下可以正常登录并使用了
解决办法:改用私钥登录
- vagrant ssh 默认通过vagrant账号(密码也是vagrant)登录虚拟机(查看virtualbox确保虚拟机是启动状态的)
- ssh-keygen -t rsa 生成rsa公私钥
- cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys 将公钥添加到authorized_keys文件里面
- cat .ssh/id_rsa 查看私钥,并在目录新建一个文件id_rsa将私钥复制进来
- config.ssh.private_key_path = 'id_rsa' 编辑目录下的Vagrantfile配置文件,加入此配置
- logout 登出虚拟机后,重新vagrant ssh登录,可以正常登录了
- vagrant reload重启,可以看到正常启动的状态了
如果上面第一步vagrant ssh没有密码登录,而是出现publickey密钥错误如下
vagrant ssh-config查看配置,
是读取D:/vagrant/.vagrant/machines/default/virtualbox/private_key的私钥,但是根据上面说的,是因为没有那个文件的权限,以及win10系统ssh二进制包的问题,可以试试使用试试。
如果还是不可以的话,那就只能先通过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
# -*- mode: ruby -*- # vi: set ft=ruby : Vagrant.configure("2") do |config| # 虚拟机名字 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地址,局域网的其他电脑可以通过这个地址访问虚拟机,如下
因为已经安装了nginx,默认是开启的,在主机的浏览器输入192.168.1.14,即可访问到nginx服务