centos 9 Kickstart + Ansible自动化部署 —— 筑梦之路

目标

利用 Kickstart 完成 centos 9 系统的全自动安装(裸金属/虚拟机)。

安装完成后自动接入 Ansible 进行软件包、服务、用户、配置等系统初始化操作。

实现一套通用、可重复、可维护的自动化交付流程。

KS文件

bash 复制代码
# ks.cfg 示例
install
lang zh_CN.UTF-8
keyboard us
timezone Asia/Shanghai
network --bootproto=dhcp --device=eth0 --onboot=on
rootpw --iscrypted <HASHED_PASSWORD>
firewall --enabled --service=ssh
authconfig --enableshadow --passalgo=sha512
selinux --enforcing
bootloader --location=mbr
reboot

# 分区
clearpart --all --initlabel
part /boot --fstype=ext4 --size=1024
part swap --size=1024
part / --fstype=xfs --grow --size=1

%packages
@core
vim
wget
curl
openssh-server
python3
%end

%post
echo "Post install begins..."
curl -o /root/bootstrap.sh http://<IP>/ansible/bootstrap.sh
chmod +x /root/bootstrap.sh
/root/bootstrap.sh
%end

脚本

bash 复制代码
#bootstrap.sh 示例(Post-install 脚本)
#!/bin/bash
yum install -y python3 python3-pip
pip3 install ansible
mkdir -p /etc/ansible
curl -o /etc/ansible/hosts http://<IP>/ansible/inventory
curl -o /root/site.yaml http://<IP>/ansible/site.yaml

ansible-playbook /root/site.yaml -i /etc/ansible/hosts
bash 复制代码
 site.yaml 示例

- hosts: all
  become: true
  roles:
    - base
    - ssh
    - firewall
    - monitoring
    - docker
bash 复制代码
Roles 结构(简化版)

roles/
├── base/       # 基础配置(时区、主机名、NTP)
├── ssh/        # SSH 优化
├── firewall/   # 防火墙规则开放
├── monitoring/ # 安装 Zabbix Agent 或 Prometheus Node Exporter
├── docker/     # 安装容器环境

实践建议

  1. 版本控制

使用 Git 管理 Ansible Playbook 和 Kickstart 模板,便于审计和变更追踪。

  1. 模板参数化

利用 Jinja2 模板实现主机名、网段、角色等自动替换,提高复用率。

  1. 分环境处理

按 prod、test、dev 维护不同 inventory 和 Playbook 逻辑。

  1. 安全控制

Kickstart 中密码使用 openssl passwd -6 加密。

Playbook 中敏感数据用 ansible-vault 管理。

  1. 日志与追踪

Kickstart %post 输出日志到 /root/kickstart.log

Ansible 启用 log_path,记录执行详情

bash 复制代码
整体流程:

[ PXE + DHCP ]
      │
      ▼
[ 加载 Kickstart 自动安装 ]
      │
      ▼
[ Post 脚本安装 Ansible 并执行 Playbook ]
      │
      ▼
[ 系统初始化完成,加入运维体系 ]
相关推荐
jinglong.zha29 分钟前
LScript-从零基础到商业变现的AI自动化学习平台
运维·学习·自动化
苏州邦恩精密2 小时前
江苏三维扫描仪厂家如何选择合适的工业测量方案?
人工智能·科技·机器学习·3d·自动化·制造
lbb 小魔仙2 小时前
【Linux】DevOps 工程师必备:Linux 自动化脚本与高效工具链整合
linux·自动化·devops
梦想的旅途23 小时前
企业微信外部群主动调用:RPA 接口与官方 API 的技术边界
网络·mysql·自动化·企业微信·rpa
AC赳赳老秦4 小时前
OpenClaw 助力技术面试:自动生成面试题、模拟面试、整理面试知识点
开发语言·python·面试·职场和发展·自动化·deepseek·openclaw
元启数宇4 小时前
机电设计AI不只是消防:给排水、暖通、强弱电如何进入自动化?
运维·人工智能·自动化
CHrisFC4 小时前
LIMS 系统 AI 建设路径:从自动化到智能化的演进之路
运维·人工智能·自动化
蜡笔婧萱5 小时前
磁盘监控 + Web 服务巡检自动化脚本实训任务
运维·自动化
Techblog of HaoWANG5 小时前
智巡守卫:多模态巡检智能体算法服务端设计与实现——基于Ollama+Qwen3.5的自动化巡检报告生成系统
运维·人工智能·算法·目标检测·自动化·边缘计算
有什么事5 小时前
AI革命:云手机从脚本到智能体的跨越
人工智能·智能手机·自动化