阅读量:2
在 Debian 上使用脚本自动化 Cobbler 任务
一 总体思路与前置条件
- 在 Debian 服务器上安装并启用 Cobbler 及其依赖(如 cobbler cobbler-web dhcp tftp-server pykickstart httpd),将 server 与 next_server 指向本机 IP,按需开启 manage_dhcp 并用 cobbler sync 使配置生效。导入 Debian ISO 或 Netboot 镜像,创建 Profile/System,在 Profile 上绑定 Preseed(Debian 的无人值守应答文件),客户端以 PXE 启动即可无人值守安装。关键检查与日志:cobbler check、/var/log/cobbler/cobbler.log。
二 自动化脚本骨架与用法
- 目标:用脚本完成“环境校验 → 配置 → 导入镜像 → 创建 Profile/System → 同步 → 触发安装”的闭环,并支持 CSV 批量导入主机。
- 示例脚本(可直接改造使用,按需替换变量):
#!/usr/bin/env bash
set -Eeuo pipefail
# ===== 用户可配置 =====
COBBLER_IP="192.168.1.100"
DHCP_SUBNET="192.168.1.0"
DHCP_RANGE="192.168.1.100 192.168.1.200"
ROUTER="192.168.1.1"
DNS_SERVERS="8.8.8.8 1.1.1.1"
DEBIAN_ISO="/path/to/debian.iso"
PROFILE_NAME="debian-12-amd64"
SEED_FILE="/var/lib/cobbler/templates/debian.seed"
# ======================
log(){ echo "[$(date '+%F %T')] $*"; }
# 1) 环境校验
log "检查 cobbler 与必要服务..."
systemctl is-active --quiet cobblerd || { log "启动 cobblerd"; systemctl start cobblerd; }
systemctl is-active --quiet tftpd-hpa || { log "启动 tftpd-hpa"; systemctl start tftpd-hpa; }
systemctl is-active --quiet apache2 || { log "启动 apache2"; systemctl start apache2; }
if command -v dhcpd >/dev/null 2>&1; then
systemctl is-active --quiet isc-dhcp-server || { log "启动 isc-dhcp-server"; systemctl start isc-dhcp-server; }
fi
# 2) 写入关键配置
log "写入 /etc/cobbler/settings"
sed -i "s/^server: .*/server: ${COBBLER_IP}/" /etc/cobbler/settings
sed -i "s/^next_server: .*/next_server: ${COBBLER_IP}/" /etc/cobbler/settings
# 按需开启:manage_dhcp、manage_tftp(示例开启 DHCP)
sed -i "s/^manage_dhcp: .*/manage_dhcp: 1/" /etc/cobbler/settings
sed -i "s/^manage_tftp: .*/manage_tftp: 1/" /etc/cobbler/settings
# 3) 配置 DHCP 模板
log "配置 DHCP 子网"
cat >/etc/cobbler/dhcp.template <<EOF
subnet ${DHCP_SUBNET} netmask 255.255.255.0 {
option routers ${ROUTER};
option domain-name-servers ${DNS_SERVERS};
range dynamic-bootp ${DHCP_RANGE};
default-lease-time 21600;
max-lease-time 43200;
next-server \$next_server;
}
EOF
# 4) 导入镜像(若已导入可跳过)
if ! cobbler distro list | grep -qw "${PROFILE_NAME}"; then
log "挂载并导入 ISO: ${DEBIAN_ISO}"
mkdir -p /mnt/debian
mount -o loop "${DEBIAN_ISO}" /mnt/debian
cobbler import --path=/mnt/debian --name="${PROFILE_NAME}"
umount /mnt/debian
fi
# 5) 绑定 Preseed
if [[ -f "${SEED_FILE}" ]]; then
log "绑定 Preseed: ${SEED_FILE}"
cobbler profile edit --name="${PROFILE_NAME}" --autoinstall="${SEED_FILE}"
fi
# 6) 同步
log "同步配置到 DHCP/TFTP/HTTP"
cobbler sync
# 7) 可选:从 CSV 批量注册主机(CSV 列:mac,ip,hostname,gateway)
register_from_csv(){
local csv="$1"
while IFS=',' read -r mac ip hostname gateway; do
[[ -z "${mac}" || "${mac}" =~ ^# ]] && continue
local name="host-${ip##*.}"
cobbler system add \
--name="${name}" \
--profile="${PROFILE_NAME}" \
--mac="${mac}" \
--ip-address="${ip}" \
--subnet="255.255.255.0" \
--gateway="${gateway:-${ROUTER}}" \
--hostname="${hostname}" \
--name-servers="${DNS_SERVERS}"
done < <(sed 's/\r//g' "$csv")
}
# 示例:register_from_csv "hosts.csv"
# 客户端需设置 PXE 启动,上电后将自动安装
log "完成。请为目标主机设置 PXE 启动。"
- 使用要点
- 将脚本与 hosts.csv 配合使用即可批量注册主机;CSV 示例:
- 00:11:22:33:44:55,192.168.1.101,host1.example.com,192.168.1.1
- 00:11:22:33:44:56,192.168.1.102,host2.example.com,192.168.1.1
- 每次修改 Profile/System/DHCP 后务必执行 cobbler sync。
- 客户端需在同一二层网段、以 PXE 启动,且防火墙放行 DHCP/TFTP/HTTP。
- 将脚本与 hosts.csv 配合使用即可批量注册主机;CSV 示例:
三 在 Preseed 中执行安装后脚本
- 在 Debian Preseed(debian.seed) 中使用 preseed/late_command 执行安装完成后的任意脚本(本地或远程):
# 示例:安装后执行本地脚本(位于安装介质的 preseed/late_command 可访问路径)
d-i preseed/late_command string \
in-target sh -c ' \
apt-get update && apt-get install -y curl vim htop; \
echo "部署完成: $(date)" > /root/deploy-done.txt; \
'
# 示例:从内网 Git 拉取并运行配置脚本
# d-i preseed/late_command string \
# in-target sh -c ' \
# apt-get update && apt-get install -y git; \
# git clone https://git.example.com/deploy.git /root/deploy && \
# bash /root/deploy/bootstrap.sh; \
# '
- 说明
- 将需要自动化的动作(软件安装、用户创建、配置管理、CM 客户端安装等)放入 late_command,即可实现“装机即配置”。
- 若脚本较大或需复用,建议放到内网 HTTP/HTTPS 服务器,用 wget/curl 拉取执行。
四 批量编排与 API 方式
- 命令行批量化:结合 CSV 与脚本循环调用 cobbler system add 可快速为成百上千台主机生成 System 条目,实现“零接触”装机。
- API 自动化:Cobbler 提供可编程接口,适合与 Ansible/自研平台 集成。示例(Python,需安装 cobbler-api):
import cobbler_api
api = cobbler_api.CobblerAPI("http://${COBBLER_IP}/cobbler_api", "cobbler", "cobbler")
api.add_system({
"name": "host-192-168-1-101",
"profile": "debian-12-amd64",
"mac_address": "00:11:22:33:44:55",
"ip_address": "192.168.1.101",
"hostname": "host1.example.com",
"gateway": "192.168.1.1",
"name_servers": ["8.8.8.8", "1.1.1.1"],
"netboot_enabled": True
})
# 变更后同步
api.sync()
- 适用场景
- 与 CMDB/资产系统联动,按业务线自动生成 System、选择 Profile/Seed,实现全自动交付流水线。
五 排错与最佳实践
- 常用检查
- 执行 cobbler check,按提示修复(如 loader、服务、配置项)。
- 查看 /var/log/cobbler/cobbler.log 与 journalctl -u cobblerd/tftpd-hpa/apache2,定位导入、同步、引导失败原因。
- 确保 DHCP/TFTP/HTTP 端口未被防火墙拦截,且 next-server 与 server 配置正确。
- 网络与多 DHCP 冲突
- 同一二层网段避免存在多个 DHCP 服务;若使用外部 DHCP,请将 manage_dhcp=0 并在外部 DHCP 配置 next-server 指向 Cobbler 服务器。
- 镜像与引导
- 若导入的 ISO 缺少 PXE 引导文件(如 initrd.gz),可使用 Debian Netboot 镜像或补齐引导文件后再导入。
- 幂等与可重复执行
- 脚本中先判断对象是否存在(如 distro/profile 是否已导入),再执行创建/绑定,保证可重复运行。
以上就是关于“如何在Debian Cobbler中使用脚本自动化任务”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm