首页 > 其他分享 >ansible-playbook

ansible-playbook

时间:2024-02-20 10:45:36浏览次数:26  
标签:name firewalld nginx state ansible user playbook

ansible-playbook

playbooks 本身由以下各部分组成
(1)Tasks:任务,即通过 task 调用 ansible 的模板将多个操作组织在一个 playbook 中运行
(2)Variables:变量
(3)Templates:模板
(4)Handlers:处理器,当changed状态条件满足时,(notify)触发执行的操作
(5)Roles:角色

 

palybook的基础应用

实操1:通过palybooks完成nginx的安装

第一种:通过yum安装nginx

 

 

 

#定义剧本名称为nginx安装
- name: install nginx
#表示捕收剂facts信息
  gather_facts: false
#指定指定此play的远程主机组
  hosts: webservers
#指定运行此play的用户
  remote_user: root
#指定当前play的任务列表
  tasks:
#关闭防火墙和selinux
  - name: disabled firewalld
    service: name=firewalld  state=stopped  enabled=no
  - name: disable selinux
    command: '/sbin/setenforce 0'
    ignore_errors: yes
  - name: disabled selinux forever
    replace: path=/etc/selinux/config  regexp=enforcing  replace=disabled  after=loaded
#将nginx的repo文件传输给远程主机
  - name: copy nginx repo
    copy: src=/etc/yum.repos.d/nginx.repo dest=/etc/yum.repos.d/nginx.repo
#通过yum安装nginx
  - name: install nginx by yum
    yum: name=nginx state=latest
#安装nginx
  - name: start nginx service
    systemd: name=nginx state=started enabled=yes

 

 

 

 

 

[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

 

 

 

第二种:通过编译安装nginx

 

 

 #需粘贴,前需要在命令行输入此命令

 

 

---
- name: nginx install with source
gather_facts: false
hosts: webservers
remote_user: root
vars:
tasks:
# 关闭防火墙和selinux,启动 set ai 后,从注释行换行后会保持注释
- name: disabled firewalld
service: name=firewalld state=stopped enabled=no
- name: disabled selinux
command: "/sbin/setenforce 0"
ignore_errors: yes
- name: disabled selinux forever
replace: path=/etc/selinux/config regexp=enforcing replace=disabled after=loaded

# 安装依赖包
- name: install environment packages
yum: name=pcre-devel,zlib-devel,openssl-devel,gcc,gcc-c++,make state=latest

# 创建运行用户
- name: create nginx user
user: name=nginx create_home=no shell=/sbin/nologin

# 在线下载nginx安装包
- name: nginx package
command: "/usr/bin/wget http://nginx.org/download/nginx-1.24.0.tar.gz -P /opt"
- name: unarchive nginx package
unarchive: copy=no src=/opt/nginx-1.24.0.tar.gz dest=/opt/
- name: install nginx with source
shell: chdir=/opt/nginx-1.24.0/ ./configure --prefix=/opt/apps/nginx --user=nginx --group=nginx --with-http_stub_status_module --with-stream && make && make install

# 创建软连接
- name: create link file for nginx
file: state=link src=/opt/apps/nginx/sbin/nginx path=/usr/bin/nginx

# 启动nginx服务
- name: create nginx service file
copy: src=nginx.service dest=/usr/lib/systemd/system/nginx.service
- name: start nginx
service: name=nginx state=started enabled=yes

 

 

[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/opt/apps/nginx/logs/nginx.pid
ExecStart=/opt/apps/nginx/sbin/nginx
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target

 

 #验证

 

实操2:playbook定义、引用变量​​​​​​​

 

 

 

---
- name: stop firewalld nfs crond
  gather_facts: true
  hosts: webservers:dbservers
  remote_user: root
#定义变量名为servername值为firewalld
  vars:
  - servername: firewalld
  tasks:
  - name: stop firewalld
#调用vars定义的变量
    systemd: name={{servername}} state=stopped enabled=no
  - name: copy ipv4 info
#通过调用收集的facts信息做变量值
    copy: content={{ansible_default_ipv4.address}} dest=/opt/ip.txt

 

 

 

 

 

 

 

 

纵向写法

 

---
2 - name: stop firewalld nfs crond
3 gather_facts: true
4 hosts: webservers:dbservers
5 remote_user: root
6 #定义变量名为servername值为firewalld
7 vars:
8 - servername: firewalld
9 tasks:
10 - name: stop firewalld
11 #调用vars定义的变量
12 systemd:
13 name: "{{servername}}"
14 state: stopped
15 enabled: no
16 - name: copy ipv4 info
17 #通过调用收集的facts信息做变量值
18 copy:
19 content: "{{ansible_default_ipv4.address}}"
20 dest: /opt/ip.txt

 

实操3:通过playbook完成普通账户权限提权为root用户

 

---
- name: stop firewalld nfs crond
  gather_facts: true
  hosts: webservers
  remote_user: yr
  become: yes
  become_user: root
#定义变量名为servername值为firewalld
  vars:
  - servername: firewalld
  tasks:
  - name: stop firewalld
#调用vars定义的变量
    systemd:
      name: "{{servername}}"
      state: stopped
      enabled: no
  - name: copy ipv4 info
#通过调用收集的facts信息做变量值
    copy:
      content: "{{ansible_default_ipv4.address}}"
      dest: /opt/ip.txt

 

 

 #webservers,服务器也要设置

 

实操4:通过when条件判断指定主机完成相应的任务

 

 

---
- hosts: all
  remote_user: root
  tasks:
   - name: shutdown host 
     command: /sbin/shutdown -r now
     when: ansible_default_ipv4.address == "192.168.19.24"      #when指令中的变量名不需要手动加上 {{}}
#或 
    # when: inventory_hostname == "<主机名>"

 

实操5:通过with_items循环实现在远程主机上关闭服务、创建文件和目录

 

---
- name: stop firewalld nfs crond
  gather_facts: true
  hosts: webservers:dbservers
  remote_user: root
#定义变量名为servername,值分别为firewalld,nfs,crond
  vars:
  - servername: [firewalld, nfs, crond]
  tasks:
  - name: stop firewalld nfs crond
#通过with_items实现循环关闭服务
    with_items: "{{servername}}"
    systemd: name={{item}} state=stopped enabled=no

 

 #将webservers,和dbservers开启firewalld,nfs,crond

 

 批量创建多个用户,并加入指定的组

 

---
- name: create user
  gather_facts: false
  hosts: dbservers
  remote_user: root
  vars:
    myusers:
    - {myname: xyc, mygroup: ky33}
    - {myname: wwy, mygroup: ky34}
    - {myname: hb, mygroup: ky35}
  tasks:
  - name: create groups
    with_items: [ky33, ky34, ky35]
    group: name={{item}}
 
  - name: create users and join into group
    with_items: "{{myusers}}"
    user: name={{item.myname}}  groups={{item.mygroup}}  state=present

 

 

 

 

实操6:基于templates模块,完成nginx服务的配置模板

Templates 模块
Jinja是基于Python的模板引擎。Template类是Jinja的一个重要组件,可以看作是一个编译过的模板文件,用来产生目标文本,传递Python的变量给模板去替换模板中的标记。
 
1.先准备一个以 .j2 为后缀的 template 模板文件,设置引用的变量
cp /etc/httpd/conf/httpd.conf /opt/httpd.conf.j2
 
vim /opt/httpd.conf.j2
Listen {{http_port}}                #42行,修改
ServerName {{server_name}}            #95行,修改
DocumentRoot "{{root_dir}}"          #119行,修改

实操7:基于tags标签,指定完成特定的任务模块

可以在一个playbook中为某个或某些任务定义“标签”,在执行此playbook时通过ansible-playbook命令使用--tags选项能实现仅运行指定的tasks。
playbook还提供了一个特殊的tags为always。作用就是当使用always作为tags的task时,无论执行哪一个tags时,定义有always的tags都会执行。

 

tags 模块
可以在一个playbook中为某个或某些任务定义“标签”,在执行此playbook时通过ansible-playbook命令使用--tags选项能实现仅运行指定的tasks。
playbook还提供了一个特殊的tags为always。作用就是当使用always作为tags的task时,无论执行哪一个tags时,定义有always的tags都会执行。
 
vim webhosts.yaml
---
- hosts: webservers
  remote_user: root
  tasks:
    - name: Copy hosts file
      copy: src=/etc/hosts dest=/opt/hosts
      tags:
      - only     #可自定义
    - name: touch file
      file: path=/opt/testhost state=touch
      tags:
      - always    #表示始终要运行的代码
 
ansible-playbook webhosts.yaml --tags="only"
 
vim dbhosts.yaml
---
- hosts: dbservers
  remote_user: root
  tasks:
    - name: Copy hosts file
      copy: src=/etc/hosts dest=/opt/hosts
      tags:
        - only
    - name: touch file
      file: path=/opt/testhost state=touch
 
 
ansible-playbook dbhosts.yaml --tags="only"
//分别去两台被管理主机上去查看文件创建情况

合并:综合多模块

---
- name: serventh play for install nginx with source
  gather_facts: yes
  hosts: webservers
  remote_user: root
  vars:
  - root_dir: /var/www/html
  tasks:
  #关闭防火墙和selinux
  - name: disabled firewalld
    service: name=firewalld  state=stopped  enabled=no
  - name: disable selinux
    command: '/sbin/setenforce 0'
    ignore_errors: yes
  - name: disabled selinux forever
    replace: path=/etc/selinux/config  regexp=enforcing  replace=disabled  after=loaded
 
  #安装依赖包
  - name: mount cdrom
    mount: src=/dev/sr0  path=/mnt  fstype=iso9660 state=mounted
  - name: install pkgs
    with_items: [pcre-devel, zlib-devel, openssl-devel, gcc, gcc-c++, make]
    yum: name={{item}}  state=latest
 
  #创建运行用户
  - name: create nginx user
    user: name=nginx create_home=no shell=/sbin/nologin
 
  #解压软件包并安装
  - name: unarchive nginx package
    unarchive: copy=yes src=/etc/ansible/playbook/nginx-1.24.0.tar.gz dest=/opt/
  - name: install nginx with source
    shell: chdir=/opt/nginx-1.24.0/  ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module && make && make install
 
  #创建软链接并启动服务
  - name: create link file for nginx
    file: state=link src=/usr/local/nginx/sbin/nginx path=/usr/local/sbin/nginx
  - name: create nginx service file
    copy: src=nginx.service  dest=/lib/systemd/system/nginx.service
  - name: start nginx
    service: name=nginx state=started enabled=yes
 
  #创建网页根目录
  - name: create root dir
    file: path={{root_dir}}  state=directory
  #创建网页文件
  - name: create index.html for accp.com
    copy: content="<h1>this is accp test web page</h1>" dest={{root_dir}}/index.html
    when: ansible_default_ipv4.address == "192.168.20.17"
  - name: create index.html for benet.com
    copy: content="<h1>this is benet test web page</h1>" dest={{root_dir}}/index.html
    when: ansible_default_ipv4.address == "192.168.20.12"
 
  #生成配置文件
  - name: copy nginx config file with template
    template: src=/etc/ansible/playbook/nginx.conf.j2  dest=/usr/local/nginx/conf/nginx.conf
    notify: "reload nginx"
 
  handlers:
  - name: reload nginx
    service: name=nginx state=reloaded

关于playbook的知识点总结

inventory主机清单管理
主机清单配置文件   /etc/ansible/hosts
 
格式:
[组名]
主机IP[:ssh端口]     #默认是 22 端口
主机名[:ssh端口]
主机IP[0:255]        #设置连续的主机列表范围
主机名[a:z]    ansible_port=     ansible_user=    ansible_password=           #设置主机变量
 
[组名:vars]             #设置组变量
ansible_port=
ansible_user=
ansible_password=
 
[大组名:children]       #设置嵌套组
组名1
组名2
组名3
 
 
playbook剧本
vim XXX.yaml  XXX.yml
---
- name:                 #设置play的名称
  hosts:                #指定执行此play的远程主机组
  remote_user:          #指定执行此play的用户
  #become:              #设置是否sudo切换
  #become_user:         #指定sudo切换的用户
  gather_facts:         #设置是否收集facts信息 yes|no|true|false
  vars:                 #设置自定义变量
  tasks:                #指定此play的任务列表
  - name:                  #定义任务的名称
    模块名: 模块参数       #定义任务要使用的模块和参数(键值对格式)
  - name:  
    模块名: 模块参数
    ignore_errors: true    #忽略此任务的失败
  - name:  
    模块名: 模块参数
    notify: '任务名'       #定义此任务执行结果为changed状态时要触发的handlers任务
  - name:  
    模块名: 模块参数
    when:                  #定义条件表达式(== != > >= < <=),条件成立时执行此task任务,否则不执行此任务
  - name:  
    模块名: 模块参数={{item}}
    with_items:            #定义循环列表
  - name:  
    模块名: 模块参数
    tags:                  #定义任务的标签,ansible-playbook --tags="标签" 可实现仅执行拥有指定标签的任务(拥有always标签的任务总是执行)
    - 标签1
    - 标签2
    ....
    
  handlers:
  - name: 任务名
    模块名: 模块参数
 
 
ansible-playbook XXX.yaml -u -k -K  
                          --syntax-check
                          --list-task
                          --list-hosts
                          --start-at-task="任务名称"
                          --tags="标签"
 
 
tasks任务的模块语法格式:
纵向格式:
    模块名:
      参数1: 值
      参数2: "{{变量名}}"
        ....
横向格式:
    模块名: 参数1=值  参数2={{变量名}} ....
 
        
with_items 和 vars 的语法格式
纵向格式:
  - name:
    with_items:
    - 值1
    - 值2
    ....
    模块名: 参数={{item}}
 
  vars:
    变量名:
    - 值1
    - 值2
    ....
  tasks:
  - name:
    模块名: 参数={{item}}
    with_items: "{{变量名}}"
 
  #值为对象类型(键值对字段)时:
    with_items:
    - key1: 值1
      key2: 值2
    - key1: 值3
      key2: 值4
    ....
 
  vars:
    变量名:
    - key1: 值1
      key2: 值2
    - key1: 值3
      key2: 值4
    ....
    
横向格式:
  #值为纯量类型时:
    with_items: [值1, 值2, ....]
 
  vars:
    变量名: [值1, 值2, ....]
 
  #值为对象类型(键值对字段)时:
    with_items:
    - {key1: 值1, key2: 值2}
    - {key1: 值3, key2: 值4}
    ....
 
 
template配置模板模块
1)先准备一个 XXX.j2 配置模板文件,在模板文件中使用 {{变量名}} 格式引用主机变量、组变量、facts信息字段变量或vars字段自定义的变量的值
2)编辑 playbook 文件,在文件中的 tasks 任务中定义 template 模块配置(template: src=XXX.j2文件路径 dest=远程主机文件路径)
 
 
roles角色的作用?
可以把playbook剧本里的各个play看作为一个角色,将各个角色的tasks任务、vars变量、template模板和copy、script模块使用的相关文件等内容放置在指定角色的目录里统一管理,在需要的时候可在playbook中使用roles角色直接调用即可。也就是说roles角色可以在playbook中实现代码的复用。
 
roles/                         #角色总目录,其每个子目录就是一个角色目录
   nginx/                         #相当于playbook中的每一个play主题,目录名就是角色名
      files/                         #存放copy、script模块调用的文件
      templates/                     #存放template模块调用的 XXX.j2 模板文件
      tasks/main.yml                 #定义此角色的tasks普通任务列表
      handlers/main.yml              #定义此角色通过notify触发时执行的handlers处理器任务列表
      vars/main.yml                  #定义此角色用的自定义变量
      defaults/main.yml              #定义此角色用的默认变量(一般不用)
      meta/main.yml                  #定义此角色的元数据信息和依赖关系
   mysql/
     .... 
   php/
     ....
 
 
vim XXX.yaml
- name:
  hosts:
  remote_user:
  roles:
  - nginx
  - mysql
  - php
 
ansible-playbook XXX.yaml

 


 

标签:name,firewalld,nginx,state,ansible,user,playbook
From: https://www.cnblogs.com/yanrui07/p/18020408

相关文章

  • ansible-playbook 之 roles
     rolesroles用于层次性、结构化地组织playbook。roles能够根据层次型结构自动装载变量文件、tasks以及handlers等。要使用roles只需要在playbook中使用include指令引入即可。简单来讲,roles就是通过分别将变量、文件、任务、模板及处理器放置于单独的目录中,并可以便捷的include......
  • Ansible 常用模块
    Ansible介绍Ansible是一个基于Python开发的配置管理和应用部署工具,现在也在自动化管理领域大放异彩。它融合了众多老牌运维工具的优点,Pubbet和Saltstack能实现的功能,Ansible基本上都可以实现。Ansible能批量配置、部署、管理上千台主机。比如以前需要切换到每个主机上执行的......
  • 自动化运维工具【ansible】
    ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于paramiko开发的,并且基于模块化工作,本身没有批量部署的能力。真正具有批量部署的是ansible所运行......
  • Linux基础47 Ansible之ad-hoc, 命令模块(command, shell, script), 软件管理模块(yum,
    Ansible之ad-hoc一、什么是ad-hoc1.什么是ad-hocad-hoc简而言之就是“临时命令”,执行完即结束,并不会保存2.ad-hoc使用场景可以用作查看远程机器的进程,或者磁盘,或者拷贝文件3.ad-hoc命令使用[root@m01~]#ansibleweb01-mshell-a'free-m'web01|CHANGED|rc=......
  • Ansible-playbook剧本进阶
    剧本高级特性篇循环在写playbook的时候发现了很多task都要重复引用某个相同的模块,比如一次启动10个服务,或者一次拷贝10个文件,如果按照传统的写法最少要写10次,这样会显得playbook很臃肿。如果使用循环的方式来编写playbook,这样可以减少重复编写task带来的臃肿。http......
  • ansible-role角色
    官网文档https://docs.ansible.com/ansible/latest/user_guide/playbooks_reuse_roles.html为什么要用role之前你部署的nfs、rsync、lsyncd、nginx是如何管理他们的palybook的?想必是随便放在某一个文件夹里吧而如果你部署这个备份方案的多个playbook,还使用到了一些额外......
  • Linux基础46 ansible概述, 结构, 安装与配置文件, 主机清单配置
    Ansible学习一、Ansible概述1.什么是ansible?Ansible是一个自动化统一配置管理工具,自动化主要体现在Ansible集成了丰富模块以及功能组件,可以通过一个命令完成一系列的操作,进而能减少重复性的工作和维护成本,可以提高工作效率。2.自动化工具1.puppet学习难,安装ruby环境难,没......
  • Ubuntu安装Ansible AWX
    环境:AWSEC2,UbuntuServer22.04+桌面环境1.-安装dockersudoaptinstallapt-transport-httpsca-certificatescurlsoftware-properties-commoncurl-fsSLhttps://download.docker.com/linux/ubuntu/gpg|sudoapt-keyadd-sudoadd-apt-repository"deb[arch=amd64]......
  • Ansible - Roles
      前言Q1:什么是Roles在实际生产环境中,会编写大量的playbook文件来实现不同的功能。而且,每个playbook还可能会调用其他文件(变量文件),对于海量的、无规律的文件,管理是个问题。Ansible从1.2版本开始支持Roles,Roles是管理ansible文件的一种规范(目录结构),Roles会按照标准的规范,自......
  • sudo提权,ansible批量给所有主机创建系统账户,授权
    sudo(superuseroranotherdo)让普通用户可以以超级管理员或其他人的身份执行命令。sudo基本流程如下:1.管理员需要先授权(修改/etc/sudoers文件)2.普通用户以sudo的形式执行命令3.可以通过sudo-l查看授权情况修改/etc/sudoers的方法如下:1.visudo(带语法检查,默认没有颜色提示)2......