NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

自动化运维 - 云装机实践

  • 2019-09-22
  • 本文字数:1360 字

    阅读完需:约 4 分钟

自动化运维-云装机实践

项目背景

随着 IDC 服务器数不断增加,服务器系统变更频繁,系统安装工作日益繁重,需要管理员到机房一台一台安装。新增、变更服务器资产信息无法自动录入 CMDB,手动录入设备信息容易出现错误。整个装机操作耗时耗力,服务器自动化装机、管理已经迫在眉睫。

功能介绍

云装机系统支持远程自动化安装操作系统。提供远程开关机、自动采集服务器信息功能,支持系统模板管理,可根据不同业务线和硬件配置自动选择系统模板,支持录入机架信息、IP 信息,实时显示装机进度,装机完成信息自动录入 CMDB 等功能。

核心技术

PXE:网络引导启动。支持客户机通过网络从远端服务器下载镜像,并由此通过网络安装操作系统。


KS 文件:自动化安装操作系统。通过创建一个单独的,包含安装过程中遇到的所有问题答案的文件,即在装机过程中需要手动选择和配置的选项。同时可以在 ks 文件里加入 shell 脚本,进行装机进度汇报等操作。

与原生 PXE+KS 对比

基于 PXE+KS 开发,再此基础上增加了一些新的功能,自动采集服务器信息,同步到云装机管理后台,防止后期手动录入导致数据错误。云装机管理后台支持多种装机模板管理,为新设备自动选择装机模板。支持录入服务器所在机房机架信息,用于后期机房可视化管理。支持同时进行多台设备装机,支持在管理后台实时查看装机进度。系统装机完成自动同步服务器信息到 CMDB,保证服务器数据准确性。

系统架构

主要分三层结构,六大功能模块。采用分层思想,前后端分离,模块之间通过 API 接口进行调用,相互独立。


系统各个功能模块如下:


UI 模块:提供远程开关机、发现,录入新设备、设备列表管理,系统模板管理等功能

Server 模块:提供 API 服务,包括数据录入查询等,对接 UI 模块和底层安装模块

HardWare 模块:提供支持的硬件设备信息,提供手动添加新的硬件设备等功能

CMDB 模块:存储服务器硬件信息、系统信息、机架信息、管理员信息等

BootOS 模块:通过 agent 进行信息采集上报,使管理员自动发现新设备。

底层安装模块:提供 dhcp/tftp/http/dns 等物理机安装服务


装机流程

1、通过远程管理卡从 PXE 启动服务器

2、启动后首先进入 BootOS,启动内置的 Agent 组件

3、Agent 采集信息上报到 Server 模块,在管理后台发现新设备

4、管理后台录入服务器信息,进入装机队列

5、然后 Agent 上报 mac 地址,通知 Server 端生成 PXE 安装文件

6、最后 Agent 会重启服务器,并进入系统安装流程

7、进入系统安装以后,获取 KS 文件、系统镜像文件

8、安装操作系统,并运行系统初始化 post 脚本

9、上报安装进度通知 Server 端安装完成,重启进入系统

10、Server 端同步安装信息到 CMDB 系统


系统使用展示

第一步:从 PXE 启动服务器。



第二步:发现新设备。



第三步:录入新设备。



第四步:查看装机进度。



第五步:装机完成自动录入 CMDB


系统现状

已替代传统装机方式,实现远程快速的安装操作系统,支持多台机器同时安装操作系统,历史最大并发装机数 30 台。服务器从资产录入到服务器安装,之前需要 20 多分钟,现在可以控制在 10 分钟之内操作完成,单台装机速度提升 50%,目前累计装机 600+台,系统模板 30+个。


作者介绍:


巩立新,技术保障部,运维开发工程师,参与开发 IDC 自动化、门店网络监管、通用调研等项目。


本文转载自公众号贝壳产品技术(ID:gh_9afeb423f390)。


原文链接:


https://mp.weixin.qq.com/s/fSrWF4PFZkvky7rkeCf46w


2019-09-22 21:171026

评论

发布
暂无评论
发现更多内容

浩若烟海事半功倍|利用Docker容器技术构建自动化分布式web测试集群Selenium Grid

刘悦的技术博客

Docker Python3 测试 单元测试 测试环境 selenium

Linux之nl命令

入门小站

Linux

[译] D8 类库脱糖

Antway

6月日更

AI论文解读:基于Transformer的多目标跟踪方法TrackFormer

华为云开发者联盟

预测 Transformer 多目标跟踪 TrackFormer 跟踪目标

带你认识9种常用卷积神经网络

华为云开发者联盟

神经网络 深度学习 卷积神经网络 图像 卷积

架构师实战营 模块七总结

代廉洁

架构实战营

前端 JavaScript 中的三种 for 循环语句总结

编程三昧

JavaScript 大前端 for循环

使用SpringCloud的openFeign组件踩坑纪实

小江

dubbo Feign spring-cloud

网络攻防学习笔记 Day57

穿过生命散发芬芳

网络攻防 6月日更

容器化 | 在 Kubernetes 上部署 RadonDB MySQL 集群

RadonDB

MySQL Kubernetes 容器

计算机网络的 89 个核心概念

cxuan

后端 计算机网络 网络

JAVA 面向对象 (十三)-- 关键字static

加百利

Java 6月日更

Rust从0到1-自动化测试-测试组织

rust 单元测试 集成测试 自动化测试

冰泉奶茶香牙膏好不好?奶茶控的宝藏牙膏就是它

Geek_50a546

30分钟接入SDK 融云是如何让开发者做到开箱即用的?

融云 RongCloud

从2021钉峰会,看钉钉生态背后的强大赋能力

ToB行业头条

钉钉

为什么 Python 没有函数重载?如何用装饰器实现函数重载?

Python猫

Python

APP 开发技术如何进行选型 ?

程序员海军

大前端 App 技术选型 APP开发

12种mysql常见错误总结 +分析示例

李阿柯

MySQL 面试 常见问题

架构师实战营 模块七作业(王者荣耀商城的异地多活架构设计)

代廉洁

架构实战营

JavaScript学习(十一)---RegExp对象

空城机

JavaScript 大前端 6月日更

为什么switch的case没有break不行

叫我阿柒啊

Switch case break

EasyRecovery——一款专业的数据恢复软件

淋雨

文件恢复 Easyrecovery破解 免费恢复软件 硬盘数据恢复

使用 Scala 宏解决对象转换

GrowingIO技术专栏

scala protobuf 元编程 macro

页面制作的15个CSS技巧

devpoint

CSS css3 Flex 6月日更

在线sitemap链接提取工具

入门小站

工具

一步步设计版本控制系统

Java·课代表

git 版本控制 版本管理

代码管理工具:Git和SVN

正向成长

git svn

数据结构——顺序表

若尘

数据结构 6月日更

基于 Web 引擎扩展技术的 RTC 混合开发框架实践

白玉兰开源

大前端

全网最详细XSS跨站脚本攻击,不是过来打死我!!

网络安全学海

程序员 网络安全 信息安全 XSS 漏洞修复

自动化运维-云装机实践_文化 & 方法_巩立新_InfoQ精选文章