YAML是什么?

  • YAML是一个可读性高、用来表达数据序列的格式语言
  • YAML:YAML Ain't a Markup Language
  • YAML以数据为中心,重点描述数据的关系和结构

YAML的格式要求如下:

  • "#"代表注释,一般第一行为三个横杠(---)
  • 键值(key/value)对使用":"表示,数组使用"-"表示
  • key和value之间使用":"分隔
  • ":"后面必须有空格
  • 一般缩进由两个或以上空格组成
  • 相同层级的缩进必须对齐,缩进代表层级关系
  • 全文不可以使用tab键
  • 区分大小写
  • 扩展名为yml或者yaml
  • 跨行数据需要使用>或者|,其中|会保留换行符

YAM注意-和:后面必须有空格。

L示例展示:

1.

---

"诗仙": "李白"

或者

"诗仙":

      "李白"

2.数组的例子

---

- "李白"

- "杜甫"

- "白居易"

- "唐僧"

#使用一行表示数组的例子

---

"诗人": ["李白","杜甫","白居易"]

#键值对和数组符合例子:

---

"诗人":

- "李白"

- "杜甫"

- "白居易"

Playbook语法格式要求如下:

  • playbook采用YAML格式编写
  • playbook文件中由一个或多个play组成
  • 每个play中可以包含:
  • hosts(主机)、tasks(任务)、vars(变量)等元素组成
  • 使用ansible-playbook命令运行playbook剧本

测试Playbook语法格式

1)编写第一个Playbook

hosts、tasks、name是关键词(不可修改),ping是模块,调用不同模块完成不同任务。

# vim ~/ansible/test.yml

---
- hosts: all                                    #host定义要远程的谁那个主机,或组
tasks:                                            #定义远程后要执行的任务
- name: ping                                  #name后面的具体内容可以任意
ping:

#ansible-playbook test.yml

############################################################

2)定义多个主机和任务

hosts由一个或多个组或主机组成,逗号分隔,tasks由一个或多个任务组成,多个任务按顺序执行,执行ansible-playbook命令可以使用-f选项自定义并发量。

#vim test1.yml

---
- hosts: test,webserver                    #hosts定义需要远程哪些被管理主机,hosts是关键

  tasks:      
      - name: ping
        ping:
      - name: shell
        shell: touch ~/shell.txt
# ansible-playbook ~/ansible/test.yml -f 5

###############################################################

3)多个play的Playbook文件

# vim ~/ansible/test2.yml

#第一个play剧目

---

- hosts: test

:

: This is first play

:

 #第二个play剧目

- hosts: webserver

:

: This is second play

:

##############################################################

用户管理,创建系统账户、账户属性、设置密码(ansible-doc user)。

#vim test_user.yml

---
- hosts: webserver
  tasks:
     - name: Add the user 'johnd'
       user:
       name: johnd
       uid: 1040
       group: daemon
       password: "{{ '123' | password_hash('sha512') }}"

# vim ~/ansible/user_johnd.yml

---

- hosts: webserver

:

: Remove the user 'johnd'

:

: johnd

: absent

#删除系统账户johnd,state的值设置为absent是删除用户

############################################################

3)使用playbook管理软件(ansible-doc yum)

RHEL或CentOS系统中的软件有组包的概念,使用yum grouplist或者dnf grouplist可以查看组包的名称。

# vim ~/ansible/package.yml

---

- hosts: webserver #需要远程的主机是谁

: #定义剧本需要执行的任务

: Install a list of packages                            #第一个任务的描述信息

:                                                                      #调用yum模块安装软件

:                                                     #安装软件的名字,它的值有多个,使用数组-

                - httpd                                                #安装httpd软件

                - mariadb                                           #安装mariadb软件

-server                               #安装mariadb-server 

: install the 'RPM Development Tools' package group #第二个任务的描述信息

:                                                         #调用yum模块安装软件组包

: "@RPM Development Tools"     #安装哪个组包,@是关键词

: update software                            #第三个任务的描述信息

:                                                        #调用yum模块升级软件

: '*'                                                #需要升级哪些软件

: latest                                           #latest代表升级软件

#备注:state的值可以是(present|absent|latest)

#present代表安装软件(默认是present);absent代表卸载软件

#latest代表升级软件

##############################################

Ansible特殊模块

################################################

1.setup模块

ansible_facts用于采集被管理设备的系统信息,所有收集的信息都被保存在变量中,每次执行playbook默认第一个任务就是Gathering Facts,使用setup模块可以查看收集到的facts信息。

# ansible test -m setup

192.168.4.10 | SUCCESS => {

"ansible_facts": {

"ansible_all_ipv4_addresses": [

 

  • ansible_all_ipv4_addresses #IP地址
  • ansible_bios_version #主板BIOS版本
  • ansible_memtotal_mb #总内存
  • ansible_hostname #主机名
  • ansible_fqdn #主机的域名
  • ansible_devices.sda.partitions.sda1.size #某个磁盘分区的大小

2.debug模块

debug模块可以显示变量的值,可以辅助排错,通过msg可以显示变量的值,变量需要使用{{}}扩起来。

# vim ~/ansible/debug.yml

---
- hosts: test
  tasks:
      - debug:
           var: ansible_all_ipv4_addresses
      - debug:
           msg: "主机名是:{{ ansible_hostname }}"
      - debug:
           var: ansible_devices.vda.partitions.sda1.size
      - debug:
           msg: "总内存大小:{{ ansible_memtotal_mb }}"

#备注调用debug模块显示某些具体的变量值

#debug模块可以显示变量的值,可以辅助排错

#debug模块有两个参数,var和msg(引用变量需要{{}})

#var后面调用变量不需要使用{{}}

#msg后面调用变量需要使用{{}}