优秀的编程知识分享平台

网站首页 > 技术文章 正文

Ansible实战系列二 _ Playbook入门

nanyue 2024-12-01 01:45:47 技术文章 7 ℃

前言

需求: 操纵多台主机, 为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 文件夹

# 待定 自己写

其他

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

Tags:

最近发表
标签列表