本文将帮助您了解如何使用 Vagrant 来管理虚拟机实例,并解释如何利用 Puppet 来配置各种资源,例如 PHP 和 PostgreSQL。
开发人员有多种方法来构建他们的 Web 开发环境。
开发人员有多种方法来构建他们的 Web 开发环境。您可以使用“本地”选项,例如安装预构建的“一体化”服务器堆栈,例如 Zend Server、XAMPP、MAMP、WAMP 等,或者您可以从源代码自行安装组件,或者通过软件包管理系统,例如 Homebrew、Apt 和 Yum。
当您使用 PHP 5.3 和 PHP 5.4、MySQL、SQLite、MongoDB、Postgres、PEAR、PHPUnit、Rails 3.1、Memcached、Redis、Gearman、NodeJS 等处理各种项目时,这可能会逐渐增加。如果您升级或你的电脑死机了,你将不得不重新开始。
您可以使用网络上具有 Samba 共享的服务器或使用 ExpanDrive 等工具安装的 SSH 服务器进行“远程”设置。后一个选项可能会导致文件读/写延迟,这非常烦人。您可以使用 SSH + Vim 来完成所有事情,这很快,但只有当您想使用 Vim 来完成所有事情时才有效。
虽然您可能对现在的工作方式感到满意,但有多少人听说过(或说过)“它在我的计算机上运行得很好”。这种情况非常常见,当环境存在差异时,即使是最微不足道的细节也会发生这种情况。
确保您的开发环境与生产环境相同,并与临时和测试服务器相匹配(如果您也有的话)非常重要。
如果您只考虑安装 Apache、PHP 和 MySQL 的一些副本,这听起来可能很简单,但有一百万个因素需要考虑。如果您在 OSX 上进行开发并部署到 Ubuntu 系统,那么您会注意到文件大小写的有趣问题。当有人拥有首字母小写的库时,这在 CodeIgniter 中很常见。它可以在 OSX 上正常加载,但在部署到生产环境时会崩溃。您的开发过程可能只是让您失去了一些业务,这一切都是因为一些微不足道的操作系统差异,没有人意识到,直到为时已晚。
强迫开发人员使用相同的操作系统会导致问题。
那么解决办法是什么呢?迫使所有开发人员放弃不同的工具并在完全相同型号的笔记本电脑上进行开发?如果您的开发人员都使用全新的 Macbook,那么您可能不会收到太多投诉,但您需要使用 OSX Server 来完成所有工作。
你可以使用 Linux 来做所有事情,但是你必须为使用哪个发行版而争论。强迫开发人员使用相同的操作系统会导致问题、降低生产力并促进书呆子之间的争斗。
虚拟化就是答案,这并不是什么新鲜事,但是当人们想到虚拟化时,他们经常会想到性能问题,他们的风扇会疯狂旋转,而他们的笔记本电脑会拼命地尝试运行两个操作系统。
尝试在低功耗机器上运行 Windows 时仍然会遇到这种情况,但如今,普通 Mac 开箱即用有 4 GB RAM,这足以为运行在 Windows 上的 Ubuntu 服务器安装提供动力。命令行模式和所有常用的开发工具(IDE、浏览器、调试工具等)。虚拟化有几个选项,但我更喜欢 Oracle 的 VirtualBox(免费)。该软件完成了虚拟化的所有繁重工作,然后由一个名为 Vagrant 的工具来管理实例。
首先下载VirtualBox并安装它。在 *nix 系统(Mac OSX、Linux 等)上,您需要修改 .bash_profile
(或 .zsh_profile)以扩展 $PATH
变量:
PATH=$PATH:/Applications/VirtualBox.app/Contents/MacOS/ export PATH
这将使 Vagrant 知道 VirtualBox 的安装位置,当然,不同的操作系统会有所不同。
您可以下载适用于您的操作系统的 vagrant 版本,或者如果不可用,则将其安装为 gem:
$ gem install vagrant
为你的 vagrant 设置提供一个生存的地方:
mkdir -p ~/Vagrant/test cd ~/Vagrant/test
我们将使用 Ubuntu 12.04 LTS(Precise Pangolin),它已经设置了一个“盒子”。
vagrant box add precise32 http://files.vagrantup.com/precise32.box
您可以在此处看到参数“precise32”,它是 URL 的昵称。您现在可以创建一个实例,该实例将下载此 .box。
vagrant init precise32 vagrant up
它现在将运行。简单的!如果您想通过 SSH 进入此实例,请使用以下命令:
vagrant ssh
您将有一个名为 Vagrantfile
的文件,其中包含此实例的配置:
# -*- mode: ruby -*- # vi: set ft=ruby : Vagrant::Config.run do |config| config.vm.box = "precise32" config.vm.box_url = "http://files.vagrantup.com/precise32.box" # Assign this VM to a host-only network IP, allowing you to access it # via the IP. Host-only networks can talk to the host machine as well as # any other machines on the same network, but cannot be accessed (through this # network interface) by any external networks. config.vm.network :hostonly, "192.168.33.10" # Set the default project share to use nfs config.vm.share_folder("v-web", "/vagrant/www", "./www", :nfs => true) config.vm.share_folder("v-db", "/vagrant/db", "./db", :nfs => true) # Forward a port from the guest to the host, which allows for outside # computers to access the VM, whereas host only networking does not. config.vm.forward_port 80, 8080 # Set the Timezone to something useful config.vm.provision :shell, :inline => "echo \"Europe/London\" | sudo tee /etc/timezone && dpkg-reconfigure --frontend noninteractive tzdata" # Update the server config.vm.provision :shell, :inline => "apt-get update --fix-missing" # Enable Puppet config.vm.provision :puppet do |puppet| puppet.facter = { "fqdn" => "local.pyrocms", "hostname" => "www" } puppet.manifests_path = "puppet/manifests" puppet.manifest_file = "ubuntu-apache2-pgsql-php5.pp" puppet.module_path = "puppet/modules" end end
如果您没有注意到,这是 Ruby 语法;这样您就可以对该文件发挥相当大的创意,但这是基础知识。
它将显示要使用的昵称并具有 URL,以防本地未设置昵称(适合共享)。
share_folder
行对于将实例中的文件夹映射到本地文件夹非常有用。使用 nfs => true
实例将能够写入和更改文件的权限,这在您尝试在其中安装 CMS 等情况时非常有用。
端口转发允许您访问 http://localhost:8080
上的实例,当然,如果发生冲突,请将其更改为其他端口。
此配置文件还将时区设置为欧洲/伦敦,然后运行 apt-get update
,这将强制您的系统在启动时保持最新状态。如果您跳过此配置项,您可能会发现多个软件包拒绝安装,因为参考现已过时。
当您更改配置时,您可以重新加载实例来使用它:
vagrant reload
现在我们的服务器已经运行并准备就绪,我们需要安装一些软件。我们不仅仅要通过命令行 apt-get install
一堆软件包,我们还要“配置”我们的服务器。
服务器配置并不是许多开发人员需要考虑的问题。
服务器配置并不是许多开发人员需要考虑的事情,因为它通常留给系统管理员。这个想法是对服务器上的软件和配置进行一些记录,以便您可以创建新的开发环境、复制生产的新登台服务器,或者创建另一个生产服务器以在两者之间进行负载平衡。
系统管理员处理这个问题的方式各不相同,但过去已经使用过各种解决方案 - 从保持命令维基运行(它可能会很快变得庞大和过时)到拥有“多终端”的绝佳方法,您在一个窗口中输入命令,它会同时在另外 7 台服务器上复制相同的命令。 这些方法都很糟糕。
一种解决方案是构建您自己的 .box
文件,或创建 .iso
备份,以便新服务器可以基于此,但维护这些图像会产生大量额外的工作,而且无论多么困难你尝试一下,随着时间的推移,这些开发机器将会变得不同步。
目前有两种流行的系统,称为 Puppet 和 Chef。
目前有两种流行的系统,称为 Puppet 和 Chef。两者都已存在多年,但随着 DevOps 开发方法的增加而开始变得更加流行。两者的想法相似,您应该研究这两个系统,但本教程将专门关注 Puppet。
本质上,您不必运行一堆命令并希望一切正常,而是为 Puppet 构建一个清单,解释您需要确保已完成的所有内容。当您在终端中运行命令时,您基本上是在对计算机说:
“安装 Apache”
对于 Puppet,我们会说:
“确保 Apache 已安装”
或者,代替:
“创建一个新文件夹,名为
/var/www
并设置 www-data:www-data 的权限”
对于 Puppet,我们会说:
“确保
/var/www
存在并且具有与 www-data:www-data 匹配的权限”
这里的区别在于,这些清单可以运行多次(在 cron 作业中每小时或每天)以保持最新状态,并且尝试安装两次不会出现意外结果。
它还将帮助您测试一切是否按预期运行,因为任何规则失败都会引发错误,这些错误比 grep 大量 bash 命令结果更容易跟踪。 Puppet 会抛出大红色错误,让您知道 PHP 没有安装,或者无法配置特定模块。
清单一开始有点令人困惑,但过了一段时间,它们就开始有意义了。
查看一个基本示例:
file {'testfile': path => '/tmp/testfile', ensure => present, mode => 0640, content => "I'm a test file.", }
无需解释这里发生了什么,对吧?
此文件稍后可以在清单中称为“testfile”,这意味着它可以被列为其他操作的依赖项。
有关更多示例,我们将参考 GitHub 上的 PyroCMS Puppet 清单。
include apache $docroot = '/vagrant/www/pyrocms/' $db_location = "/vagrant/db/pyrocms.sqlite" # Apache setup class {'apache::php': } apache::vhost { 'local.pyrocms': priority => '20', port => '80', docroot => $docroot, configure_firewall => false, } a2mod { 'rewrite': ensure => present; }
这包括“apache”模块,设置一些变量,在 apache 模块中运行额外的“apache::php”清单,设置虚拟主机,然后确保启用“mod_rewrite”。
所有这些类都在我们包含的 Apache 模块中定义。
继续,我们还想安装 PHP:
include php php::module { ['xdebug', 'pgsql', 'curl', 'gd'] : notify => [ Service['httpd'], ], } php::conf { [ 'pdo', 'pdo_pgsql']: require => Package['php5-pgsql'], notify => Service['httpd'], }
这块清单将安装我们需要的 PHP 扩展,然后 notify
选项会让 Apache 知道您已经安装了新配置,这意味着它将重新启动。
include postgresql class {'postgresql::server': } postgresql::db { 'pyrocms': owner => 'pyrocms', password => 'password', }
这将设置一个 postgres 服务器,创建一个名为“pyrocms”的数据库,并确保名为“pyrocms”的用户存在并提供密码。
快完成了!最后一步是确保您正确设置了可写文件和文件夹:
file { $docroot: ensure => 'directory', } file { "${docroot}system/cms/config/config.php": ensure => "present", mode => "0666", require => File[$docroot], } $writeable_dirs = ["${docroot}system/cms/cache/", "${docroot}system/cms/config/", "${docroot}addons/", "${docroot}assets/cache/", "${docroot}uploads/"] file { $writeable_dirs: ensure => "directory", mode => '0777', require => File[$docroot], }
这将确保 Apache 文档根目录存在,配置文件设置为 0666,一些可写文件夹设置为 777。
我们有了!
要运行所有这些,只需重新启动 vagrant 实例,或运行:
vagrant provision
如果一切正常,您应该会看到很多蓝色文本,表明一切都正在安装,但是,如果出现问题,您会看到红色。 Google 搜索这些错误,然后重试。
这里使用的模块是:Apache、Postgres、PHP,您可以通过克隆 PyroCMS Vagrant 存储库来查看整个操作:
git clone --recursive git://github.com/pyrocms/devops-vagrant.git ~/vagrant/pyrocms cd ~/vagrant/pyrocms vagrant up
将浏览器指向 http://localhost:8089/
,您应该会看到安装程序。很简单的事情,是吧?
注意:这将与 MySQL 一起安装,因为 PyroCMS 的 Postgres 和 SQLite 支持仍在开发中,等待某些 CodeIgniter PDO 功能完成。如果您有兴趣,可以通过更改 Vagrantfile 来尝试使用 ubuntu-apache2-pgsql-php5.pp
清单,销毁实例,然后再次启动它。 Pyrocms 子模块还需要签出到 feature/pdo
在本文中,我们使用 Vagrant、VirtualBox 和 Puppet 不仅设置了一个可供我们使用的服务器实例,而且还为我们的服务器创建了一个测试套件,以确保一切都正确运行、安装和配置。
我们还创建了一份需求清单,并且将来能够在几分钟而不是几小时内创建任意数量的相同服务器!
以上是探索 Vagrant:了解其目的、好处和实施的详细内容。更多信息请关注PHP中文网其他相关文章!