cobbler自动安装系统

一、简介

Cobbler是一个快速网络安装linux的服务,而且在经过调整也可以支持网络安装windows。该工具使用python开发,小巧轻便(才15k行python代码),使用简单的命令即可完成PXE网络安装环境的配置,同时还可以管理DHCP、DNS、以及yum仓库、构造系统ISO镜像。

Cobbler支持命令行管理,web界面管理,还提供了API接口,可以方便二次开发使用。

Cobbler客户端Koan支持虚拟机安装和操作系统重新安装,使重装系统更便捷。

二、cobbler提供的功能

使用 Cobbler,您无需进行人工干预即可安装机器。Cobbler 设置一个 PXE 引导环境(它还可使用 yaboot 支持 PowerPC),并控制与安装相关的所有方面,比如网络引导服务(DHCP 和 TFTP)与存储库镜像。当希望安装一台新机器时,Cobbler 可以:

l  使用一个以前定义的模板来配置 DHCP 服务(如果启用了管理 DHCP)

l  将一个存储库(yum 或 rsync)建立镜像或解压缩一个媒介,以注册一个新操作系统

l  在 DHCP 配置文件中为需要安装的机器创建一个条目,并使用您指定的参数(IP 和 MAC 地址)

l  在 TFTFP 服务目录下创建适当的 PXE 文件

l  重新启动 DHCP 服务以反映更改

l  重新启动机器以开始安装(如果电源管理已启用)

安装环境:centos 7

首先关闭防火墙和selinux

[root@localhost ~]#systemctl stop firewalld

[root@localhost ~]#setenforce 0

1、安装centos 7 yum源

[root@localhost ~]#rpm -ivh https://mirrors.aliyun.com/epel/epel-release-latest-7.noarch.rpm

2、安装cobbler工具

[root@localhost ~]#yum install  httpd dhcp cobbler-web xinetd cobbler pykickstart tftp -y

3、启动并检查和进行初始操作

[root@localhost ~]#systemctl start cobblerd

[root@localhost ~]#systemctl start httpd

[root@localhost ~]#systemctl start xinetd

[root@localhost ~]#cobbler check

根据提示一步步完成,然后重启cobbler

3.1、在/etc/cobbler/settings文件第384行

server: 127.0.0.1改成server: 192.168.56.133(本机ip)

3.2、在/etc/cobbler/settings文件第272行

next_server: 127.0.0.1改成192.168.56.133(本机ip)

3.3、在/etc/xinetd.d/tftp文件里

disable= yes改成disable= no

3.4、生成cobbler默认密码,然后

[root@linux-node2 ~]# openssl passwd -1 -salt 'cobbler' 'cobbler'

$1$cobbler$M6SE55xZodWc9.vAKLJs6.

3.5、在etc/cobbler/settings第101行,

default_password_crypted: "$1$mF86/UHC$WvcIcX2t6crBz2onWxyac."修改成刚生成的        密码default_password_crypted: "$1$cobbler$M6SE55xZodWc9.vAKLJs6."

3.6、启动rsync服务

systemctl start rsyncd

3.7、执行cobbler get-loaders命令下载相关的文件

3.8、重启cobbler并在此检测

[root@localhost ~]#systemctl restart cobblerd

[root@localhost ~]#cobbler check

这三项可以不用管

3.9、让cobbler来管理dhcp

在/etc/cobbler/settings文件第242行

manage_dhcp:0改成manage_dhcp:1即可

然后修改cobbler的dhcp模版文件在自动生成dhcp文件

路径:/etc/cobbler/dhcp.template

只需修改如下几行即可(修改成自己的网段等)

subnet 192.168.56.0 netmask 255.255.255.0 {

     option routers             192.168.56.2;

     option domain-name-servers 192.168.56.2;

     option subnet-mask         255.255.255.0;

     range dynamic-bootp        192.168.56.100 192.168.56.254;

3.10、重启cobbler及cobbler check

[root@localhost ~]#systemctl restart cobblerd

[root@localhost ~]#cobbler check   #自动生成dhcp文件并重启dhcp

可以看到是由cobbler在管理dhcp

4、镜像导入

4.1、挂载镜像

[root@localhost ~]#mount /dev/cdrom /mnt

mount: /dev/sr0 is write-protected, mounting read-only

4.2、导入(会把镜像导入到/var/www/cobbler/ks_mirror/目录下)

[root@localhost ~]#cobbler import --path=/mnt/ --name=centos-7-x86_64 --arch=x86_64

4.3、cobbler profile 指令

[root@localhost ~]#  cobbler profile

usage

=====

cobbler profile add

cobbler profile copy

cobbler profile dumpvars

cobbler profile edit

cobbler profile find

cobbler profile getks

cobbler profile list

cobbler profile remove

cobbler profile rename

cobbler profile report

可以看到 cobbler profile的各指令

[root@localhost ~]# cobbler profile list

   centos-7-x86_64

可以看到有几个镜像

[root@localhost ~]# cobbler profile report

Name                           : centos-7-x86_64

TFTP Boot Files                : {}

Comment                        :

DHCP Tag                       : default

Distribution                   : centos-7-x86_64

Enable gPXE?                   : 0

Enable PXE Menu?               : 1

Fetchable Files                : {}

Kernel Options                 : {}

Kernel Options (Post Install)  : {}

Kickstart                      : /var/lib/cobbler/kickstarts/sample_end.ks      #默认的ks路径

Kickstart Metadata             : {}

Management Classes             : []

Management Parameters          : <<inherit>>

Name Servers                   : []

Name Servers Search Path       : []

Owners                         : ['admin']

Parent Profile                 :

Internal proxy                 :

Red Hat Management Key         : <<inherit>>

Red Hat Management Server      : <<inherit>>

Repos                          : []

Server Override                : <<inherit>>

Template Files                 : {}

Virt Auto Boot                 : 1

Virt Bridge                    : xenbr0

Virt CPUs                      : 1

Virt Disk Driver Type          : raw

Virt File Size(GB)             : 5

Virt Path                      :

Virt RAM (MB)                  : 512

Virt Type                      : kvm

可以看到各镜像的详细信息

4.3、加载自定义的ks文件

[root@localhost ~]#cobbler profile edit --name=centos-7-x86_64 --kickstart=/var/lib/cobbler/kickstarts/centos7.cfg

4.4、修改centos7内核参数把网卡变成eth模式

[root@localhost ~]#cobbler profile edit --name=centos-7-x86_64  --kopts='net.ifnames=0 biosdevname=0'

4.5、运行cobbler sync更新配置即可

[root@localhost ~]#cobbler sync

4.6、重新创建个虚拟机启动,看到如下表示ok的,就会自动安装了

注:ks文件内容如下

lang en_US

keyboard us

timezone Asia/Shanghai

rootpw --iscrypted $default_password_crypted

text

install

url --url=$tree

bootloader --location=mbr

zerombr

clearpart --all --initlabel

part /boot --fstype xfs --size 1024 --ondisk sda

part / --fstype xfs --size 1 --grow --ondisk sda

auth --useshadow --enablemd5

$SNIPPET('network_config')

reboot

firewall --disabled

selinux --disabled

skipx

%pre

$SNIPPET('log_ks_pre')

$SNIPPET('kickstart_start')

$SNIPPET('pre_install_network_config')

$SNIPPET('pre_anamon')

%end

%packages

@base

@core

sysstat

iptraf

ntp

lrzsz

ncurses-devel

openssl-devel

zlib-devel

OpenIPMI-tools

nmap

screen

%end

%post

systemctldisable postfix.service

$yum_config_stanza

%end

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏云鼎实验室的专栏

跨站的艺术-XSS入门与介绍

什么是XSS? XSS全称跨站脚本(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写...

4027
来自专栏PhpZendo

Symfony 服务容器性能优化

本文是依赖注入(Depeendency Injection)系列教程的最后一篇文章,本系列教程主要讲解如何使用 PHP 实现一个轻量级服务容器,教程包括:

1551
来自专栏坚毅的PHP

hbase问题总结

 1 java.io.IOException: java.io.IOException: java.lang.IllegalArgumentException:...

5006
来自专栏FreeBuf

利用Web查询文件(.iqy)有效钓鱼

几天前我在Casey Smith的twitter上看到了有关iqy文件的一些介绍,和大多数渗透测试人员或者技术狂热者一样我也在探寻它的价值。能够通过使用本地/可...

2636
来自专栏魏艾斯博客www.vpsss.net

如何修改 windows VPS 默认 3389 端口

4852
来自专栏龙首琴剑庐

原 微服务Spring Cloud Eur

1603
来自专栏SpringBoot 核心技术

第四十三章: 基于SpringBoot & RabbitMQ完成TopicExchange分布式消息消费

32715
来自专栏Rainbond开源「容器云平台」

敲黑板 | 云帮日志那点事儿

1624
来自专栏生信宝典

生信人写程序2. Editplus添加Perl, Shell, R, markdown模板和语法高亮

前言 “工欲善其事必先利其器”,生信工程师每天写代码、搭流程,而且要使用至少三门编程语言,没有个好集成开发环境(IDE,Integrated Developme...

2948
来自专栏葡萄城控件技术团队

Web API 持续集成:PostMan+Newman+Jenkins(图文讲解)

上篇文章我们已经完成了API测试工具选型,接下来是一系列周期性的开发测试过程:接口开发、检出代码、运行测试、记录结果、发送报告。为了快速发现问题,并减少重复过程...

1202

扫码关注云+社区