登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
1
2
/ 2 页
下一页
返回列表
首页
›
资源区
›
代码
›
Ansible 核心功能模块与应用场景全解析
Ansible 核心功能模块与应用场景全解析
[ 复制链接 ]
梁宁
2025-6-2 23:23:32
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
一、软件管理类模块
1. yum/dnf 模块
功能
:管理 RPM 软件包(安装/升级/删除)
典型场景
:
批量部署基础环境(如安装 Nginx/MySQL)
自动化更新安全补丁
示例参数
:
- name: Install httpd
yum:
name: httpd
state: latest
复制代码
2. apt 模块
功能
:管理 DEB 软件包(Ubuntu/Debian)
典型场景
:
配置 APT 源仓库
安装特定版本软件
示例参数
:
---
- name: 管理 DEB 软件包
hosts: ubuntu_servers
become: yes # 需要 root 权限
vars:
target_package: nginx
package_version: "1.18.0-0ubuntu1"
tasks:
# 场景 1:配置 APT 源仓库
- name: 添加 Docker 官方 APT 源
ansible.builtin.apt_repository:
repo: "deb [arch=amd64] https://download.docker.com/linux/ubuntu {{ ansible_distribution_release }} stable"
state: present
filename: docker.list # 存储到 /etc/apt/sources.list.d/docker.list
update_cache: yes
# 场景 2:安装特定版本软件
- name: 安装指定版本软件包
ansible.builtin.apt:
name: "{{ target_package }}={{ package_version }}"
state: present
update_cache: yes
复制代码
二、文件管理类模块
1. copy 模块
功能
:传输本地文件到远程主机
典型场景
:
分发统一配置文件(如 nginx.conf )
部署静态资源文件
高级用法
:
- copy:
src: app_config.ini
dest: /etc/app/
mode: 0644
复制代码
2. template 模块
功能
:带变量替换的文件传输
典型场景
:
动态生成环境差异配置(如数据库连接地址)
多节点差异化部署
示例参数
:
---
- name: 动态配置部署
hosts: all
become: yes
vars:
# 基础变量定义
db_connection: "{{ hostvars[inventory_hostname]['db_host'] }}:3306"
deploy_path: "/opt/{{ app_name }}"
tasks:
- name: 创建配置目录
ansible.builtin.file:
path: "{{ deploy_path }}/conf"
state: directory
mode: '0755'
- name: 生成动态配置文件
ansible.builtin.template:
src: templates/app_config.j2 # Jinja2模板文件
dest: "{{ deploy_path }}/config.yml"
mode: '0644'
validate: '/usr/bin/yamllint %s' # 配置文件语法校验[1]()
- name: 分发差异证书文件
ansible.builtin.copy:
src: "certs/{{ cert_type }}.pem" # 根据节点类型选择证书
dest: "{{ deploy_path }}/ssl.pem"
复制代码
三、服务管理类模块
1. service/systemd 模块
功能
:管理系统服务状态
典型场景
:
批量重启异常服务
配置开机自启动
示例参数
:
- service:
name: nginx
state: restarted
enabled: yes
复制代码
四、用户权限类模块
1. user 模块
功能
:管理用户账号
典型场景
:
批量创建应用专用账户
设置用户密码过期策略
示例参数
:
- user:
name: appuser
groups: www-data
shell: /sbin/nologin
复制代码
2. lineinfile 模块
功能
:精准修改文件指定行
典型场景
:
配置 SSH 安全策略
修改系统内核参数
示例参数
:
- lineinfile:
path: /etc/ssh/sshd_config
regexp: '^#PermitRootLogin'
line: 'PermitRootLogin no'
复制代码
五、系统信息类模块
1. setup 模块
功能
:收集主机系统信息
典型场景
:
资产信息自动化采集
条件判断依据获取(如根据系统版本执行不同操作)
示例参数
:
---
- name: 采集主机信息并执行条件操作
hosts: all
become: yes
gather_facts: no # 显式禁用默认 facts 收集
tasks:
# ---------------------------
# 核心功能模块
# ---------------------------
- name: 收集完整系统信息
ansible.builtin.setup:
gather_subset:
- all # 收集所有信息子集[1]()
- !hardware # 排除硬件相关数据
filter: "ansible_distribution_*" # 过滤发行版信息[2]()
register: host_facts
# ---------------------------
# 资产信息处理
# ---------------------------
- name: 生成资产报告文件
ansible.builtin.template:
src: reports/host_report.j2
dest: "/var/log/ansible/{{ inventory_hostname }}_report.txt"
when: host_facts.ansible_facts.ansible_os_family == "Debian"
# ---------------------------
# 条件判断应用
# ---------------------------
- name: 针对 Ubuntu 20.04 的特殊配置
ansible.builtin.apt:
name: nginx
state: latest
when:
- host_facts.ansible_facts.ansible_distribution == "Ubuntu"
- host_facts.ansible_facts.ansible_distribution_major_version >= "20"
- name: 针对 CentOS 的防火墙配置
ansible.builtin.yum:
name: firewalld
state: present
when: host_facts.ansible_facts.ansible_os_family == "RedHat"
复制代码
六、任务调度类模块
1. cron 模块
功能
:管理定时任务
典型场景
:
部署日志轮转任务
配置备份脚本定时执行
示例参数
:
- cron:
name: "Daily backup"
minute: "0"
hour: "2"
job: "/opt/backup.sh"
复制代码
七、网络管理类模块
1. get_url 模块
功能
:从网络下载文件
典型场景
:
离线环境预下载安装包
获取远程配置文件
示例参数
:
- name: 下载离线安装包
ansible.builtin.get_url:
url: "https://example.com/packages/nginx-1.18.0.deb"
dest: "/opt/packages/nginx.deb"
checksum: "sha256:2e1a6dda32e987d3011223f33ef16aee3f4862ac9d28c3d4855c9d15205652d5"
mode: '0644'
force: no # 仅在文件不存在时下载
---
- name: 拉取动态配置文件 #获取远程配置文件
ansible.builtin.get_url:
url: "http://config-server/app.conf"
dest: "/etc/app/app.conf"
validate_certs: no # 适用于自签名证书场景
timeout: 30
headers:
Authorization: "Bearer {{ auth_token }}"
复制代码
模块对比与选型建议
场景需求推荐模块优势特性简单命令执行command无依赖、快速执行复杂脚本执行shell支持管道/重定向批量文件分发synchronize增量同步高效配置版本管理git集成版本控制
实践建议
:优先使用声明式模块(如 yum/file),减少 shell/command 的使用频率以增强可维护性。建议配合 ansible-lint 进行剧本规范性检查。
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
Ansible
核心
功能模块
应用
场景
相关帖子
HagiCode 启动页设计:React 19 应用中填补 Hydration 空白期的极致体验
DeepResearch 应用展示
AI 应用开发者的福音 —— OceanBase seekdb JavaScript / TypeScript SDK 正式开源!
.NET AI 核心构建块:重塑智能应用开发的架构范式与生态
PWM子系统基础学习与应用笔记
PHP 应用遭遇 DDoS 攻击时会发生什么 从入门到进阶的防护指南
Flask - 常见应用部署方案
linux设备驱动阻塞IO应用
AI元人文:制造、部署应用与养护AI(岐式参考)
【Parasoft应用案例】在 DO-178C 标准下,实现航空嵌入式软件测试自动化
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
HagiCode 启动页设计:React 19 应用中填补 Hydration 空白期的极致体验
10
781
腥狩频
2026-02-04
安全
DeepResearch 应用展示
13
69
锟及
2026-02-04
安全
AI 应用开发者的福音 —— OceanBase seekdb JavaScript / TypeScript SDK 正式开源!
14
43
倡粤
2026-02-05
业界
.NET AI 核心构建块:重塑智能应用开发的架构范式与生态
11
1011
何书艺
2026-02-06
安全
PWM子系统基础学习与应用笔记
4
679
费卿月
2026-02-06
业界
PHP 应用遭遇 DDoS 攻击时会发生什么 从入门到进阶的防护指南
0
13
游康
2026-02-09
业界
Flask - 常见应用部署方案
1
738
注思
2026-02-14
业界
linux设备驱动阻塞IO应用
1
646
咸和璧
2026-02-16
安全
AI元人文:制造、部署应用与养护AI(岐式参考)
0
972
琉艺戕
2026-02-16
业界
【Parasoft应用案例】在 DO-178C 标准下,实现航空嵌入式软件测试自动化
0
292
敛饺乖
2026-02-17
回复
(26)
百里宵月
2025-10-20 20:04:19
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
这个好,看起来很实用
汇干环
2025-12-6 01:52:39
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
用心讨论,共获提升!
梁丘艷蕙
2025-12-17 01:30:57
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
这个好,看起来很实用
彭水晶
2025-12-20 10:51:59
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享
杠氯
2025-12-24 18:56:16
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
谢谢楼主提供!
济曝喊
2026-1-6 12:22:17
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
喜欢鼓捣这些软件,现在用得少,谢谢分享!
任静柔
2026-1-14 15:33:00
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
这个有用。
铜坠匍
2026-1-14 15:51:50
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
很好很强大 我过来先占个楼 待编辑
墨佳美
2026-1-18 07:02:59
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
yyds。多谢分享
峰邑
2026-1-19 12:08:26
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢发布原创作品,程序园因你更精彩
褐洌
2026-1-23 02:34:51
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢发布原创作品,程序园因你更精彩
煅汾付
2026-1-24 08:45:29
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
热心回复!
金娅鸣
2026-1-26 11:09:42
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
分享、互助 让互联网精神温暖你我
丘娅楠
2026-1-28 03:53:23
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
分享、互助 让互联网精神温暖你我
沃盼盼
2026-1-30 06:56:27
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享,学习下。
尹疋
2026-2-8 06:14:58
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
喜欢鼓捣这些软件,现在用得少,谢谢分享!
骆贵
2026-2-8 12:00:10
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享,下载保存了,貌似很强大
俏襟选
2026-2-8 16:08:51
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
不错,里面软件多更新就更好了
史华乐
2026-2-8 17:41:10
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
前排留名,哈哈哈
下一页 »
1
2
/ 2 页
下一页
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
科技
业界
安全
签约作者
程序园优秀签约作者
发帖
梁宁
2026-2-8 17:41:10
关注
0
粉丝关注
25
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991124
anyue1937
9994892
kk14977
6845359
4
xiangqian
638210
5
宋子
9897
6
韶又彤
9918
7
闰咄阅
9993
8
刎唇
9995
9
蓬森莉
9883
10
遗憩
10006
查看更多
今日好文热榜
3
CSP-J2025游记
6
从挖矿木马入侵到 Docker Rootless 加固,
319
OpenClaw多Agent协作踩坑实录:从翻车到跑
713
【节点】[MainLightShadow节点]原理解析与
633
模拟退火算法
902
Claude Code 的 Skills 可以在 Trae IDE 中
254
付费 AI 用户和免费用户之间,究竟差了什么
699
手把手教你使用vscode开发stm32!
1003
“老东西,你懦弱了”——关于Vibe Coding
926
告别Hyprland/Niri键鼠共享难题:Pynergy
752
解惑|公司员工健身房需要哪些器材?上海皓
519
凸优化数学基础笔记(六):凸集、凸函数与
3
【强化学习的数学原理-赵世钰】随记
389
SeeDance2.0提示词之跳舞女孩
11
SeeDance2.0提示词之跳舞女孩
683
国内零门槛首个免费 开源 7×24小时帮
572
[拆解LangChain执行引擎]非常规Pending Wri
3
读人工智能全球格局:未来趋势与中国位势10
70
AI开发-python-milvus向量数据库(2-8 -mil