37544 2016-09-28 10:36:12 11222次浏览 2条评论 10 1 0

相信大家对yii2已经相当熟悉了,但是你知道如何正确的打开yii2吗?

让我们先来看一下yii2的目录结构(高级模板):

这两个东西是干啥的呢?没错,这个就是大名鼎鼎的vagrant,用来统一我们的开发环境的神器!yii2已经为我们做了很多工作,现在我们只要做剩下的一点点安装和配置,就可以让我们的小伙伴们都用上统一的开发环境了。

1.安装vagrant、VirtualBox.

这个不是本文的重点,所以只简单介绍一下。安装vagrant只需要去它的官网下载最新的安装包即可,我用的是ubutnu 64位,所以下载的是debian 64 bit的安装包,双击安装包即可安装。virtualbox也一样,去官网下载对应平台的安装包即可。

2.添加ubuntu 14.04镜像:

vagrant box add ubuntu/trusty64

3.切换到yii2高级模板根目录下,启动环境:

注意:本来我们要先执行 "vagrant init ubuntu/trusty64"来初始化当前目录并生成一个Vagrantfile的配置文件的,不过我们现在已经有了这个文件,所以可以跳过这一步

cd /home/www/yourApp/
vagrant up

如你所见,会报错,因为我们的Vagrantfile里面使用了hostmanager这个插件,这个插件可以让我们使用y2aa.dev这样的域名访问我们的项目,而是不使用192.168.xx.xx之类的ip。让我们来安装这个插件:

vagrant plugin install vagrant-hostmanager

另外,我们需要打开 vagrant/config/vagrant-local.yml这个文件,填上你的github token,并把时区改为Asia/Shanghai:

你还可以设置虚拟机的cpu数量及内存等,如无特殊需求,建议使用默认值。

好了,再次执行vagrant up,应该能看到启动过程:

启动完成之后,在浏览器输入http://y2aa.dev (我做了点小修改以配合我的项目,下面会讲),应该能看到前台页面。

4.

你可以看到启动过程做了很多工作,配置网络、端口映射、安装/重启nginx、mysql、php等,这些都是通过Vagrantfile这个文件来实现的,让我们来看看这个文件!

require 'yaml'
require 'fileutils'
#这里配置前、后台的域名
domains = {
  frontend: 'y2aa.dev',
  backend:  'y2aa.dev/admin'
}
#配置文件的路径
config = {
  local: './vagrant/config/vagrant-local.yml',
  example: './vagrant/config/vagrant-local.example.yml'
}

# copy config from example if local config not exists
FileUtils.cp config[:example], config[:local] unless File.exist?(config[:local])
# read config
options = YAML.load_file config[:local]

# check github token
if options['github_token'].nil? || options['github_token'].to_s.length != 40
  puts "You must place REAL GitHub token into configuration:\n/yii2-app-advancded/vagrant/config/vagrant-local.yml"
  exit
end

# vagrant configurate
Vagrant.configure(2) do |config|
  # select the box.使用ubuntu14.04 64-bit
  config.vm.box = 'ubuntu/trusty64'

  # should we ask about box updates?
  config.vm.box_check_update = options['box_check_update']

  config.vm.provider 'virtualbox' do |vb|
    # machine cpus count
    vb.cpus = options['cpus']
    # machine memory size
    vb.memory = options['memory']
    # machine name (for VirtualBox UI)
    vb.name = options['machine_name']
  end

  # machine name (for vagrant console)
  config.vm.define options['machine_name']

  # machine name (for guest machine console)
  config.vm.hostname = options['machine_name']

  # network settings
  config.vm.network 'private_network', ip: options['ip']

  # sync: folder 'yii2-app-advanced' (host machine) -> folder '/app' (guest machine)
  #把当前目录同步到虚拟机的 /app 目录下面
  config.vm.synced_folder './', '/app', owner: 'vagrant', group: 'vagrant'

  # disable folder '/vagrant' (guest machine)
  config.vm.synced_folder '.', '/vagrant', disabled: true

  # hosts settings (host machine)
  # 使用hostmanager,把我们的前后台的域名绑定到虚拟机的ip上
  config.vm.provision :hostmanager
  config.hostmanager.enabled            = true
  config.hostmanager.manage_host        = true
  config.hostmanager.ignore_private_ip  = false
  config.hostmanager.include_offline    = true
  config.hostmanager.aliases            = domains.values

  # provisioners
  # 集成预安装,run: 'always' 设置成每次执行vagrant up启动环境都执行一次这个脚本,否则只在初次运行时执行。
  config.vm.provision 'shell', path: './vagrant/provision/once-as-root.sh', args: [options['timezone']]
  config.vm.provision 'shell', path: './vagrant/provision/once-as-vagrant.sh', args: [options['github_token']], privileged: false
  config.vm.provision 'shell', path: './vagrant/provision/always-as-root.sh', run: 'always'

  # post-install message (vagrant console)
  config.vm.post_up_message = "Frontend URL: http://#{domains[:frontend]}\nBackend URL: http://#{domains[:backend]}"
end

看来想要一些特殊服务,只能去修改./vagrant/provision/下面的三个脚本了,当然你也可以添加自己的脚本。

首先来看once-as-root.sh,以root身份运行一次,只在初次启动环境时执行,除非执行了"vagrant reload --provision"命令。这个脚本将会安装nginx、php、mysql,并进行配置。不懂shell命令也没关系,我们只要做一点点修改:

找到60行:

ln -s /app/vagrant/nginx/app.conf /etc/nginx/sites-enabled/app.conf

注意上面的路径都是虚拟机里面的路径。这个命令把 ./vagrant/nginx/app.conf软链接到了nginx的配置文件目录下面,所以我们只要修改./vagrant/nginx/app.conf就可以应用到虚拟机里面。

再找到64行:

info "Initailize databases for MySQL"
#mysql -uroot <<< "CREATE DATABASE yii2advanced"
#mysql -uroot <<< "CREATE DATABASE yii2_advanced_tests"
mysql -uroot <<< "CREATE DATABASE IF NOT EXISTS Your_db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_bin"
mysql -uroot -DYour_db_name < /app/vagrant/mysql/your.sql
echo "Done!"

把原来的创建数据库的命令注释掉,然后加上你自己的,你需要在 ./vagrant 目录下面建一个名为mysql的目录,用来存放sql文件。当然,有时候你不希望sql文件加入版本控制里面,你可以排除它。或者你们团队共享一个局域网里面的数据库,这时候就不用再创建数据库了,甚至连安装mysql都可以省了。如果不需要mysql,可以把相关的命令都注释掉。

其它两个脚本你也可以根据需要修改。

5.如果修改了Vagrantfile或 vagrant目录下面的脚本和配置而又不是初次运行,你需要执行一下命令:

vagrant reload --provision

6.很多博客都有介绍"vagrant package"命令打包配置好的虚拟机分发给其他人,我试了一下,打包的之后的大小大概500M。我不建议打包,一个是我们初始化的时候绑定了ip,还有就是如果更改了配置,又要重新打包分发。其实我们只要执行一下第5步的命令就可以使更改应用到虚拟机。

总结:从上面的可以看出来,只要你配置好了Vagrantfile及相关脚本,你的团队的其他人只要安装好vagrant、VirtualBox,然后进入项目根目录执行"vagrant up",就能获得统一的运行环境。ftp直连编程什么的,呵呵啊呵呵。

参考文章:

https://segmentfault.com/a/1190000000264347

http://www.oschina.net/translate/get-vagrant-up-and-running-in-no-time

觉得很赞
您需要登录后才可以评论。登录 | 立即注册