Ansible --- playbook 脚本+inventory 主机清单

一 inventory 主机清单

Inventory支持对主机进行分组,每个组内可以定义多个主机,每个主机都可以定义在任何一个或

多个主机组内。

如果是名称类似的主机,可以使用列表的方式标识各个主机。

vim /etc/ansible/hosts

[webservers]

192.168.10.14:2222        #冒号后定义远程连接端口,默认是 ssh 的 22 端口

192.168.10.1[2:5]

[dbservers]

db-[a:f].example.org    #支持匹配 a~f

1 inventory 中变量

Inventory变量名                  含义
ansible_host                  ansible连接节点时的IP地址
ansible_port                  连接对方的端口号,ssh连接时默认为22
ansible_user                  连接对方主机时使用的主机名。不指定时,将使用执行ansible或ansible-playbook命令的用户
ansible_password              连接时的用户的ssh密码,仅在未使用密钥对验证的情况下有效
ansible_ssh_private_key_file  指定密钥认证ssh连接时的私钥文件
ansible_ssh_common_args       提供给ssh、sftp、scp命令的额外参数
ansible_become                允许进行权限提升
ansible_become_method         指定提升权限的方式,例如可使用sudo/su/runas等方式
ansible_become_user           提升为哪个用户的权限,默认提升为root
ansible_become_password       提升为指定用户权限时的密码

 环境准备:

192.168.11.6
192.168.11.12
192.168.11.13
192.168.11.7

关闭 防火墙 防护 

 

实验 1 :修改端口

连接对方端口号 

[root@11-6 ansible]# vim hosts

[root@mcb-11-7 ~]# vim  /etc/ssh/sshd_config 

验证一下:

实验 2 :连接端口另一个写法 
[webservers]

192.168.11.16 ansible_port=22 ansible_user=root ansible_password=abc1234

#加端口  加用户  加密码

[root@11-6 ansible]# vim hosts 

检测一下:

2 组变量 

[webservers:vars]			#表示为 webservers 组内所有主机定义变量
ansible_user=root
ansible_password=abc1234

[all:vars]					#表示为所有组内的所有主机定义变量
ansible_port=22

[root@11-6 ansible]# vim hosts 

修改被控制端口1116 

ansible主机检测 

3 组嵌套

[root@11-6 ansible]# vim hosts

[root@11-6 ansible]# ansible onlys -m ping 

检测错误:

 二 Ansible 的脚本 --- playbook 剧本

1 playbook格式

playbook由YMAL语言编写。YMAL格式是类似于JSON的文件格式,便于人理解和阅读,同时便于

书写。一个剧本里面可以有多个play,每个play只能有一个tasks,每个tasks可以有多个name。

yaml三板斧
1、缩进:yaml使用一个固定的缩进风格表示层级结构,每个缩进由两个空格组成,不能使用tab键

2、冒号: 以冒号结尾的除外,其他所有冒号后面所有必须有空格。

3、短横线:表示列表项,使用一个短横线加一个空格作为一个列表项,多个项使用同样的缩进级别作为同一列表。

2 playbooks 各部分组成

(1)Tasks:任务,即通过 task 调用 ansible 的模板将多个操作组织在一个 playbook 中运行

(2)Variables:变量

(3)Templates:模板

(4)Handlers:处理器,当changed状态条件满足时,(notify)触发执行的操作

(5)Roles:角色

3 示例诠释:

常用属性: 
vim test1.yaml --- #yaml文件以---开头,以表明这是一个yaml文件,可省略

name: first play #定义一个play的名称,可省略

gather_facts: false #设置不进行facts信息收集,这可以加快执行速度,可省略

hosts: webservers #指定要执行任务的被管理主机组,如多个主机组用冒号分隔

remote_user: root #指定被管理主机上执行任务的用户

tasks: #定义任务列表,任务列表中的各任务按次序逐个在hosts中指定的主机上执行
编辑剧本: 
name: test connection #自定义任务名称

ping:  #使用 module: [options] 格式来定义一个任务

name: disable selinux

command: '/sbin/setenforce 0' #command模块和shell模块无需使用key=value格式

ignore_errors: True #如执行命令的返回值不为0,就会报错,tasks停止,可使用ignore_errors忽

略失败的任务

name: disable firewalld service: name=firewalld state=stopped #使用 module: options 格式来定义

任务,option使用key=value格式

name: install httpd yum: name=httpd state=latest

name: install configuration file for httpd copy: src=/opt/httpd.conf dest=/etc/httpd/conf/httpd.conf

#这里需要一个事先准备好的/opt/httpd.conf文件 notify: "restart httpd" #如以上操作后为changed的

状态时,会通过notify指定的名称触发对应名称的handlers操作

name: start httpd service service: enabled=true name=httpd state=started handlers: #handlers中

定义的就是任务,此处handlers中的任务使用的是service模块

name: restart httpd #notify和handlers中任务的名称必须一致 service: name=httpd state=restarted

##Ansible在执行完某个任务之后并不会立即去执行对应的handler,而是在当前play中所有普通任

务都执行完后再去执行handler,这样的好处是可以多次触发notify,但最后只执行一次对应的

handler,从而避免多次重启。

注意:

每一个名字就是一个模块

4 实验:自动安装apache

[root@11-6 opt]# vim mcb1.yaml

---
- name: install httpd
  gather_facts: all
  hosts: mcbweb01
  remote_user: root
  tasks:
    - name: mcb1 connection
      ping:
    - name: disable firewalld
      service: name=firewalld state=stopped
    - name: install apache
      yum: name=httpd state=latest
    - name: install config file
      copy: src=/opt/httpd.conf dest=/etc/httpd/conf/httpd.conf
      notify: "restart httpd"
    - name: start httpd service
      service: enabled=true name=httpd state=started
  handlers:
    - name: "restart httpd"
      service:  name=httpd state=restarted
运行playbook

ansible-playbook test1.yaml

错误分析:

补充参数:
-k(–ask-pass):用来交互输入ssh密码

-K(-ask-become-pass):用来交互输入sudo密码

-u:指定用户 
ansible-playbook test1.yaml --syntax-check

#检查yaml文件的语法是否正确

②ansible-playbook test1.yaml --list-task

#检查tasks任务


 

ansible-playbook test1.yaml --list-hosts

检查生效的主机

 

ansible-playbook mcb1.yaml --start-at-task='install apache'

指定从某个task开始运行

主机检测一下:

三 playbook定义、引用变量

[root@11-6 opt]# vim mcb2.yaml
---
- name: yin yong bianliang
  hosts: mcb02
  remote_user: root
  vars:
    - groupname: ky38
    - username: nginx
  tasks:
    - name: create group
      group: name={{groupname}} system=yes gid=305
    - name: create user
      user: name={{username}} uid=305 group={{groupname}}
    - name: copy file
      copy: content="{{ansible_default_ipv4}}" dest=/opt/ky38.txt

在命令行里定义变量  

[root@11-6 opt]# ansible-playbook mcb2.yaml -e "mcb" 

检测:

报错信息:

四 指定远程主机sudo切换用户

 hosts: dbservers

remote_user: zhangsan

become: yes #2.6版本以后的参数,之前是sudo,意思为切换用户运行

become_user: root #指定sudo用户为root

执行playbook时:ansible-playbook test1.yml -K <密码>

1 当ssh不允许root用户登录时 打开普通用户sudo提权

编写脚本

2 修改sudoers加入配置文件

 

 给主机11.3 mcb做免密登录

五 when条件判断

在Ansible中,提供的唯一一个通用的条件判断是when指令,当when指令的值为

true时,则该任务执行,否则不执行该任务。

when一个比较常见的应用场景是实现跳过某个主机不执行任务或者只有满足条件的主机执行任务

1 调用command模块进行shutdown服务  

---
- name: restart host 
  hosts: mcbweb01
  remote_user: root
  tasks:
  - name: shutdown host
    command: /sbin/shutdown -r now
    when: ansible_default_ipv4.address == "192.168.11.12"
 查看结果:

2 调用service模块关闭httpd服务 

六 迭代

Ansible提供了很多种循环结构,一般都命名为with_items,作用等同于 loop 循环。  

实验 1:批量创建目录 

[root@11-6 opt]# vim mcb4.yaml 

---
- name: mcb4
  hosts: mcbweb01
  tasks:
    - name: create dir
      file: path={{item}} state=directory
      with_items:          
        - /opt/heze
        - /opt/dingtao
        - /opt/shandong
 检测一下:

实验 2: 批量创建文件

---
- name: play1
  hosts: mcbweb01
  gather_facts: false
  tasks: 
    - name: create directories
      file:
        path: "{{item}}"
        state: directory
      with_items:          
        - /tmp/test1
        - /tmp/test2
    - name: add users
      user: name={{item.name}} state=present groups={{item.groups}}
      with_items:
        - name: test1
          groups: wheel
        - name: test2
          groups: root
 检测一下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值