Vagrant 支持多个虚拟机、多个操作系统的混合使用,并且可以通过 YAML 文件进行简单配置,还可以使用 Ansible provisoner 进行配置
流浪者- YAML- Ansible
首先
在Vagrantfile的设置中,当涉及到多个虚拟机和不同的客户操作系统(如Windows和CentOS)时,变得更加复杂。因此,我对Vagrantfile进行了自定义,使其从YAML文件中读取每个客户虚拟机的独立设置。
验证环境
主机正在使用OSX进行验证,但只要Vagrantfile在能运行Ruby环境的情况下,且提供者(即虚拟化软件)是VirtualBox,应该就能正常工作。
样本代码
代码包括样本已经上传到以下的github,请在使用时参考。
https://github.com/tbuchi888/vagrant-yaml-ansibleを参照するか
git clone https://github.com/tbuchi888/vagrant-yaml-ansible.gitしてください。
特点
-
- VagrantのゲストVMに関する設定をYAMLで定義できます。
-
- 複数VM、複数OS(Windows,CentOSなど)混在に対応できます。
- Ansible provisionerを利用できます。
确认动作环境
-
- Host
Mac OSX Yosemite
VirtualBox 5.0.16
Vagrant 1.8.1
Ansible 2.1.0
ruby 2.0.0p481
GuestVM
CentOS 6
WinowsServer2012R2
使用方法
-
- サンプルを参考にゲストVMの情報(ホスト名やIPアドレスなど)をYAML形式で書いてconf-vbox-guestvm.ymlとしてVagrantfileと同じディレクトリへ置いてください。
Vagrantfileをgithubからダウンロードしたカスタマイズ版と置き換えてください。
Ansible provisionerを使う場合は、playbookやinventoryファイルなどをconf-vbox-guestvm.ymlに記載のパスに置いてください。
Vagrant upなどコマンドは通常のVagrantと同じように使えます。
複数VM時のvagrantコマンドはこちらの記事
を参考にしてください。
YAML 样本
由于是YAML格式,基本信息如BOX名称等可以像这篇文章中一样进行映射合并等操作:YAML 支持合并映射等功能。
# Define the set value of guestvm in YAML format.
# You can either create a yml file in the current directory, Or "str" described variable.
# (*):The fields are required.
#---
#guestvm:
# - name: * Set the guest VM's name . It is use hostname and Vagrant nodename
# box: * Set the guest VM's box name'.
# box_url: Set the guest VM's box url or path.
# ipaddress: Set the guest VM's ipaddress. If not set ignore template's used.
# os_type: * Set the guest VM's OS of the guest VM in 'windows' or 'linux'.
# os_username: Set the guest VM's OS username for ssh or WinRM. If not set ignore.
# os_password: Set the guest VM's OS password for ssh or WinRM. If not set ignore.
# ansible_playbook: Set the playbook name of Ansible to use provisioning. If not set ignore.
# ansible_inventory_path: Set the inventory file path of Ansible to use provisioning. If not set ignore.
#
#
---
win_base: &WIN_BASE
box: win-2012r2-standard-amd64-nocm-mod
os_type: windows
os_username: vagrant
os_password: vagrant
centos_base: &CENT_BASE
box: geerlingguy/centos6
os_type: linux
guestvm:
- name: win2012-iis01
ipaddress: 192.168.33.51
ansible_playbook: win2012_feature_iis_install.yml
ansible_inventory_path: hosts
<< : *WIN_BASE
- name: centos6-httpd01
ipaddress: 192.168.33.41
ansible_playbook: centos6_httpd_install_noproxy.yml
<< : *CENT_BASE
- name: centos6-httpd02
ipaddress: 192.168.33.42
ansible_playbook: centos6_httpd_install_noproxy.yml
<< : *CENT_BASE
执行”vagrant up”的结果是什么?
/vagrant-yaml-ansible $ vagrant up
Bringing machine 'win2012-iis01' up with 'virtualbox' provider...
Bringing machine 'centos6-httpd01' up with 'virtualbox' provider...
Bringing machine 'centos6-httpd02' up with 'virtualbox' provider...
==> win2012-iis01: Importing base box 'win-2012r2-standard-amd64-nocm-mod'...
==> win2012-iis01: Matching MAC address for NAT networking...
==> win2012-iis01: Setting the name of the VM: vagrant-yaml-ansible_win2012-iis01_1458379134800_68871
==> win2012-iis01: Clearing any previously set network interfaces...
==> win2012-iis01: Preparing network interfaces based on configuration...
win2012-iis01: Adapter 1: nat
win2012-iis01: Adapter 2: hostonly
==> win2012-iis01: Forwarding ports...
win2012-iis01: 5985 (guest) => 55985 (host) (adapter 1)
win2012-iis01: 5986 (guest) => 55986 (host) (adapter 1)
==> win2012-iis01: Running 'pre-boot' VM customizations...
==> win2012-iis01: Booting VM...
==> win2012-iis01: Waiting for machine to boot. This may take a few minutes...
win2012-iis01: WinRM address: 127.0.0.1:55985
win2012-iis01: WinRM username: vagrant
win2012-iis01: WinRM execution_time_limit: PT2H
win2012-iis01: WinRM transport: plaintext
==> win2012-iis01: Machine booted and ready!
Sorry, don't know how to check guest version of Virtualbox Guest Additions on this platform. Stopping installation.
==> win2012-iis01: Checking for guest additions in VM...
==> win2012-iis01: Setting hostname...
==> win2012-iis01: Configuring and enabling network interfaces...
==> win2012-iis01: Mounting shared folders...
win2012-iis01: /vagrant => /Users/foo/vagrant-yaml-ansible
==> win2012-iis01: Running provisioner: ansible...
win2012-iis01: Running ansible-playbook...
PLAY [all] *********************************************************************
TASK [setup] *******************************************************************
ok: [win2012-iis01]
TASK [win2012-iis01: copy html file] *******************************************
changed: [win2012-iis01]
TASK [win2012-iis01: shuld be Installed IIS] ***********************************
ok: [win2012-iis01]
PLAY RECAP *********************************************************************
win2012-iis01 : ok=3 changed=1 unreachable=0 failed=0
==> centos6-httpd01: Importing base box 'geerlingguy/centos6'...
==> centos6-httpd01: Matching MAC address for NAT networking...
==> centos6-httpd01: Checking if box 'geerlingguy/centos6' is up to date...
==> centos6-httpd01: Setting the name of the VM: vagrant-yaml-ansible_centos6-httpd01_1458380691988_27772
==> centos6-httpd01: Clearing any previously set network interfaces...
==> centos6-httpd01: Preparing network interfaces based on configuration...
centos6-httpd01: Adapter 1: nat
centos6-httpd01: Adapter 2: hostonly
==> centos6-httpd01: Forwarding ports...
centos6-httpd01: 22 (guest) => 2222 (host) (adapter 1)
==> centos6-httpd01: Running 'pre-boot' VM customizations...
==> centos6-httpd01: Booting VM...
==> centos6-httpd01: Waiting for machine to boot. This may take a few minutes...
centos6-httpd01: SSH address: 127.0.0.1:2222
centos6-httpd01: SSH username: vagrant
centos6-httpd01: SSH auth method: private key
centos6-httpd01: Warning: Remote connection disconnect. Retrying...
centos6-httpd01:
centos6-httpd01: Vagrant insecure key detected. Vagrant will automatically replace
centos6-httpd01: this with a newly generated keypair for better security.
centos6-httpd01:
centos6-httpd01: Inserting generated public key within guest...
centos6-httpd01: Removing insecure key from the guest if it's present...
centos6-httpd01: Key inserted! Disconnecting and reconnecting using new SSH key...
==> centos6-httpd01: Machine booted and ready!
GuestAdditions 5.0.16 running --- OK.
==> centos6-httpd01: Checking for guest additions in VM...
==> centos6-httpd01: Setting hostname...
==> centos6-httpd01: Configuring and enabling network interfaces...
==> centos6-httpd01: Mounting shared folders...
centos6-httpd01: /vagrant => /Users/foo/vagrant-yaml-ansible
==> centos6-httpd01: Running provisioner: ansible...
centos6-httpd01: Running ansible-playbook...
PLAY [all] *********************************************************************
TASK [centos6-httpd01: libselinux-python should have been installed] ***********
ok: [centos6-httpd01]
TASK [centos6-httpd01: httpd should have been installed] ***********************
changed: [centos6-httpd01]
TASK [centos6-httpd01: copy html file] *****************************************
changed: [centos6-httpd01]
TASK [centos6-httpd01: httpd should have been running] *************************
changed: [centos6-httpd01]
TASK [centos6-httpd01: lokkit -p 80:tcp] ***************************************
changed: [centos6-httpd01]
PLAY RECAP *********************************************************************
centos6-httpd01 : ok=5 changed=4 unreachable=0 failed=0
==> centos6-httpd02: Importing base box 'geerlingguy/centos6'...
==> centos6-httpd02: Matching MAC address for NAT networking...
==> centos6-httpd02: Checking if box 'geerlingguy/centos6' is up to date...
==> centos6-httpd02: Setting the name of the VM: vagrant-yaml-ansible_centos6-httpd02_1458380895063_96616
==> centos6-httpd02: Fixed port collision for 22 => 2222. Now on port 2200.
==> centos6-httpd02: Clearing any previously set network interfaces...
==> centos6-httpd02: Preparing network interfaces based on configuration...
centos6-httpd02: Adapter 1: nat
centos6-httpd02: Adapter 2: hostonly
==> centos6-httpd02: Forwarding ports...
centos6-httpd02: 22 (guest) => 2200 (host) (adapter 1)
==> centos6-httpd02: Running 'pre-boot' VM customizations...
==> centos6-httpd02: Booting VM...
==> centos6-httpd02: Waiting for machine to boot. This may take a few minutes...
centos6-httpd02: SSH address: 127.0.0.1:2200
centos6-httpd02: SSH username: vagrant
centos6-httpd02: SSH auth method: private key
centos6-httpd02: Warning: Remote connection disconnect. Retrying...
centos6-httpd02:
centos6-httpd02: Vagrant insecure key detected. Vagrant will automatically replace
centos6-httpd02: this with a newly generated keypair for better security.
centos6-httpd02:
centos6-httpd02: Inserting generated public key within guest...
centos6-httpd02: Removing insecure key from the guest if it's present...
centos6-httpd02: Key inserted! Disconnecting and reconnecting using new SSH key...
==> centos6-httpd02: Machine booted and ready!
GuestAdditions 5.0.16 running --- OK.
==> centos6-httpd02: Checking for guest additions in VM...
==> centos6-httpd02: Setting hostname...
==> centos6-httpd02: Configuring and enabling network interfaces...
==> centos6-httpd02: Mounting shared folders...
centos6-httpd02: /vagrant => /Users/foo/vagrant-yaml-ansible
==> centos6-httpd02: Running provisioner: ansible...
centos6-httpd02: Running ansible-playbook...
PLAY [all] *********************************************************************
TASK [centos6-httpd02: libselinux-python should have been installed] ***********
ok: [centos6-httpd02]
TASK [centos6-httpd02: httpd should have been installed] ***********************
changed: [centos6-httpd02]
TASK [centos6-httpd02: copy html file] *****************************************
changed: [centos6-httpd02]
TASK [centos6-httpd02: httpd should have been running] *************************
changed: [centos6-httpd02]
TASK [centos6-httpd02: lokkit -p 80:tcp] ***************************************
changed: [centos6-httpd02]
PLAY RECAP *********************************************************************
centos6-httpd02 : ok=5 changed=4 unreachable=0 failed=0
~/vagrant-yaml-ansible $
其他
关于Ansible配置管理工具。
- Ansible provisioneの使い方はVagrantサイトを参照してください。
关于示例的Windows盒子
为了在基于opentable/win-2012r2-standard-amd64-nocmBOX文件的基础上运行Ansible provisoner,我们对样本中提及的win-2012r2-standard-amd64-nocm-mod box文件所附带的HashiCorp.的链接进行了以下附加配置。
- Vagrant と接続している 192.168.33.0/24ネットワークをPublic から Private へ以下パワーシェルのコマンドで変更し、さらにGUIでPrivate Network の Firewallをoffにします。
Get-NetConnectionProfile
Get-NetConnectionProfile | where Name -eq 'Unidentified network'
Get-NetConnectionProfile | where Name -eq 'Unidentified network' | Set-NetconnectionProfile -NetworkCategory Private
Get-NetConnectionProfile | where Name -eq 'Unidentified network'
执行结果
Windows PowerShell
Copyright (C) 2013 Microsoft Corporation. All rights reserved.
PS C:\Users\Administrator> Get-NetConnectionProfile
Name : Network
InterfaceAlias : Ethernet
InterfaceIndex : 12
NetworkCategory : Public
IPv4Connectivity : Internet
IPv6Connectivity : NoTraffic
Name : Unidentified network
InterfaceAlias : Ethernet 2
InterfaceIndex : 15
NetworkCategory : Public
IPv4Connectivity : LocalNetwork
IPv6Connectivity : NoTraffic
PS C:\Users\Administrator> Get-NetConnectionProfile | where Name -eq 'Unidentified network'
Name : Unidentified network
InterfaceAlias : Ethernet 2
InterfaceIndex : 15
NetworkCategory : Public
IPv4Connectivity : LocalNetwork
IPv6Connectivity : NoTraffic
PS C:\Users\Administrator> Get-NetConnectionProfile | where Name -eq 'Unidentified network' | Set-NetconnectionProfile
-NetworkCategory Private
PS C:\Users\Administrator> Get-NetConnectionProfile | where Name -eq 'Unidentified network'
Name : Unidentified network
InterfaceAlias : Ethernet 2
InterfaceIndex : 15
NetworkCategory : Private
IPv4Connectivity : LocalNetwork
IPv6Connectivity : NoTraffic
- コマンドプロンプトよりWinRM へ以下設定を追加。
winrm quickconfig -q
winrm set winrm/config/winrs @{MaxMemoryPerShellMB="512"}
winrm set winrm/config @{MaxTimeoutms="1800000"}
winrm set winrm/config/service @{AllowUnencrypted="true"}
winrm set winrm/config/service/auth @{Basic="true"}
sc config WinRM start= auto
执行结果
Microsoft Windows [Version 6.3.9600]
(c) 2013 Microsoft Corporation. All rights reserved.
C:\Users\Administrator> winrm quickconfig -q
WinRM service is already running on this machine.
WinRM is already set up for remote management on this computer.
C:\Users\Administrator> winrm set winrm/config/winrs @{MaxMemoryPerShellMB="512"}
Winrs
AllowRemoteShellAccess = true
IdleTimeout = 7200000
MaxConcurrentUsers = 10
MaxShellRunTime = 2147483647
MaxProcessesPerShell = 25
MaxMemoryPerShellMB = 512
MaxShellsPerUser = 30
C:\Users\Administrator> winrm set winrm/config @{MaxTimeoutms="1800000"}
Config
MaxEnvelopeSizekb = 500
MaxTimeoutms = 1800000
MaxBatchItems = 32000
MaxProviderRequests = 4294967295
Client
NetworkDelayms = 5000
URLPrefix = wsman
AllowUnencrypted = false
Auth
Basic = true
Digest = true
Kerberos = true
Negotiate = true
Certificate = true
CredSSP = false
DefaultPorts
HTTP = 5985
HTTPS = 5986
TrustedHosts
Service
RootSDDL = O:NSG:BAD:P(A;;GA;;;BA)(A;;GR;;;IU)S:P(AU;FA;GA;;;WD)(AU;SA;GXGW;;;WD)
MaxConcurrentOperations = 4294967295
MaxConcurrentOperationsPerUser = 1500
EnumerationTimeoutms = 240000
MaxConnections = 300
MaxPacketRetrievalTimeSeconds = 120
AllowUnencrypted = true
Auth
Basic = true
Kerberos = true
Negotiate = true
Certificate = false
CredSSP = false
CbtHardeningLevel = Relaxed
DefaultPorts
HTTP = 5985
HTTPS = 5986
IPv4Filter = *
IPv6Filter = *
EnableCompatibilityHttpListener = false
EnableCompatibilityHttpsListener = false
CertificateThumbprint
AllowRemoteAccess = true
Winrs
AllowRemoteShellAccess = true
IdleTimeout = 7200000
MaxConcurrentUsers = 10
MaxShellRunTime = 2147483647
MaxProcessesPerShell = 25
MaxMemoryPerShellMB = 512
MaxShellsPerUser = 30
C:\Users\Administrator> winrm set winrm/config/service @{AllowUnencrypted="true"}
Service
RootSDDL = O:NSG:BAD:P(A;;GA;;;BA)(A;;GR;;;IU)S:P(AU;FA;GA;;;WD)(AU;SA;GXGW;;;WD)
MaxConcurrentOperations = 4294967295
MaxConcurrentOperationsPerUser = 1500
EnumerationTimeoutms = 240000
MaxConnections = 300
MaxPacketRetrievalTimeSeconds = 120
AllowUnencrypted = true
Auth
Basic = true
Kerberos = true
Negotiate = true
Certificate = false
CredSSP = false
CbtHardeningLevel = Relaxed
DefaultPorts
HTTP = 5985
HTTPS = 5986
IPv4Filter = *
IPv6Filter = *
EnableCompatibilityHttpListener = false
EnableCompatibilityHttpsListener = false
CertificateThumbprint
AllowRemoteAccess = true
C:\Users\Administrator> winrm set winrm/config/service/auth @{Basic="true"}
Auth
Basic = true
Kerberos = true
Negotiate = true
Certificate = false
CredSSP = false
CbtHardeningLevel = Relaxed
C:\Users\Administrator> sc config WinRM start= auto
[SC] ChangeServiceConfig SUCCESS
C:\Users\Administrator>