macOS下vagrant搭建本地web开发环境(CentOS)

  • macOS 10.13.6
  • VirtualBox 5.2.18
  • Vagrant 2.1.4
  • CentOS Linux release 7.5.1804 (Core)
目标:利用Vagrant创建CentOS虚拟机,并快速部署LNMP环境,调试本地代码。
1.安装Vagrant

下载VirtualBox 并安装
下载Vagrant 并安装

2.安装虚拟机

新建一个Vagrant操作目录,我这里叫centos,下载需要的box(即系统),Vagrant社区提供了很多已经打包好的系统。下载地址
找到需要的系统,会有介绍和安装方式

centos

$ mkdir centos
$ cd centos
$ vagrant init centos/7
$ vagrant up

下载比较慢,需翻墙,也可以下载到本地后再add,方式如下:

依然在终端运行$ vagrant init centos/7命令,但是在运行过程中会发现终端将box文件原地址打印了出来,见下图, 一出现该地址,按 ctrl + c 退出

centos地址

将下载的box放到centos目录下,并删除已经产生的Vagrantfile,执行
$ vagrant box add centos-7.box
$ vagrant init centos-7
$ vagrant up

目录下会生成Vagrantfile配置文件,修改配置文件可以实现虚拟机与本地的ip端口转发与数据共享。


Vagrant配置文件

通过$ vagrant -h查看常用的Vagrant命令,经常使用的有$ vagrant up启动虚拟机;$ vagrant reload 重启虚拟机;$ vagrant halt关闭虚拟机;$ vagrant ssh登录虚拟机,默认的虚拟机root密码是vagrant

Vagrant命令

3.部署web软件

自己部署NMP,或推荐个简单的工具——宝塔面板,可视化一键部署。
$ vagrant ssh
$ yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_pro.sh && sh install.sh
安装时会设置默认端口,我这里设置为8881,并会得到后台默认的账户名和密码。

宝塔面板安装完毕,配置ip端口转发,访问虚拟机宝塔面板的可视化页面,打开Vagrantfile,修改以下值:
guest是虚拟机上对应的端口,host是本机对应的端口,为了避免常用端口占用,虚拟机的80端口转发到本地的8880端口。

修改配置

配置完毕,$ vagrant reload 重启虚拟机。

浏览器打开 http://localhost:8881/ 就可以看到可视化面板了,软件管理中安装NMP等服务软件。

安装软件

安装完毕后,添加站点:

添加站点
添加站点

我这里用本地hosts www.test.com访问虚拟机中/www/wwwroot/test目录下的web主页,需要修改本地hosts,推荐软件SwitchHosts,添加一条规则并开启:

SwitchHosts

规则

OK,浏览器打开 www.test.com:8880 就可以看到宝塔面板的欢迎页了。

4.共享目录

修改 Vagrantfile 文件,


配置

参数含义:

config.vm.synced_folder
"your_folder"(必须) //物理机目录,可以是绝对地址或相对地址,相对地址是指相对与vagrant配置文件所在目录
,"vm_folder(必须)" // 挂载到虚拟机上的目录地址 ,create(boolean)--可选 //默认为false,若配置为true,挂载到虚拟机上的目录若不存在则自动创建
,disabled(boolean):--可选 //默认为false,若为true,则禁用该项挂载
,owner(string):'root'--可选 //虚拟机系统下文件所有者(确保系统下有该用户,否则会报错),默认为vagrant
,group(string):'root'--可选 //虚拟机系统下文件所有组( (确保系统下有该用户组,否则会报错),默认为vagrant
,mount_options(array):["dmode=775","fmode=664"]--可选 dmode配置目录权限,fmode配置文件权限 //默认权限777
,type(string):--可选 //指定文件共享方式,例如:'nfs',vagrant默认根据系统环境选择最佳的文件共享方式

重要:安装 vagrant-vbguest 插件实现目录实时共享:

这时如果直接$ vagrant reload重启会报错误:
Vagrant was unable to mount VirtualBox shared folders. This is usually because the filesystem "vboxsf" is not available. This filesystem is made available via the VirtualBox Guest Additions and kernel module. Please verify that these guest additions are properly installed in the guest. This is not a bug in Vagrant and is usually caused by a faulty Vagrant box. For context, the command attempted was: mount -t vboxsf -o uid=0,gid=0 www_wwwroot_test /www/wwwroot/test The error output from the command was: mount: unknown filesystem type 'vboxsf'

需要安装插件,网上一般的安装方式($ vagrant plugin install vagrant-vbguest)会因为墙的问题导致各种安装失败,切换国内的gem源安装:
$ gem update --system # gem更新到最新,需翻墙
$ gem sources --add https://gems.ruby-china.com/ --remove https://rubygems.org/ # 删除默认源,添加国内源,注意使用ruby-china.com新域名,原ruby-china.org源也需要删除重新设置
$ gem sources -l # 检查源,确保只有一个,多余需要删除
$ vagrant plugin install vagrant-vbguest --plugin-clean-sources --plugin-source [https://gems.ruby-china.com/](https://gems.ruby-china.com/) # 安装插件
$ vagrant reload # 重启虚机

重新登录虚机,$ vagrant ssh ,提权到root,$ su,测试本地test目录和虚机/www/wwwroot/test目录是否已经共享同步,配置完成。

推荐阅读更多精彩内容