今天浅浅的回顾一下Ansible吧

什么是Ansible,他有什么用?

Ansible是一款无代理自动化运维工具,核心作用是批量管理服务器:比如批量执行命令、安装软件、配置服务、部署代码等。

它的优势很明显:

  • 无代理:被控服务器不用装额外软件,靠SSH就能通信(大多数服务器默认支持)。
  • 用Python写的,跨平台、兼容性好。
  • 配置文件是YAML格式,简单易懂,不用写复杂代码。
  • 轻量:安装简单,学习成本低。

怎么安装Ansible?

Centos 7 在有epel的情况下:yum install -y ansible即可。

Ansible的目录结构是什么?

Ansible默认配置文件和核心目录都在 /etc/ansible/ 下,主要有三个文件:

  • ansible.cfg(主配置文件) :控制Ansible的运行参数,比如默认SSH端口、超时时间、模块路径等。新手初期不用改,用默认配置即可,后续熟悉后再根据需求调整。
  • hosts(主机清单) :最核心的文件之一!用来记录所有需要管理的被控服务器信息(IP、用户名、端口等),Ansible执行命令时,就是通过这个文件找到目标服务器。
  • roles(角色目录) :用来存放Ansible角色(Role),是进阶功能,用于组织复杂的Playbook。

host的编写

ini 复制代码
# 单台服务器
lb 192.168.1.100 ansible_ssh_user=root ansible_ssh_pass=****

# 多台Web服务器分组
[web]
web01 192.168.1.100 ansible_ssh_user=root ansible_ssh_pass=****
web02 192.168.1.100 ansible_ssh_user=root ansible_ssh_pass=****

然后使用ansible lb -m ping/ansible web -m ping测试,出现 "pong" 就说明连接成功了!

编写自己的第一个Playbook

Ansible的剧本是Playbook,格式是yml,对于空格有严格的要求。 下面我写个安装Nginx和关闭SElinux、firewalld的Playbook,如下。

yaml 复制代码
# Play块起始:定义整个任务的核心信息
- name: install Nginx  # 任务名称:明确该Play的核心作用是安装Nginx
  hosts: lb           # 目标主机:操作名为lb的服务器
  
  tasks:              # 任务列表:后续所有具体操作都放在tasks下
    - name: install Nginx  # 子任务名称:描述当前步骤作用
      yum:                # 使用yum模块
        name: nginx       # 安装的软件名称:nginx
        state: present    # 状态:present表示确保软件已安装
    
    - name: stop firewalld
      service:              # 使用service模块:管理系统服务
        name: firewalld     # 操作的服务名称:firewalld
        state: stopped      # 服务状态:stopped表示停止当前服务
        enabled: no         # 开机自启:no表示禁止服务开机自动启动
    
    - name: stop SELinux    # 子任务名称
      command: setenforce 0 # 使用command模块执行系统命令

先写这么多,后面有时间再多写点干货🤭。

相关推荐
Elastic 中国社区官方博客3 分钟前
测试 Elasticsearch,现在变得更简单了
大数据·运维·elasticsearch·搜索引擎·全文检索
木子欢儿9 分钟前
在 Debian 12 上安装多个版本的 php(7.3、7.4、8.1、8.2)
运维·开发语言·debian·php
DJ斯特拉11 分钟前
Docker基本使用
运维·docker·容器
菩提树下的凡夫15 分钟前
基于C++语言的Onnx CUDA加速部署推理
linux·运维·人工智能
竹之却25 分钟前
Ubuntu 系统安装 Ollama 教程
linux·运维·ubuntu·ollama
珠海西格26 分钟前
4 月 1 日起执行分布式光伏监控新规,直接影响从业者与项目收益
大数据·运维·服务器·分布式·能源
Leinwin9 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
2401_865382509 小时前
信息化项目运维与运营的区别
运维·运营·信息化项目·政务信息化
漠北的哈士奇9 小时前
VMware Workstation导入ova文件时出现闪退但是没有报错信息
运维·vmware·虚拟机·闪退·ova
如意.7599 小时前
【Linux开发工具实战】Git、GDB与CGDB从入门到精通
linux·运维·git