Ansible实战系列二 _ Playbook入门

本文通过实例演示如何使用Ansible playbook进行远程任务执行,涉及语法检查、指定用户和主机组、文件夹结构配置,以及使用SSH和sudo权限。适合初学者了解Ansible在多主机管理中的应用。
摘要由CSDN通过智能技术生成

前言

需求: 操纵多台主机, 为Kubespray做铺垫

环境

Ubuntu 20.04

1、命令

-k(–ask-pass) 用来交互输入ssh密码
-K(-ask-become-pass) 用来交互输入sudo密码
-u 指定用户
		# ansible-playbook a.yml --syntax-check    #检查yaml文件的语法是否正确
		# ansible-playbook a.yml --list-task       #检查tasks任务
		# ansible-playbook a.yml --list-hosts      #检查生效的主机
		# ansible-playbook a.yml --start-at-task='Copy Nginx.conf'     #指定从某个task开始运行

2、例子

demo 1: 入门小例子

  • 编辑
sudo nano demo1.yaml
# 修改如下
- hosts: 172.16.106.20                  #指定主机
  remote_user: ubuntu20                         #指定在被管理的主机上执行任务的用户
  tasks:                                            #任务列表↓
  - name: hello world                #任务名关闭防火墙
    command: 'echo hello world'    #调用command模块 执行关闭防火墙命令
  • 执行
ansible-playbook demo1.yml --syntax-check
ansible-playbook demo1.yaml
  • 输出如下

PLAY [172.16.106.20] ***************************************************************************************

TASK [Gathering Facts] *************************************************************************************
ok: [172.16.106.20]

TASK [hello world] *****************************************************************************************
changed: [172.16.106.20]

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

demo 2: 指定用户组

默认是/etc/ansible/hosts里面的

  • 查看
cat /etc/ansible/hosts
# 输出
[web]
172.16.106.20 ansible_ssh_user='ubuntu20'
172.16.106.21 ansible_ssh_user='ubuntu20'
172.16.106.22 ansible_ssh_user='ubuntu20'
  • 编辑
sudo nano demo2.yaml
# 修改如下
- hosts: web                #指定主机
  remote_user: ubuntu20                         #指定在被管理的主机上执行任务的用户
  tasks:                                            #任务列表↓
  - name: hello world                #任务名关闭防火墙
    command: 'echo hello world'    #调用command模块 执行关闭防火墙命令
  • 执行
ansible-playbook demo2.yml --syntax-check
ansible-playbook demo2.yaml
  • 输出如下
PLAY [web] *********************************************************************************************************************************

TASK [Gathering Facts] *********************************************************************************************************************
ok: [172.16.106.20]
ok: [172.16.106.21]
ok: [172.16.106.22]

TASK [hello world] *************************************************************************************************************************
changed: [172.16.106.20]
changed: [172.16.106.21]
changed: [172.16.106.22]

PLAY RECAP *********************************************************************************************************************************
172.16.106.20              : ok=2    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
172.16.106.21              : ok=2    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
172.16.106.22              : ok=2    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0  

demo 3: 大致文件夹架构

tree
# 输出如下
.
├── demo3.yaml
└── hosts
    └── demo3.ini
  • 编辑 hosts 文件夹
sudo nano hosts/demo3.ini
# 修改如下:
[web]
172.16.106.20 ansible_ssh_user='ubuntu20'
172.16.106.21 ansible_ssh_user='ubuntu20'
172.16.106.22 ansible_ssh_user='ubuntu20'
  • 编辑 yaml 文件
sudo nano demo3.yaml
# 修改如下:
- hosts: web
  tasks:
  - name: echo hello world
    command: 'echo hello world'
  • 运行
ansible-playbook demo3.yaml --syntax-check
ansible-playbook -i hosts/demo3.ini demo3.yaml

demo 4: 添加 roles 文件夹

# 待定 自己写

其他

如有遗漏欢迎补充
如有问题欢迎留言
如有作用欢迎点赞

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hyh123a

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值