PXE

  • 预启动执行环境,基于tftp条件下完成基于网络的自动化部署软件
  • 原理:
    1. 网卡利用自身的tftp 请求dhcp 服务器获取ip和一个pxelinux.0的地址
    1. 在给定的tftp目录下存有ks的配置文件,指定开机后从哪里获取内核、initrd和系统光盘包文件,
    1. 一般设定的网络地址下载系统文件然后执行安装,安装参数也会在填写的网络地址中存放,即ks.cfg文件
  • ks.cfg应答文件一般由对应系统可以生成,需要安装对应的包,文件中包含了安装需要的文件和执行前后脚本用户配置等

    自动化部署centos7实战

    条件

  • selinux firewall :enable
  • dhcpd,httpd:192.168.47.25 tftp-server:192.168.47.26 安装和配置完成
  • 下载安装 yum -y install syslinux

    配置yum源:

  • mkdir /centos/7/isos/x86_64 -pv 在web服务器/var/www/html下创建文件夹,
  • mount -o /dev/sr0 /var/www/html/centos/7/isos/x86_64/(光盘文件挂载到这里)
  • http://192.168.47.25/centos/7/isos/x86_64/,访问光盘看是否能够访问

    制作应答文件

    1. yum install kicstart
    1. 利用cento7的kickstart 程序 执行system-config-kickstart 在图形界面下定制自己所需要的配置生成ks.cfg文件
    1. 应答文件需要指定yum源位置为前面web的光盘挂载的文件目录
    1. 将应答文件放置到网站根目录下,cp -p ks.cfg /var/www/html/
    1. http://192.168.47.25/ks.cfg 查看是否能够访问

      dhcp 配置

    1. 复制模板文件:cp /user/share/doc/dhcp-4.3.5/dhcpd.config.example,到/etc/dhcp/下改名成为配置文件dhcpd.config
    1. subnet中加入tftp的pxelinux下载地址:next-server 192.168.47.26 filename"pxelinux.0"
    1. 完成重启服务

      tftp-server配置

  • tftp目录文件夹: /var/lib/tftpboot
    1. 在tftp服务目录下创建一个pxelinux.cfg的文件夹:mkdir pxelinux.cfg( /var/lib/tftpboot/下)
    1. 复制 /usr/share/syslinux/{pxelinux.0,menu.c32} 到tftp服务器的文件目录下
    1. 将kernel和initrd.img 文件从光驱复制到文件目录下(同上面放置yum源一样挂载光驱然后拉取isolinux文件夹中的这两个文件)
    1. 将创建命名default后放在目录文件夹下pxelinux.cfg文件夹下
    1. 完成后文件目录树为:/var/lib/tftpboot/下 包含四个文件:initrd.img、vmlinux、menu.c32 、pxelinux.0 一个文件夹:pxelinux.cfg 内有一个default文件

      配置安装菜单

  • 编辑tftp目录下pxelinux.cfg的default
    1. defualt menu.c32
    1. timeout 20
    1. menu title install centos7
    1. label Install ins7
    1. kernel vmlinuz
    1. append initrd=initrd.img ks=http://192.168.47.25/ks.cfg

      最后检查

  1. dhcp服务正常保障能够获取ip
  2. tftp服务正常保障能够读取文件
  3. http服务正常保障能够下载yum源和应答文件
  4. 完成检查后新建一个centos7的虚拟机开机,正常的话就会加载菜单,2秒后执行安装程序

PXE自动化部署的更多相关文章

  1. Cobbler自动化部署最佳实践

    第1章 Cobbler自动化部署最佳实践 运维自动化在生产环境中占据着举足轻重的地位,尤其是面对几百台,几千台甚至几万台的服务器时,仅仅是安装操作系统,如果不通过自动化来完成,根本是不可想象的. 面对 ...

  2. MySQL主从复制原理及配置详细过程以及主从复制集群自动化部署的实现

    一.复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重 ...

  3. python+paramiko库+svn写的自动化部署脚本

    第一篇博文 直接开门见山的说了. 这是件什么事?:每次部署都是复制本地的文件粘贴到服务器端,因为路径复杂,所以费时且手工容易出漏洞. 一直在想有什么办法可以解决这种,因为以前在微软的一个牛人同事做过一 ...

  4. ASP.NET MVC 从零开始 - 自动化部署(其二)

    这篇文章是从我的 github 博客 http://lxconan.github.io 导入的. 这是这个系列的第五篇了,前四篇请参见: ASP.NET MVC 从零开始 – Create and R ...

  5. ASP.NET MVC 从零开始 - 自动化部署(其一)

    本文是从我的 github 博客 http://lxconan.github.io 导入的. 这是这个系列的第四篇了,前三篇请参见: ASP.NET MVC 从零开始 – Create and Run ...

  6. 比Ansible更吊的自动化运维工具,自动化统一安装部署_自动化部署udeploy 1.0

    新增功能: 2015-03-11 除pass(备份与更新)与start(启动服务)外,实现一切自动化. 注:pass与start设为业务类,由于各类业务不同,所以无法实现自动化.同类业务除外,如更新的 ...

  7. 比Ansible更吊的自动化运维工具,自动化统一安装部署自动化部署udeploy 1.0 版本发布

    新增功能: 逻辑与业务分离,完美实现逻辑与业务分离,业务实现统一shell脚本开发,由框架统一调用. 并发多线程部署,不管多少台服务器,多少个服务,同时发起线程进行更新.部署.启动. 提高list规则 ...

  8. jenkins+git+maven搭建自动化部署项目环境

    简介    折腾了两个晚上,趁着今晚比较有空,把jenkins+git+maven搭建自动化部署项目环境搭建的过程记录一下,这里我把github作为git的远程仓库(https://github.co ...

  9. 使用Cargo实现自动化部署

    Cargo是一组帮助用户操作Web容器的工具,它能帮助用户实现自动化部署,而且它几乎支持所有的Web容器,如Tomcat.JBoss.Jetty和Glassfish.Cargo通过cargo-mave ...

随机推荐

  1. Linux性能分析之上下文切换

    而在每个任务运行前,CPU 都需要知道任务从哪里加载.又从哪里开始运行,也就是说,需要系统事先帮它设置好 CPU 寄存器和程序计数器 CPU 寄存器,是 CPU 内置的容量小.但速度极快的内存.而程序 ...

  2. 阿里JAVA诊断工具Arthas的初步使用

    Arthas 是Alibaba开源的Java诊断工具,主要解决以下问题: 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception? 我改的代码为什么没有执行到?难道是我没 comm ...

  3. TCP/IP及内核参数优化调优(转)

    Linux下TCP/IP及内核参数优化有多种方式,参数配置得当可以大大提高系统的性能,也可以根据特定场景进行专门的优化,如TIME_WAIT过高,DDOS攻击等等.如下配置是写在sysctl.conf ...

  4. Mysqlfunc.c

    int rc;int db_connection;char *server = "192.168.139.207"; // 数据库的ip地址char *user = "c ...

  5. Tomcat服务org.springframework.web.util.NestedServletException: Handler processing failed; nested exception is java.lang.OutOfMemoryError: Java heap space

    一个运行了很久的项目,最近忽然报错:OOM( java.lang.OutOfMemoryError: Java heap space),异常如下 org.springframework.web.uti ...

  6. Python爬虫学习==>第三章:Redis环境配置

    学习目的: 学习非关系型数据库环境安装,为后续的分布式爬虫做基建 正式步骤 Step1:安装Redis 打开http://www.runoob.com/,搜索redis安装 打开搜索的内容,得到red ...

  7. 使用URLOS 五分钟安装rTorrent (轻量级优秀BT/PT客户端)

    rTorrent是一个非常简洁.优秀.非常轻量的BT客户端,它使用ncurses库以C++编写,将 rTorrent 用在安装有 GNU Screen 和 Secure Shell 的低端系统上作为远 ...

  8. 【C/C++】assert()函数用法总结

    assert()函数用法总结 assert宏的原型定义在<assert.h>中,其作用是如果它的条件返回错误,则终止程序执行,原型定义: #include <assert.h> ...

  9. python的变量 以及操作系统

    变量 : (变量真没有什么好说的) 变: 就是会变化的 量:衡量现实的事物标准 python 中引用 变量值的作用 操作系统:就计算机控制硬件的软件,定义各个硬件的接口给应用软件调用 应用软件:在操作 ...

  10. Spring boot 整合CXF webservice 遇到的问题及解决

    将WebService的WSDL生成的代码的命令: wsimport -p com -s . com http://localhost:8080/service/user?wsdl Spring bo ...