Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3279425
  • 博文数量: 515
  • 博客积分: 5116
  • 博客等级: 大校
  • 技术积分: 4137
  • 用 户 组: 普通用户
  • 注册时间: 2006-09-30 11:24
个人简介

黑马王子就是我! 技术认证:系统分析师,网络规划设计师,网络工程师,信息系统监理师,系统集成项目管理师,初级程序员,MCSE,MCDBA,CCNA 目前主攻虚拟化技术,VPN,系统架构,集群和高可用性等。

文章分类

全部博文(515)

文章存档

2023年(11)

2022年(17)

2021年(19)

2020年(28)

2019年(42)

2018年(53)

2017年(41)

2016年(33)

2015年(43)

2014年(25)

2013年(13)

2011年(6)

2010年(28)

2009年(47)

2008年(55)

2007年(26)

2006年(28)

分类: 服务器与存储

2019-08-09 10:21:44

下载并安装程序


  • 下载并安装virtualbox
  • 下载并安装vagrant
  • 下载ubuntu/xenial64的box(注意选择的是Ubuntu 16.04 LTS 64位系统镜像,不要搞错了,后面换源的时候如果一个14.04的box使用16.04的源,会报错的W: Unknown Multi-Arch type 'no' for package 'compiz-core'的错误的,血的教训
    1. 访问
    2. 点击最新的版本,得到链接
    3. 在尾部手动添加/providers/virtualbox.box补全下载链接,使用迅雷下载(更快)

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

添加box


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

image.png


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

其他相关命令:

  • 查看box列表:vagrant box list
  • 删除box:vagrant box remove

vagrant初次安装


  • 初始化vagrant:vagrant init u14evm(u14evm为),生成Vagrantfile
  • 安装并启动虚拟机:vagrant up(第一次才是安装,之后就只是启动)
  • 登录:vagrant ssh

这里第二步: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的私钥,但是根据上面说的,是因为没有那个文件的权限,以及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 
image.png

vagrant开发环境搭建

  • 配置Vagrantfile
# -*- 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 
  • 重启: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地址,局域网的其他电脑可以通过这个地址访问虚拟机,如下

image.png


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

image.png


参考链接




作者:u14e
链接:
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
阅读(1586) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~