使用ansible playbook在VmWare上部署大量VM guest虚拟机

问题描述 投票:0回答:2

我为ansible编写了一本playbook,用于在我的vmware基础架构上创建虚拟机。它工作得很好,但我不知道如何查看要创建的机器列表,是否有人知道是否可以这样做?

这是我的剧本:

hosts: all
gather_facts: false
vars_files:
 - variables.yml
connection: local
   tasks:
      - name: configura install cfg
        template:
          src: template_install.j2
          dest:  /root/cfg/{{ vm_name }}.cfg

      - name: configura isolinux.cfg
        template:
          src: isolinux.j2
          dest:  /root/rhel/isolinux/isolinux.cfg

      - name: copia file su satellite
        shell: scp /root/cfg/{{ vm_name }}.cfg [email protected]:/var/ftp/pub/kickstart/.

      - name: make cd iso for install red hat
          shell: /root/makecdrom.sh {{ vm_name }}

      - name: upload cdrom to library datastore
          vsphere_copy:
          host: <Myvcentername>
          login: <myvcenterusername>
          password:  <Mycenterpassword>
          validate_certs: no
          src: /root/{{ vm_name}}.iso
          datacenter: {{ vm_datacenter }}
          datastore: VMW_LIBRARY01
          path: ISO/{{ vm_name }}.iso

      - name: Crea VM 
          vmware_guest:
          hostname: <Myvcentername>
          login: <myvcenterusername>
          password:  <Mycenterpassword>
          datacenter: "{{ vm_datacenter }}"
          resource_pool: "{{ vm_resource_pool }}"
          validate_certs: no
          annotation: 'creata con script ansible ip address " {{ vm_ip_addr }} "'
          folder: "{{ vm_folder }}"
          name: "{{ vm_name }}"
          state: "{{ vm_state }}"
          guest_id: "{{ vm_guest_id }}"
          cluster: "{{ vm_cluster }}"
             cdrom:
               type: iso
               iso_path: "[VMW_LIBRARY01] ISO/'{{vm_name}}.iso'"
             disk:
               - size_gb: "{{ disk_size_gb }}"
                 type: "{{ disk_type }} "
                 datastore: "{{ disk_datastore }}"
             hardware:
                 memory_mb: "{{ hardware_memory_mb }}"
                 num_cpus: "{{ hardware_num_cpus }}"
             scsi: paravirtual
             networks:
               - name: "{{ networks_name }}"
                 device_type: vmxnet3
          delegate_to: 127.0.0.1
          register: deploy_vm

这是变量文件

vm_netmask: 255.255.252.0
vm_gateway: 10.100.8.1
vm_fqdn_name: mcdlnxevtp01.menarini.net
vm_name: MCDLNXEVTP01
vm_folder: APP - EASYVISTA
vm_cluster: MCDVMWCLU02
vm_resource_pool: 06 - PRD
networks_name: dPG_3008_PRD
disk_datastore: VMW_PRD_DS02
Vm_OS: Red Hat 7.6
vm_datacenter: MDC-METROPOOL
vm_state: poweredoff
vm_guest_id: rhel7_64Guest
disk_size_gb: 50
disk_type: thin
hardware_memory_mb: 8192
hardware_num_cpus: 4
hardware_scsi: paravirtual
vm_validate_certs: no
networks_device_type: vmxnet3

谢谢你的回答......西蒙娜

ansible vmware rhel7
2个回答
1
投票

确实这是可能的。我会通过将变量分成整个库存的全局变量(如网关 - 对于所有服务器或服务器组来说都是相同的)和每个服务器来实现它。您可以通过创建包含库存清单和变量列表的文件来执行此操作:

inventory/
  my_vms/
    hosts
    group_vars/
      all.yml
      south-dc.yml
      north-dc.yml
    host_vars/
      my_vm_1.yml
      my_vm_2.yml

hosts文件包含服务器列表(在您的情况下为VM)。它可能包含以下内容:

[all]
my_vm_1
my_vm_2

[south-dc]
my_vm_1

[north-dc]
my_vm_2

host_vars目录包含YAML文件,其中的变量以hosts文件中的主机命名,即如果您将服务器命名为my_vm_1,则该文件将命名为my_vm_1.yml

group_vars类似于host_vars,但是您提供由主机组共享的变量。名为all的特殊组为所有主机提供全局变量。

所有全局变量都可以放在all.yml中。例如,您可以将这些放在该文件中:

disk_size_gb: 50
disk_type: thin
hardware_memory_mb: 8192
hardware_num_cpus: 4

然后,所有每个主机变量都将转到库存host_vars文件:

vm_fqdn_name: mcdlnxevtp01.menarini.net
vm_name: MCDLNXEVTP01

通过这种方式,您可以提供一致的库存分类方法,从而为您提供清理代码的机会

然后您可以通过简单地调用来使用它

ansible-playbook -i inventory/my_vms -l my_vm_1 playbook.yml

如果您希望针对服务器组运行playbook,只需使用-l <groupname>-l all为库存中的所有服务器启动它。

PS:您不必将服务器放在[all]组中。它是包含清单中所有服务器的特殊组。


1
投票

我更喜欢仅将库存用于配置管理。您可以这样做但是如何跟踪更改或如何将新项目添加到堆栈?

从我的角度来看,最好的方法是使用这样的yaml配置文件:

vmstodeploy:
- name: myvm
  vm_ip_addr: 192.168.0.15
  vm_netmask: 255.255.255.0
  vm_gateway: 192.168.0.1
  etc...

并将其保存在git存储库中以进行更改控制。如果要向堆栈添加更多vms,只需添加另一个vm:

vmstodeploy:
- name: myvm
  vm_ip_addr: 192.168.0.15
  vm_netmask: 255.255.255.0
  vm_gateway: 192.168.0.1
- name: myvm2
  vm_ip_addr: 192.168.0.16
  vm_netmask: 255.255.255.0
  vm_gateway: 192.168.0.1

阅读它:

- name: Read My VMs
    include_vars:
      file: "MyConfigFile"
      name: mydeploy

从这里,您将获得mydeploy var中的vm部署信息列表。

只需在这样的角色中创建一个循环:

  - name: Deploy VMs
    include_tasks: vmware_deploy.yml
    with_items: "{{ mydeploy|default([]) }}"
    loop_control:
      loop_var: _myvms

从那里,在vmware_deploy.yml文件中创建vms:

- name: Create my VMs
  vmware_guest:

如果vms具有相同的数据,请使用with_sequence,使用batch()序列化您的部署,尝试不同的选项,但总是从yaml中的配置文件开始。

© www.soinside.com 2019 - 2024. All rights reserved.