Ansible-playblook

1.Playbook的功能

playbook 是由一个或多个play组成的列表

Playboot 文件使用YAML来写的

2.YAML

2.1 简介

是一种表达资料序列的格式,类似XML
Yet Another Markup Language
2001年首次发表
www.yaml.org

2.2 特点

可读性好
和脚本语言交互性号
易于实现
适用程序执行流梳理方式
可扩展性强

2.3 语法简介

在文件中用[---]开始
在文件中用[...]结尾
次行一般书写文件内容
缩进严格
大小写敏感
key/value可以多行书写也可一行书写,一行书写用,隔开
value可以是个字符串,也可是list
一个play需要包括name和tasks
name 是描述
tasks 是动作
一个name只能包含一个task
扩展名称yml或者yaml

2.4 YAML 列表

[Linux,C++,Java,Python]
- Linux
- C++
- Java
- Python

2.5 YAML的字典

字典作用存放键值
name:westos
age:12
jobs:linux

{name: "westos", age: "12", jobs: "linux"}

2.5 playbook执行命令

ansible-playbook xxx.yml ...
--check|-C       ##检测
--syntax-check   ##check language
--list-hosts     ##列出hosts
--list-tags      ##列出tag
--list-tasks     ##列出task
--limit          ##指定执行主机
-v -vv           ##现实过程

2.6 Playbook的核心组件

name     #可选,建议使用多用于说明
hosts    #受控主机列表
tasks    #任务,用与选择执行部分代码

3. 基本示例

3.1 用playbook的方式下载httpd,并且访问httpd的时候显示hello westos

书写的文件
[admin@ansible .ansible]$ cat httpd.yml 
- name: install httpd
  hosts: westos
  tasks:
    - name: install httpd
      yum:
        name: httpd
        state: present
 
    - name: configure httpd
      copy:
        dest: /var/www/html/index.html
        content: hello westos
 
    - name: configure firewalld
      firewalld:
        service: http
        permanent: yes
        state: enabled
        immediate: yes
 
    - name: start httpd
      service:
        name: httpd
        state: started
        enabled: yes
测试书写的yml文件
[admin@ansible .ansible]$ ansible-playbook httpd.yml

PLAY [install httpd] **************************************************************************************************************

TASK [Gathering Facts] ************************************************************************************************************
ok: [172.25.32.12]
ok: [172.25.32.11]

TASK [install httpd] **************************************************************************************************************
ok: [172.25.32.12]
ok: [172.25.32.11]

TASK [configure httpd] ************************************************************************************************************
changed: [172.25.32.12]
changed: [172.25.32.11]

TASK [configure firewalld] ********************************************************************************************************
ok: [172.25.32.12]
ok: [172.25.32.11]

TASK [start httpd] ****************************************************************************************************************
ok: [172.25.32.11]
ok: [172.25.32.12]

PLAY RECAP ************************************************************************************************************************
172.25.32.11               : ok=5    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
172.25.32.12               : ok=5    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   

3.2 用playbook的书写方式给被控机/mnt下建立一个linux的文件。文件内容为hello linux

书写的文件内容
[admin@ansible .ansible]$ cat linux.yml 
- name: test
  hosts: westos
  tasks: 
    - name: copy
      copy:
        dest: /mnt/linux
        content: hello linux
测试书写的文件
[admin@ansible .ansible]$ ansible-playbook linux.yml 

PLAY [test] ***********************************************************************************************************************

TASK [Gathering Facts] ************************************************************************************************************
ok: [172.25.32.12]
ok: [172.25.32.11]

TASK [copy] ***********************************************************************************************************************
changed: [172.25.32.11]
changed: [172.25.32.12]

PLAY RECAP ************************************************************************************************************************
172.25.32.11               : ok=2    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
172.25.32.12               : ok=2    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   

被控主机中查看
[root@www ~]# cat /mnt/linux 
hello linux

4. vim 设定技巧

autocmd FileType yaml setlocal ai ts=2 sw=2 et

setlocal     ##设定当前文件
ai           ##自动退格对齐    auto indent  
ts           ##tab建长度为2空格 tabstop=2
sw           ##缩进长度为2  shiftwidth=2
et           ##把tab键变成空格 expandta
[admin@ansible .ansible]$ cat ~/.vimrc
autocmd FileType yaml setlocal ai ts=2 sw=2 et
posted @ 2023-03-16 19:48  yunyeblog  阅读(18)  评论(0编辑  收藏  举报  来源