Ansible 核心运维场景落地:YUM 仓库、SSH 公钥、固定 IP 配置技巧

1:如何一次性验证所有主机能否被 Ansible 访问?

答:使用临时命令:ansible all -m ansible.builtin.ping

或验证 sudo 是否正常:ansible all -m ansible.builtin.ping --become -K

2:如何用 Ansible 统一配置 YUM/DNF 仓库并导入 GPG key?

答:

  • 写仓库文件:

yaml

  • name: 配置 EPEL

ansible.builtin.yum_repository:

name: epel

description: EPEL

baseurl: https://download.fedoraproject.org/pub/epel/$releasever/$basearch/

gpgcheck: 1

gpgkey: https://download.fedoraproject.org/pub/epel/RPM-GPG-KEY-EPEL-{{ ansible_distribution_major_version }}

  • 导入公钥:

yaml

  • name: 导入 EPEL GPG key

ansible.builtin.rpm_key:

key: https://download.fedoraproject.org/pub/epel/RPM-GPG-KEY-EPEL-{{ ansible_distribution_major_version }}

state: present

  • 装包:

yaml

  • name: 安装 htop

ansible.builtin.dnf:

name: htop

state: present

3:如何在 100 台服务器上批量创建运维用户并下发 SSH 公钥?

答:用 user + authorized_key 模块:

yaml

  • name: 创建 ops 用户

ansible.builtin.user:

name: ops

groups: wheel

shell: /bin/bash

generate_ssh_key: yes

  • name: 下发公钥到 ops 用户

ansible.posix.authorized_key:

user: ops

key: "{{ lookup('file', '~/.ssh/id_rsa.pub') }}"

4:如何确保只有 wheel 组可免密 sudo?

答:用 lineinfile 修改 sudoers:

yaml

  • name: 配置 sudoers

ansible.builtin.lineinfile:

path: /etc/sudoers

regexp: '^%wheel'

line: '%wheel ALL=(ALL) NOPASSWD:ALL'

validate: 'visudo -cf %s'

5:如何每天晚上 2 点跑备份脚本?

答:cron 模块:

yaml

  • name: 添加备份计划任务

ansible.builtin.cron:

name: nightly-backup

minute: "0"

hour: "2"

job: /usr/local/bin/backup.sh

user: root

6:如何用系统角色一键创建 20 GB 的逻辑卷并挂载到 /data?

答:调用 redhat.rhel_system_roles.storage:

yaml

  • hosts: db_servers

vars:

storage_pools:

  • name: vg_data

disks: [sdb]

volumes:

  • name: lv_data

size: 20g

mount_point: /data

fs_type: xfs

roles:

  • redhat.rhel_system_roles.storage

7:如何给一批主机同时配置固定 IP、网关和 DNS?

答:使用redhat.rhel_system_roles.network:

yaml

  • hosts: web_servers

vars:

network_connections:

  • name: ens192

type: ethernet

autoconnect: yes

ip:

address:

  • 192.168.10.50/24

gateway: 192.168.10.1

dns:

  • 8.8.8.8

  • 8.8.4.4

state: up

roles:

  • redhat.rhel_system_roles.network

8:如何立即重启机器并等待其重新上线?

答:reboot 模块:

yaml

  • name: 重启并等待

ansible.builtin.reboot:

reboot_timeout: 600

相关推荐
johnny2334 小时前
运维管理面板:AcePanel、OpenOcta、DeepSentry
运维
青梅橘子皮4 小时前
Linux---基本指令
linux·运维·服务器
REDcker5 小时前
Linux信号机制详解 POSIX语义与内核要点 sigaction与备用栈实践
linux·运维·php
cui_ruicheng6 小时前
Linux进程间通信(三):System V IPC与共享内存
linux·运维·服务器
蚰蜒螟6 小时前
深入 Linux 内核同步机制:从 futex 到 spinlock 的完整旅程
linux·windows·microsoft
运维全栈笔记6 小时前
Linux安装配置Tomcat保姆级教程:从部署到性能调优
linux·服务器·中间件·tomcat·apache·web
小白学大数据6 小时前
Python 自动化爬取网易云音乐歌手歌词实战教程
爬虫·python·okhttp·自动化
dllmayday7 小时前
Linux 上用终端连接 WiFi
linux·服务器·windows
ACP广源盛139246256737 小时前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑
峥无8 小时前
Linux系统编程基石:静态库·动态库·ELF文件·进程地址空间全景图
linux·运维·服务器