自动化运维工具之Cobbler

2023年 5月 4日 60.3k 0

Cobbler是通过将DHCP、TFTP、DNS、HTTP等服务进行集成,创建一个中央管理节点,其可以实现的功能有配置服务,创建存储库,解压缩操作系统媒介,代理或集成一个配置管理系统,控制电源管理等。 Cobbler的最终目的是实现无需进行人工干预即可安装机器。在进行进一步的操作之前,我们有必要先了解下pxe和kickstart 。
Cobbler
自动化
笔者QQ:381493251
微信公众号:abcdocker
Abcdocker交流群:454666672
如果遇到什么问题可以进群询问,我们是一个乐于帮助的集体!

Cobbler简介

Cobbler是一个快速网络安装linux的服务,而且在经过调整也可以支持网络安装windows。该工具使用python开发,小巧轻便(才15k行python代码),使用简单的命令即可完成PXE网络安装环境的配置,同时还可以管理DHCP、DNS、TFTP、RSYNC以及yum仓库、构造系统ISO镜像。 Cobbler支持命令行管理,web界面管理,还提供了API接口,可以方便二次开发使用。 Cobbler客户端Koan支持虚拟机安装和操作系统重新安装,同时支持服务器的电源管理,使重装系统更便捷。更多内容可以查看cobbler官方网站!
cobbler官方网站:http://cobbler.github.io/

Cobbler版本

distro 发行版
面对不同的操作系统
面对同一个操作系统不同的版本
profile
核心特性是通过kickstart来部署
system
主要目的配置网络接口
1.png-172kB

      图1   cobbler各主要组件关系图

Cobbler环境

我们使用的是Centos7进行安装,如果是Centos6也可以。只是有一些相关的目录不一致,可以查阅Centos6和Centos7的区别来进行设置。
Centos7下载链接 密码:xph6
环境查看

[root@localhost ~]# cat /etc/redhat-release 
CentOS Linux release 7.2.1511 (Core) 
[root@localhost ~]# uname -r
3.10.0-327.28.3.el7.x86_64

Cobbler部署

安装EPEL源

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

yum安装cobbler

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

cobler是基于Python开发,安装操作界面也是Python写的
cobbler都是通过Apache来提供服务的
启动apache

[root@localhost conf.d]# systemctl start httpd
启动cobber
[root@localhost conf.d]# systemctl start cobblerd

如果没有需要安装,安装步骤不说了,直接yum就好了
安装cobber_web 产生的2个配置文件

[root@localhost conf.d]# ll   /etc/httpd/conf.d/ 
total 36
-rw-r--r-- 1 root root 2926 Jul 18 11:30 autoindex.conf
-rw-r--r-- 1 root root 1087 Jan 24  2016 cobbler.conf      
-rw-r--r-- 1 root root 1165 Jan 24  2016 cobbler_web.conf
-rw-r--r-- 1 root root  366 Jul 18 11:30 README
-rw-r--r-- 1 root root 9438 Jul 18 11:22 ssl.conf
-rw-r--r-- 1 root root 1252 Jul 18 11:22 userdir.conf
-rw-r--r-- 1 root root  824 Jul 18 11:22 welcome.conf

配置文件说明

[root@localhost conf.d]# cat cobbler.conf
# This configuration file allows cobbler data
# to be accessed over HTTP.
AliasMatch ^/cblr(?!/svc/)(.*)?$ "/var/www/cobbler$1"    #别名匹配
AliasMatch ^/cobbler_track(.*)?$ "/var/www/cobbler$1"
#AliasMatch ^/cobbler(.*)?$ "/var/www/cobbler$1"
Alias /cobbler /var/www/cobbler   #别名的目录
Alias /cobbler_webui_content /var/www/cobbler_webui_content
WSGIScriptAliasMatch ^/cblr/svc/([^/]*) /var/www/cobbler/svc/services.py
<Directory "/var/www/cobbler">  #一个虚拟主机
    SetEnv VIRTUALENV
    Options Indexes FollowSymLinks
    Order allow,deny
    Allow from all
Directory>
ProxyRequests off
ProxyPass /cobbler_api http://localhost:25151/  #代理,类似于nginx的代理proxypass
ProxyPassReverse /cobbler_api http://localhost:25151/
BrowserMatch "MSIE" AuthDigestEnableQueryStringHack=On
# the webui is now part of the "cobbler-web" package
# and is visited at http://.../cobbler_web not this URL.
# this is only a pointer to the new page.
<Directory "/var/www/cobbler/web/">
    Options Indexes FollowSymLinks
    Order allow,deny
    Allow from all
Directory>
<IfVersion >= 2.4>
    <Location /cblr>
    Require all granted
    Location>
IfVersion>

执行cobbler check

[root@localhost conf.d]# cobbler check     #类似一个使用手册,来告诉我们需要完成以下内容
The following are potential configuration items that you may want to fix:
1 : The 'server' field in /etc/cobbler/settings must be set to something other than localhost, or kickstarting features will not work.  This should be a resolvable hostname or IP for the boot server as reachable by all machines that will use it.
2 : For PXE to be functional, the 'next_server' field in /etc/cobbler/settings must be set to something other than 127.0.0.1, and should match the IP of the boot server on the PXE network.
3 : change 'disable' to 'no' in /etc/xinetd.d/tftp
4 : some network boot-loaders are missing from /var/lib/cobbler/loaders, you may run 'cobbler get-loaders' to download them, or, if you only want to handle x86/x86_64 netbooting, you may ensure that you have installed a *recent* version of the syslinux package installed and can ignore this message entirely.  Files in this directory, should you want to support all architectures, should include pxelinux.0, menu.c32, elilo.efi, and yaboot. The 'cobbler get-loaders' command is the easiest way to resolve these requirements.
5 : enable and start rsyncd.service with systemctl
6 : debmirror package is not installed, it will be required to manage debian deployments and repositories
7 : The default password used by the sample templates for newly installed machines (default_password_crypted in /etc/cobbler/settings) is still set to 'cobbler' and should be changed, try: "openssl passwd -1 -salt 'random-phrase-here' 'your-password-here'" to generate new one
8 : fencing tools were not found, and are required to use the (optional) power management features. install cman or fence-agents to use them
Restart cobblerd and then run 'cobbler sync' to apply changes.

下面是解释:本段参考徐博士博客http://www.xuliangwei.com/xubusi/446.html

1、修改/etc/cobbler/settings文件中的server参数的值为提供cobbler服务的主机相应的IP地址或主机名,如server: 10.0.0.101;

    [root@cobbler-node1 ~]# sed -i 's/server: 127.0.0.1/server: 10.0.0.101/' /etc/cobbler/settings

2、修改/etc/cobbler/settings文件中的next_server参数的值为提供PXE服务的主机相应的IP地址,如next_server: 10.0.0.101;

    [root@cobbler-node1 ~]# sed -i 's/next_server: 127.0.0.1/next_server: 10.0.0.101/' /etc/cobbler/settings

3、修改/etc/xinetd.d/tftp文件中的disable参数修改为 disable = no

4、执行 cobbler get-loaders 命令即可;否则,需要安装syslinux程序包,而后复制/usr/share/syslinux/{pxelinux.0,memu.c32}等文件至/var/lib/cobbler/loaders/目录中;

5、执行 systemctl enable rsyncd命令即可;

6、如果有强迫症可以选择 yum –y install debmirror 然后根据错误进行解决,一般错误如下。

    注释/etc/dedmirror.conf文件中的  @dists=”sid”;  @arches=”i386”;

7、[root@cobbler-node1 ~]# openssl passwd -1 -salt '$(openssl rand -hex 4)' 'xuliangwei'

$1$$(openss$.wbDUBV/STL0YaNuAcusK/

[root@cobbler-node1~]# grep "default_password_crypted" /etc/cobbler/settings  #替换/etc/cobbler/setting内的default_password_crypted

default_password_crypted:"$1$$(openss$.wbDUBV/STL0YaNuAcusK/"

8、yum –y install cman fence-agents

最后重启Cobbler:systemctl restart cobblerd

以上操作我们可以不根据他说的进行操作
要根据要求进行设置!——————————————
cobbler配置文件

[root@localhost conf.d]# vim /etc/cobbler/settings    #cobbler配置文件
next_server: 192.168.56.11   #修改成我们本机的IP地址
server: 192.168.56.11        #修改成服务的IP地方

设置tftp

[root@localhost conf.d]# vim /etc/xinetd.d/tftp 
将disable改成no
# default: off
# description: The tftp server serves files using the trivial file transfer 
#       protocol.  The tftp protocol is often used to boot diskless 
#       workstations, download configuration files to network-aware printers, 
#       and to start the installation process for some operating systems.
service tftp
{
        socket_type             = dgram
        protocol                = udp
        wait                    = yes
        user                    = root
        server                  = /usr/sbin/in.tftpd
        server_args             = -s /var/lib/tftpboot
        disable                 = no
        per_source              = 11
        cps                     = 100 2
        flags                   = IPv4
}

启动rsync

[root@localhost conf.d]# systemctl start rsyncd

执行网络安装要下载的相关文件

[root@localhost conf.d]# cobbler get-loaders
task started: 2016-08-23_115402_get_loaders
task started (id=Download Bootloader Content, time=Tue Aug 23 11:54:02 2016)
downloading http://cobbler.github.io/loaders/README to /var/lib/cobbler/loaders/README
downloading http://cobbler.github.io/loaders/COPYING.elilo to /var/lib/cobbler/loaders/COPYING.elilo
downloading http://cobbler.github.io/loaders/COPYING.yaboot to /var/lib/cobbler/loaders/COPYING.yaboot
downloading http://cobbler.github.io/loaders/COPYING.syslinux to /var/lib/cobbler/loaders/COPYING.syslinux
downloading http://cobbler.github.io/loaders/elilo-3.8-ia64.efi to /var/lib/cobbler/loaders/elilo-ia64.efi
downloading http://cobbler.github.io/loaders/yaboot-1.3.17 to /var/lib/cobbler/loaders/yaboot
downloading http://cobbler.github.io/loaders/pxelinux.0-3.86 to /var/lib/cobbler/loaders/pxelinux.0
downloading http://cobbler.github.io/loaders/menu.c32-3.86 to /var/lib/cobbler/loaders/menu.c32
downloading http://cobbler.github.io/loaders/grub-0.97-x86.efi to /var/lib/cobbler/loaders/grub-x86.efi
downloading http://cobbler.github.io/loaders/grub-0.97-x86_64.efi to /var/lib/cobbler/loaders/grub-x86_64.efi
*** TASK COMPLETE ***

设置账号密码

[root@localhost conf.d]# openssl passwd -1 -salt 'cobler' 'cobler'  第一个是掩码,第二个是密码
$1$cobler$XJnisBweZJlhL651HxAM00

复制到配置文件中

[root@localhost conf.d]# vim /etc/cobbler/settings 

按照上面的说明,我们需要重启一下cobbler

[root@localhost conf.d]# systemctl restart cobblerd

我们在执行cobbler check查看还有什么需要我们继续操作的

[root@localhost conf.d]# cobbler check
The following are potential configuration items that you may want to fix:
1 : enable and start rsyncd.service with systemctl
2 : debmirror package is not installed, it will be required to manage debian deployments and repositories
3 : fencing tools were not found, and are required to use the (optional) power management features. install cman or fence-agents to use them
Restart cobblerd and then run 'cobbler sync' to apply changes.

现在cobbler已经安装完了,现在还缺一个DHCP
cobbler可以管理DHCP,也可以不让他管

[root@localhost ~]# vim /etc/cobbler/settings
manage_dhcp: 1     #将dhcp 0修改为1表示管理dhcp

我们再修改dhcp模板文件

[root@localhost ~]# vim /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;       #DMS
     option subnet-mask         255.255.255.0;            #子网掩码
     range dynamic-bootp        192.168.56.100 192.168.56.254;     #分配的地址段
     default-lease-time         21600;
     max-lease-time             43200;
     next-server                $next_server;        #这个是cobbler配置文件里面的变量

修改完配置文件之后,重启服务

[root@localhost ~]# systemctl restart cobblerd

使用cobbler sync 生成dhcp模板,自动帮我们重启dhcp
cobbler sync 表示刷新,其实就是删除原来的文件,从新进行加载

[root@localhost ~]#  cobbler sync
task started: 2016-08-23_180604_sync
task started (id=Sync, time=Tue Aug 23 18:06:04 2016)
running pre-sync triggers
cleaning trees
removing: /var/lib/tftpboot/grub/images
copying bootloaders
trying hardlink /var/lib/cobbler/loaders/pxelinux.0 -> /var/lib/tftpboot/pxelinux.0
trying hardlink /var/lib/cobbler/loaders/menu.c32 -> /var/lib/tftpboot/menu.c32
trying hardlink /var/lib/cobbler/loaders/yaboot -> /var/lib/tftpboot/yaboot
trying hardlink /usr/share/syslinux/memdisk -> /var/lib/tftpboot/memdisk
trying hardlink /var/lib/cobbler/loaders/grub-x86.efi -> /var/lib/tftpboot/grub/grub-x86.efi
trying hardlink /var/lib/cobbler/loaders/grub-x86_64.efi -> /var/lib/tftpboot/grub/grub-x86_64.efi
copying distros to tftpboot
copying images
generating PXE configuration files
generating PXE menu structure
rendering DHCP files
generating /etc/dhcp/dhcpd.conf
rendering TFTPD files
generating /etc/xinetd.d/tftp
cleaning link caches
running post-sync triggers
running python triggers from /var/lib/cobbler/triggers/sync/post/*
running python trigger cobbler.modules.sync_post_restart_services
running: dhcpd -t -q
received on stdout:
received on stderr:
running: service dhcpd restart
received on stdout:
received on stderr: Redirecting to /bin/systemctl restart  dhcpd.service
running shell triggers from /var/lib/cobbler/triggers/sync/post/*
running python triggers from /var/lib/cobbler/triggers/change/*
running python trigger cobbler.modules.scm_track
running shell triggers from /var/lib/cobbler/triggers/change/*
*** TASK COMPLETE ***

我们可以查看一下dhcp,查看cobbler是否可以管理dhcp

[root@localhost ~]# cat /etc/dhcp/dhcpd.conf
# ******************************************************************
# Cobbler managed dhcpd.conf file
# generated from cobbler dhcp.conf template (Tue Aug 23 22:06:05 2016)
# Do NOT make changes to /etc/dhcpd.conf. Instead, make your changes
# in /etc/cobbler/dhcp.template, as /etc/dhcpd.conf will be
# overwritten.
# ******************************************************************

上述意思是 dhcp是由cobbler进行管理,如果想进行设置 请修改/etc/cobbler/dhcp.template 然后/etc/dhcp/dhcpd.conf会被覆盖
现在我们安装一台操作系统
挂载镜像 右击Centos64-->设置>CD/DVD
1.png-67.3kB
Linux 上是需要挂载光盘,我们进行挂载

[root@localhost ~]# mount /dev/cdrom /mnt/
mount: /dev/sr0 is write-protected, mounting read-only

制作镜像,用于安装操作系统,使cobbler导入镜像

[root@localhost ~]# cobbler import --path=/mnt/ --name=CentOS-6-x86_64 --arch=x86_64
--path=从哪里导入
--name=名称
--arch=系统位数32 or 64

导入过程中yum仓库和其他的已经给我们做好了
导入的位置

[root@localhost ks_mirror]# pwd
/var/www/cobbler/ks_mirror
[root@localhost ks_mirror]# ls
CentOS-7-x86_64  config

在导入一个centos.7的,首先我们先卸载7的

[root@localhost ~]# umount /dev/cdrom

2.png-81.3kB
3.png-36.1kB
重新进行挂载

[root@localhost ~]# mount /dev/cdrom /mnt/
mount: /dev/sr0 is write-protected, mounting read-only

继续执行,代表制作一个centos7的镜像

[root@localhost /]# cobbler import --path=/mnt/ --name=CentOS-7.1-x86_64 --arch=x86_64

具体参数请参考上面的内容
查看cobbler都有哪些命令

[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

例如:我们查看当前有几个镜像

[root@localhost /]# cobbler profile list
   CentOS-6-x86_64
   CentOS-7-x86_64

查看我们2个系统的详细信息

[root@localhost /]# cobbler profile report
Name                           : CentOS-7.1-x86_64
TFTP Boot Files                : {}
Comment                        : 
DHCP Tag                       : default
Distribution                   : CentOS-7.1-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
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
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
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

修改ks的路径,自定义安装后,需要设置的一些东西,例如开启哪些服务,关闭哪些服务。安装什么东西等
我们先上传已经设置好的cfg文件
下载链接 密码:iq4t
为了规范,我们把kickstarts文件放在/var/lib/cobbler/kickstarts下面

[root@localhost ~]# cd /var/lib/cobbler/kickstarts/
[root@localhost kickstarts]# rz -E
rz waiting to receive.

检查一下路径是否正确

[root@localhost kickstarts]# ll
total 60
-rw-r--r-- 1 root root 3704 Aug 24  2016 CentOS-6-x86_64.cfg
-rw-r--r-- 1 root root 1355 Aug 25  2016 CentOS-7-x86_64.cfg
-rw-r--r-- 1 root root  115 Jan 23  2016 default.ks
-rw-r--r-- 1 root root   22 Jan 23  2016 esxi4-ks.cfg
-rw-r--r-- 1 root root   22 Jan 23  2016 esxi5-ks.cfg
drwxr-xr-x 2 root root   54 Aug 23 09:17 install_profiles
-rw-r--r-- 1 root root 1424 Jan 23  2016 legacy.ks
-rw-r--r-- 1 root root  292 Jan 23  2016 pxerescue.ks
-rw-r--r-- 1 root root 2916 Jan 23  2016 sample_autoyast.xml
-rw-r--r-- 1 root root 1825 Jan 23  2016 sample_end.ks
-rw-r--r-- 1 root root    0 Jan 23  2016 sample_esx4.ks
-rw-r--r-- 1 root root  324 Jan 23  2016 sample_esxi4.ks
-rw-r--r-- 1 root root  386 Jan 23  2016 sample_esxi5.ks
-rw-r--r-- 1 root root 1784 Jan 23  2016 sample.ks
-rw-r--r-- 1 root root 3419 Jan 23  2016 sample_old.seed
-rw-r--r-- 1 root root 5879 Jan 23  2016 sample.seed

自定义kickstarts文件
我们使用cobbler profile report命令看到Kickstart默认在/var/lib/cobbler/kickstarts/sample_end.ks
我们直接使用命令进行修改,我们修改6的kickstarts

[root@localhost /]# cobbler profile edit --name=CentOS-6-x86_64 --kickstart=/var/lib/cobbler/kickstarts/CentOS-6-x86_64.cfg 

修改7的kickstarts

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

因为Centos7 默认的网卡不在/etc/init.d/network
所以我们需要修改内核

[root@localhost /]# cobbler profile report
Kernel Options                 : {}

我们查看到这里可以定义内核参数

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

这样我们在安装Centos7的时候就会默认给我们加上这个内核参数

[root@localhost /]# cobbler profile report
Name                           : CentOS-7.1-x86_64
TFTP Boot Files                : {}
Comment                        : 
DHCP Tag                       : default
Distribution                   : CentOS-7.1-x86_64
Enable gPXE?                   : 0
Enable PXE Menu?               : 1
Fetchable Files                : {}
Kernel Options                 : {'biosdevname': '0', 'net.ifnames': '0'}

提示:默认cobbler profile report会查看当前配置的所有,我们可以使用 cobbler profile ”Cobbler 定义的名字“来查看
执行cobbler sync会删除原来的文件,相当于从新进行加载

[root@localhost /]# cobbler sync
task started: 2016-08-24_001542_sync
task started (id=Sync, time=Wed Aug 24 00:15:42 2016)
running pre-sync triggers
cleaning trees
removing: /var/www/cobbler/images/CentOS-7-x86_64
removing: /var/www/cobbler/images/CentOS-7.1-x86_64
removing: /var/lib/tftpboot/pxelinux.cfg/default
removing: /var/lib/tftpboot/grub/images
removing: /var/lib/tftpboot/grub/grub-x86.efi
removing: /var/lib/tftpboot/grub/grub-x86_64.efi
removing: /var/lib/tftpboot/grub/efidefault
removing: /var/lib/tftpboot/images/CentOS-7-x86_64
removing: /var/lib/tftpboot/images/CentOS-7.1-x86_64
removing: /var/lib/tftpboot/s390x/profile_list
copying bootloaders
trying hardlink /var/lib/cobbler/loaders/grub-x86.efi -> /var/lib/tftpboot/grub/grub-x86.efi
trying hardlink /var/lib/cobbler/loaders/grub-x86_64.efi -> /var/lib/tftpboot/grub/grub-x86_64.efi
copying distros to tftpboot
copying files for distro: CentOS-7.1-x86_64
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7.1-x86_64/images/pxeboot/vmlinuz -> /var/lib/tftpboot/images/CentOS-7.1-x86_64/vmlinuz
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7.1-x86_64/images/pxeboot/initrd.img -> /var/lib/tftpboot/images/CentOS-7.1-x86_64/initrd.img
copying files for distro: CentOS-7-x86_64
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7-x86_64/images/pxeboot/vmlinuz -> /var/lib/tftpboot/images/CentOS-7-x86_64/vmlinuz
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7-x86_64/images/pxeboot/initrd.img -> /var/lib/tftpboot/images/CentOS-7-x86_64/initrd.img
copying images
generating PXE configuration files
generating PXE menu structure
copying files for distro: CentOS-7.1-x86_64
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7.1-x86_64/images/pxeboot/vmlinuz -> /var/www/cobbler/images/CentOS-7.1-x86_64/vmlinuz
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7.1-x86_64/images/pxeboot/initrd.img -> /var/www/cobbler/images/CentOS-7.1-x86_64/initrd.img
Writing template files for CentOS-7.1-x86_64
copying files for distro: CentOS-7-x86_64
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7-x86_64/images/pxeboot/vmlinuz -> /var/www/cobbler/images/CentOS-7-x86_64/vmlinuz
trying hardlink /var/www/cobbler/ks_mirror/CentOS-7-x86_64/images/pxeboot/initrd.img -> /var/www/cobbler/images/CentOS-7-x86_64/initrd.img
Writing template files for CentOS-7-x86_64
rendering DHCP files
generating /etc/dhcp/dhcpd.conf
rendering TFTPD files
generating /etc/xinetd.d/tftp
processing boot_files for distro: CentOS-7.1-x86_64
processing boot_files for distro: CentOS-7-x86_64
cleaning link caches
running post-sync triggers
running python triggers from /var/lib/cobbler/triggers/sync/post/*
running python trigger cobbler.modules.sync_post_restart_services
running: dhcpd -t -q
received on stdout:
received on stderr:
running: service dhcpd restart
received on stdout:
received on stderr: Redirecting to /bin/systemctl restart  dhcpd.service
running shell triggers from /var/lib/cobbler/triggers/sync/post/*
running python triggers from /var/lib/cobbler/triggers/change/*
running python trigger cobbler.modules.scm_track
running shell triggers from /var/lib/cobbler/triggers/change/*
*** TASK COMPLETE ***

新建虚拟机进行安装
提示:我们先打开系统日志,因为dhcp默认会将日志显示在/var/log/messages
我们在新建虚拟机
1.png-102.6kB
2.png-53.8kB
3.png-70.9kB
4.png-18.4kB
dhcp的4个步骤
5.png-18.5kB
现在已经获取到了IP,TFTP没有开启
6.png-9.9kB
我们安装tftp

[root@localhost kickstarts]# yum install xinetd -y
启动
[root@localhost kickstarts]# systemctl start xinetd

耐心等待,如果超时2次需要重新启动,因为开启了dhcp获取到了IP地址,但是无法下载文件 肯定会超时
7.png-6.7kB
** 菜单解释:**
1.本地硬盘
2.CentOS-6
3.CentOS-7
提示:默认会计时,我们使用上下键不让它进行计时。有这个菜单的好处就是不会担心重启之后就把系统给重装了。
我们选择7进行安装
1.png-30.7kB
安装完成
2.png-5.3kB
3.png-3kB
以上就是cobbler的基础安装部分!

自动重装系统

#提示:如果我们想重装那台系统,可以执行以下的步骤:
使用koan工具,让cobbler自动化重装

[root@localhost kickstarts]# yum install koan

查看我们可以安装的系统

[root@localhost kickstarts]# koan --server=192.168.56.11 --list=profiles
- looking for Cobbler at http://192.168.56.11:80/cobbler_api
CentOS-6-x86_64
CentOS-7-x86_64
##--server=此处是cobbler的IP地址

例子:我们使用koan安装centos6
指定要重装的系统

[root@localhost kickstarts]# koan --replace-self --server=192.168.56.11 --profile=CentOS-6-x86_64
- looking for Cobbler at http://192.168.56.11:80/cobbler_api
- reading URL: http://192.168.56.11/cblr/svc/op/ks/profile/CentOS-6-x86_64
install_tree: http://192.168.56.11/cblr/links/CentOS-6-x86_64
downloading initrd initrd.img to /boot/initrd.img_koan
url=http://192.168.56.11/cobbler/images/CentOS-6-x86_64/initrd.img
- reading URL: http://192.168.56.11/cobbler/images/CentOS-6-x86_64/initrd.img
downloading kernel vmlinuz to /boot/vmlinuz_koan
url=http://192.168.56.11/cobbler/images/CentOS-6-x86_64/vmlinuz
- reading URL: http://192.168.56.11/cobbler/images/CentOS-6-x86_64/vmlinuz
- ['/sbin/grubby', '--add-kernel', '/boot/vmlinuz_koan', '--initrd', '/boot/initrd.img_koan', '--args', '"ks=http://192.168.56.11/cblr/svc/op/ks/profile/CentOS-7-x86_64 ksdevice=link kssendmac lang= text "', '--copy-default', '--make-default', '--title=kick1472015796']
- ['/sbin/grubby', '--update-kernel', '/boot/vmlinuz_koan', '--remove-args=root']
- reboot to apply changes

重启之后直接加载centos6
4.png-10kB
不需要我们选择,他自己进行选择。
1.png-4.2kB
提示:在我们reboot,一定要确定我们要重启的服务器是哪一台。如果确实操作错了,需要赶紧关闭cobbler、断电

Cobbler_Web 界面设置

Cobbler提供了一个web界面,我们可以使用网页进行访问
1.png-35.4kB
地址:https://192.168.56.11/cobbler_web
这里的用户名和密码是cobbler
如果我们想修改cobbler_web用户名可以到/etc/cobbler/users.conf

[root@localhost cobbler]# cat /etc/cobbler/users.conf 
[admins]
admin = ""
cobbler = ""

cobbler是描述
修改cobbler_web密码

[root@localhost cobbler]# htdigest /etc/cobbler/users.digest "Cobbler" cobbler
Changing password for user cobbler in realm Cobbler
New password: 
Re-type new password: 

Cobbler=用户的描述
cobbler=用户名
2.png-41.4kB
我们可以查看profiles,点击Edit可以修改系统的一些选项
3.png-68.4kB
在kernel里面可以设置一些内核参数
4.png-78.1kB
在Kickstart Templates 可以查看我们的kickstarts文件
5.png-70.8kB
我们还可以修改kickstart文件
6.png-32.1kB
所有命令行操作cobbler,都可以在cobbler_web上面实现

高级设置

我们可以修改cobbler的选择系统的菜单
1.png-7.1kB
编辑配置文件

[root@localhost pxe]# cat /etc/cobbler/pxe/pxedefault.template
DEFAULT menu
PROMPT 0
MENU TITLE Cobbler www.abcdocker.com| http://www.abcdocker.com
TIMEOUT 200
TOTALTIMEOUT 6000
ONTIMEOUT $pxe_timeout_profile
LABEL local_abcdocker
        MENU LABEL [ install abcdocker.com ]
        MENU DEFAULT
        LOCALBOOT -1
$pxe_menu_items
MENU end

我们修改完配置文件之后需要刷新,否则不生效

[root@localhost pxe]# cobbler sync

我们可以在创建一台虚拟机测试(安装过程不说了,直接看结果)
修改图如下:
1.png-7.5kB
Cobbler重要的几个目录
镜像存放目录

[root@localhost cobbler]# ls /var/www/cobbler/ks_mirror/
CentOS-7.1-x86_64  CentOS-7-x86_64  config

存放仓库镜像

[root@localhost cobbler]# ls /var/www/cobbler/repo_mirror/

kickstarts配置文件存放路径

[root@localhost cobbler]# ls /var/lib/cobbler/
config                  kickstarts  lock     snippets  web.ss
distro_signatures.json  loaders     scripts  triggers  webui_sessions

存放启动引导程序的目录

[root@localhost cobbler]# ls /var/lib/cobbler/loaders/
COPYING.elilo     COPYING.yaboot  grub-x86_64.efi  menu.c32    README
COPYING.syslinux  elilo-ia64.efi  grub-x86.efi     pxelinux.0  yaboot

一些相关配置的脚本

[root@localhost cobbler]# ls /var/lib/cobbler/snippets/
cobbler_register           networking.xml
download_config_files      partition_select
download_config_files_deb  post_anamon
func_install_if_enabled    post_install_kernel_options
func_register_if_enabled   post_install_network_config
hosts.xml                  post_install_network_config_deb
kdump.xml                  post_koan_add_reinstall_entry
keep_cfengine_keys         post_run_deb
keep_files                 post_s390_reboot
keep_rhn_keys              pre_anamon
keep_ssh_host_keys         pre_install_network_config
kickstart_done             pre_partition_select
kickstart_start            preseed_apt_repo_config
koan_environment           proxy.xml
late_apt_repo_config       puppet_install_if_enabled
log_ks_post                puppet_register_if_enabled
log_ks_post_nochroot       redhat_register
log_ks_pre                 restore_boot_device
main_partition_select      rhn_certificate_based_register
network_config             save_boot_device
network_config_esx         suse_scriptwrapper.xml
network_config_esxi

cobbler配置文件存放目录

[root@localhost cobbler]# ll /etc/cobbler/
total 108
-rw-r--r-- 1 root root    40 Jan 23  2016 auth.conf
-rw-r--r-- 1 root root    75 Jan 23  2016 cheetah_macros
-rw-r--r-- 1 root root  2409 Jan 23  2016 cobbler_bash
-rw-r--r-- 1 root root 11636 Jan 23  2016 completions
-rw-r--r-- 1 root root  2951 Aug 23 18:05 dhcp.template
-rw-r--r-- 1 root root   385 Jan 23  2016 dnsmasq.template
-rw-r--r-- 1 root root  2014 Jan 23  2016 import_rsync_whitelist
drwxr-xr-x 2 root root    30 Aug 23 09:17 iso
drwxr-xr-x 2 root root    37 Aug 23 09:17 ldap
-rw-r--r-- 1 root root  3076 Jan 23  2016 modules.conf
-rw-r--r-- 1 root root    43 Jan 23  2016 mongodb.conf
-rw-r--r-- 1 root root   680 Jan 23  2016 named.template
drwxr-xr-x 2 root root  4096 Aug 23 09:17 power
drwxr-xr-x 2 root root  4096 Aug 24 05:51 pxe
drwxr-xr-x 2 root root    40 Aug 23 09:17 reporting
-rw-r--r-- 1 root root   368 Jan 23  2016 rsync.exclude
-rw-r--r-- 1 root root  1073 Jan 23  2016 rsync.template
-rw-r--r-- 1 root root   754 Jan 23  2016 secondary.template
-rw-r--r-- 1 root root 19654 Aug 23 17:59 settings
-rw-r--r-- 1 root root   740 Jan 23  2016 tftpd.template
-rw-r--r-- 1 root root   848 Jan 23  2016 users.conf
-rw-r--r-- 1 root root    49 Aug 24 05:27 users.digest
-rw-r--r-- 1 root root   117 Jan 24  2016 version
-rw-r--r-- 1 root root   522 Jan 23  2016 zone.template
drwxr-xr-x 2 root root     6 Jan 24  2016 zone_templates

主要的配置文件目录还是settings

[root@localhost cobbler]# ll /etc/cobbler/settings 
-rw-r--r-- 1 root root 19654 Aug 23 17:59 /etc/cobbler/settings

构建yum仓库

我们每次安装都需要在指定阿里云的yum源那样会比较麻烦,可以直接在装机的时候进行设置
例如:我们构建一个openstack的yum源
第一步:添加repo

[root@localhost ~]# cobbler repo add --name=openstack-mitaka --mirror=http://mirrors.aliyun.com/centos/7.2.1511/cloud/x86_64/openstack-mitaka/ --arch=x86_64 --breed=yum
repo=构建yum仓库
add=添加
--name=源的名字
--mirror=源的地址

第二部:刷新同步repo

[root@localhost ~]# cobbler reposync
#提示:他会将网站下面所有的包下载到本地,并且帮我们创建repo文件(/etc/yum.repos.d)

第三步:添加repo到对应的profile

[root@localhost ~]# cobbler profile edit --name=CentOS-7-x86_64 --repos="openstack-mitaka"

默认情况下,在安装系统的时候会默认安装openstack-mitaka
可以通过修改配置文件,1代表开启

[root@localhost ~]# vim /etc/cobbler/settings 
yum_post_install_mirror: 1

第四步:修改kickstart文件

在我们的kickstarts的配置文件中加入$yum_config_stanaz,这样在安装的时候会自动调节yum仓库
[root@localhost ~]# vim /var/lib/cobbler/kickstarts/CentOS-7-x86_64.cfg 
%post
systemctl disable postfix.service
$yum_config_stanaz
%end

第五步:添加定时任务,定期同步repo

[root@localhost ~]# echo "00 00 * * * /usr/bin/cobbler reposync --tries=3 --no-file" >>/var/spool/cron/root

自动化的一套流程(系统层面)

因为我们每次安装系统都会很麻烦,而且环境会不一致所以我们可以按照每个服务器的mac地址进行设置
profile
操作系统
分区
预分配的Ip地址
主机名
子网
网关
dns
角色
规划如下:
1.png-8.7kB
mac地址生成方法:设置--->硬件--->网络-->高级--->生成
2.png-48kB
cobbler设置

cobbler system add --name=linux-node1.com --mac=00:0C:29:AD:F2:08 
--profile=CentOS-7.1-x86_64 
--ip-address=192.168.56.12 
--subnet=255.255.255.0 
--gateway=192.168.56.2 
--interface=eth0 --static=1 
--hostname=linux-node1.com 
--name-servers="192.168.56.12"  
--kickstart=/var/lib/cobbler/kickstarts/CentOS-7-x86_64.cfg

结果如下:

[root@localhost ~]# cobbler system list
[root@localhost ~]# cobbler system add --name=linux-node1.com --mac=00:0C:29:AD:F2:08 
> --profile=CentOS-7-x86_64 
> --ip-address=192.168.56.12 
> --subnet=255.255.255.0 
> --gateway=192.168.56.2 
> --interface=eth0 --static=1 
> --hostname=linux-node1.com 
> --name-servers="192.168.56.12"  
> --kickstart=/var/lib/cobbler/kickstarts/CentOS-7-x86_64.cfg

cobbler system list查看当前的规划
如果不知道我们的本地镜像都有哪些可以通过下面的命令查看

 [root@localhost ~]# cobbler profile list
   CentOS-6-x86_64
   CentOS-7-x86_64

提示:要会看报错信息,根据报错信息进行排查
我们设置完在查看一下

[root@localhost ~]# cobbler system list
   linux-node1.com

我们执行刷新命令。

 [root@localhost ~]# cobbler sync

否则不生效
此时我们可以查看dhcp的配置文件,已经帮我们定义好了一个

[root@localhost ~]# cat /etc/dhcp/dhcpd.conf 
# group for Cobbler DHCP tag: default
group {
    host generic1 {
        hardware ethernet 00:0C:29:AD:F2:08;
        fixed-address 192.168.56.12;
        option host-name "linux-node1.com";
        option subnet-mask 255.255.255.0;
        option routers 192.168.56.2;
        filename "/pxelinux.0";
        next-server 192.168.56.11;
    }
}

温馨提示:MAC地址必须要和装系统的一样,生成见上方
11.png-400.4kB
现在按照正常的情况下,我们新建一台虚拟机默认就会安装Centos7,不会让我们选择,帮我设置好主机名和IP地址
12.png-59kB
这样就会自动进行安装了
提示:这里只有对应的mac地址匹配上了,才会执行自动安装,如果没有匹配上。会让我们 选择其他安装的选项
13.png-15.9kB
安装完成!
cobbler大多都是使用脚本实现的
脚本路径:

[root@localhost ~]# cat /var/lib/cobbler/snippets/post_install_network_config
[root@localhost ~]# ll /var/lib/cobbler/snippets/
total 208
-rw-r--r-- 1 root root   431 Jan 23  2016 cobbler_register
-rw-r--r-- 1 root root   645 Jan 23  2016 download_config_files
-rw-r--r-- 1 root root   865 Jan 23  2016 download_config_files_deb
-rw-r--r-- 1 root root    61 Jan 23  2016 func_install_if_enabled
-rw-r--r-- 1 root root   448 Jan 23  2016 func_register_if_enabled
-rw-r--r-- 1 root root   821 Jan 23  2016 hosts.xml
-rw-r--r-- 1 root root  1310 Jan 23  2016 kdump.xml
-rw-r--r-- 1 root root  2506 Jan 23  2016 keep_cfengine_keys
-rw-r--r-- 1 root root  4316 Jan 23  2016 keep_files
-rw-r--r-- 1 root root  2609 Jan 23  2016 keep_rhn_keys
-rw-r--r-- 1 root root  3155 Jan 23  2016 keep_ssh_host_keys
-rw-r--r-- 1 root root  4547 Jan 23  2016 kickstart_done
-rw-r--r-- 1 root root  1524 Jan 23  2016 kickstart_start
-rw-r--r-- 1 root root   191 Jan 23  2016 koan_environment
-rw-r--r-- 1 root root   644 Jan 23  2016 late_apt_repo_config
-rw-r--r-- 1 root root    40 Jan 23  2016 log_ks_post
-rw-r--r-- 1 root root    62 Jan 23  2016 log_ks_post_nochroot
-rw-r--r-- 1 root root   281 Jan 23  2016 log_ks_pre
-rw-r--r-- 1 root root    46 Jan 23  2016 main_partition_select
-rw-r--r-- 1 root root  3790 Jan 23  2016 network_config
-rw-r--r-- 1 root root  1918 Jan 23  2016 network_config_esx
-rw-r--r-- 1 root root  2276 Jan 23  2016 network_config_esxi
-rw-r--r-- 1 root root  4454 Jan 23  2016 networking.xml
-rw-r--r-- 1 root root   769 Jan 23  2016 partition_select
-rw-r--r-- 1 root root   707 Jan 23  2016 post_anamon
-rw-r--r-- 1 root root   561 Jan 23  2016 post_install_kernel_options
-rw-r--r-- 1 root root 16340 Jan 23  2016 post_install_network_config
-rw-r--r-- 1 root root 11545 Jan 23  2016 post_install_network_config_deb
-rw-r--r-- 1 root root   204 Jan 23  2016 post_koan_add_reinstall_entry
-rw-r--r-- 1 root root    69 Jan 23  2016 post_run_deb
-rw-r--r-- 1 root root  1988 Jan 23  2016 post_s390_reboot
-rw-r--r-- 1 root root   194 Jan 23  2016 pre_anamon
-rw-r--r-- 1 root root  6601 Jan 23  2016 pre_install_network_config
-rw-r--r-- 1 root root   773 Jan 23  2016 pre_partition_select
-rw-r--r-- 1 root root   628 Jan 23  2016 preseed_apt_repo_config
-rw-r--r-- 1 root root   263 Jan 23  2016 proxy.xml
-rw-r--r-- 1 root root    65 Jan 23  2016 puppet_install_if_enabled
-rw-r--r-- 1 root root   644 Jan 23  2016 puppet_register_if_enabled
-rw-r--r-- 1 root root   836 Jan 23  2016 redhat_register
-rw-r--r-- 1 root root   662 Jan 23  2016 restore_boot_device
-rw-r--r-- 1 root root   620 Jan 23  2016 rhn_certificate_based_register
-rw-r--r-- 1 root root   358 Jan 23  2016 save_boot_device
-rw-r--r-- 1 root root   438 Jan 23  2016 suse_scriptwrapper.xml

官方帮助文档:http://cobbler.github.io/manuals/2.4.0/
参考文档:http://www.isjian.com/linux/automatic-operations-cobbler-system/
网页不方便? 快关注我们的微信公众号吧!
weixin.gif-425.6kB

相关文章:

  1. Kuerbernetes 1.11 集群二进制安装
  2. Xtrabackup安装以及应用
  3. Kubernetes 1.14 二进制集群安装
  4. CentOS 7 ETCD集群配置大全

相关文章

服务器端口转发,带你了解服务器端口转发
服务器开放端口,服务器开放端口的步骤
产品推荐:7月受欢迎AI容器镜像来了,有Qwen系列大模型镜像
如何使用 WinGet 下载 Microsoft Store 应用
百度搜索:蓝易云 – 熟悉ubuntu apt-get命令详解
百度搜索:蓝易云 – 域名解析成功但ping不通解决方案

发布评论