centos 7 下 cobbler 安装

一、cobbler 介绍;

 

Cobbler 是一个系统启动服务(boot server),可以通过网络启动(PXE)的方式用来快速安装、重装物理服务器和虚拟机,支持安装不同的 Linux 发行版和 Windows。该工具使用python开发,小巧轻便(才15k行代码),使用简单的命令即可完成PXE网络安装环境的配置,同时还可以管理 DHCP,DNS,以及yum包镜像。

Linux学习,http:// linux.it.net.cn

Cobbler 使用命令行方式管理,也提供了基于 Web 的界面管理工具(cobbler-web),还提供了API接口,可以方便二次开发使用。 IT网,http://www.it.net.cn

Cobbler提供以下服务集成:
PXE服务支持
DHCP服务管理
DNS服务管理(可选bind,dnsmasq)
电源管理
Kickstart服务支持
yum仓库管理
TFTP (PXE启动时需要) Linux学习,http:// linux.it.net.cn
Apache(提供kickstart 的安装源,并提供定制化的kickstart配置) IT网,http://www.it.net.cn

同时,它和apache做了深度整合。通过 cobbler,可以实现对RedHat/Centos/Fedora系统的快速部署,同时也支持Suse 和Debian(Ubuntu)系统。 Linux学习,http:// linux.it.net.cn

cobbler装机系统是较早前kickstart的升级版,优点比较容易配置,还自带web界面比较易于管理,不足在于中文资料较少。和 Kickstart不同的是,使用cobbler不会因为在局域网中启动了dhcp而导致有些机器因为默认从pxe启动在重启服务器后加载tftp内容导 致启动终止。 IT网,http://www.it.net.cn

通过配置cobbler自动部署DHCP、TFTP、HTTP,在安装过程中加载kiskstart无人值守安装应答文件实现无人值守。从客户端使用PXE引导启动安装。

二、新系统初始化:

  1、修改主机名:

    # vi /etc/hostname

  2、关闭防火墙,selinxu:

    #systemctl stop firewalld    (centos 7 默认防火墙 firewall)

    #systemctl disable firewalld

  3、安装常用工具:

     #yum -y install wget vim lrzsz

  4、更新yum 源,  在本地源中没有cobbler

    #yum -y install epel-release

 三、安装配置cobbler:

  1、安装cobbler 依赖包和相关服务

    #yum -y install cobbler    

    #yum -y install cobbler-web

    #yum -y install fence-agents        (实现电源管理)

    #yum -y install dhcp        

    #yum -y install pykickstart           (kickstart 软件,系统无人值守安装

    #yum -y install xinetd        (tftp 服务 使用)

    #yum -y install tftp-server

    #yum -y install system-config-kickstart     (如果不通过图形化界面 创建ks 文件,可以不用安装)

  2、开启服务:

    # systemctl start httpd

    # systemctl start cobblerd

    # systemctl enable httpd

    # systemctl enable cobblerd

  3、配置cobbler ,检查配置:

    # cobbler check

     centos 7 下 cobbler 安装

    按提示依次解决相关报错:

    1-2:编辑cobbler配置文件/etc/cobbler/settings 修改一下几项

    # vim /etc/cobbler/settings 

      bind_master: 可用的dns服务器IP 

      next_server: cobbler服务器IP  (选项 next_server 用在 DHCP 配置文件中,向机器告知提供引导文件的服务器地址。选项 server 在机器安装期间用于引用 Cobbler 服务器地址)

      server: cobbler服务器IP 

       manage_dhcp: 1     (0:表示有独立的*服务器, 1:表示服务由cobbler 托管)

       manage_dns: 0

      manage_tftpd: 1

      restart_dns: 1

      restart_dhcp: 1

      pxe_just_once:1    (选项 pxe_just_once 预防将机器中的安装循环配置为始终从网络引导。激活此选项时,机器告诉 Cobbler 安装已完成。Cobbler 将系统对象的 netboot 标志更改为 false,这会强制机器从本地磁盘引导。)

    3:上述dhcp 服务器和 tftp 服务器均由cobbler 托管,需要配置cobbler的dhcp服务配置和tftp服务配置,配置完成后服务由cobbler sync 托管启动。

      3-1、编辑tftp配置文件:

        # vim /etc/cobbler/tftpd.template

          disable  = no    “yes改为no”

      3-2、编辑dhcp配置文件

        # vim /etc/cobbler/dhcp.template

      centos 7 下 cobbler 安装

    4:执行cobbler get-loaders 下载部分缺失的网络boot-loaders 引导文件

      # cobbler get-loaders

    5:启动rsyncd

      # systemctl start rsyncd

      # systemctl enable rsyncd

    6:debian安装用,不需要可以不管

    7:"openssl passwd -1 -salt 'random-phrase-here' 'your-password-here'"   其中random-phrase-here  为任意字符、your-password-here  是cobbler 服务器的密码

      # openssl passwd -1 -salt '123456789' '111111'   生成的密码替换/etc/cobbler/settings文件里面default_password_crypted:的密码

  4、http 配置:

    由于默认distro文件存放目录为/var/www/cobbler/ks_mirrors 而http默认站点根目录为/var/www/html,所以安装系统的时候会报错找不到/var/www/cobbler/ks_mirror/centos7.2-x86_64/LiveOS/squashfs.img 所以在这里需要更改http服务默认站点根目录然后重启服务

    # vim /etc/http/conf/httpd.conf

      DocumentRoot “/var/www/html”   ––> DocumentRoot “/var/www”

    # systemctl restart httpd

     # systemctl restart cobblerd

     # cobbler sync     (cobbler 配置刷新,检查有没有配置或依赖服务有问题)

  5、定义distro

    挂在iso镜像:

      # mkdir /mnt/iso

      # mount -o loop /date/CentOS-7-x86_64-DVD-1611.iso /mnt/iso      (iso 文件已下载至 /data 目录下)

    导入distro:

      # cobbler import --arch=x86_64 --path=/mnt/iso --name=Centos-7-x86_64    (需要一段时间)

    命令格式:cobbler import --path=镜像路径 -- name=安装引导名 --arch=32位或64位

    参数说明:
      --name :为安装源定义一个名字
      --arch :指定安装源是32位还是64位、ia64, 目前支持的选项有: x86│x86_64│ia64
      注意:这个安装源的唯一标示 就是根据这两个参数来定义

    导入成功后,安装源的唯一标示就是:centos-7-x86_64,如果重复,系统会提示导入失败,其它命令可通过cobbler -help来进行查看.如果需要更多的参数定制,也可以查看官方文档:man cobbler,然后查找 import 的配置,可以使用另外一个命令:cobbler distro. cobbler会将镜像中的所有安装文件拷贝到本地一份,放在/var/www/cobbler/ks_mirrors/下的centos-7-x86_64目录下,同时会创建一个名字为centos-7--x86_64的一个发布版本,以及一个名字为centos-7-x86_64的profile文件,此profile文件指定/var/lib/cobbler/kickstarts/simple_end.ks为默认ks文件

  6、制作ks文件 (无人值守脚本) 

# kickstart template for Fedora  and later.
# (includes %end blocks)
# do not use with earlier distros #platform=x86, AMD64, or Intel EM64T
# System authorization information
auth --useshadow --enablemd5
# System bootloader configuration
bootloader --location=mbr
# Use text mode install
text
# Firewall configuration
firewall --enabled
# Run the Setup Agent on first boot
firstboot --disable
# System keyboard
keyboard us
# System language
lang en_US
# Use network installation
url --url=$tree
# If any cobbler repo definitions were referenced in the kickstart profile, include them here.
$yum_repo_stanza
# Network information
$SNIPPET('network_config')
# Reboot after installation
reboot #Root password
rootpw --iscrypted $default_password_crypted
# SELinux configuration
selinux --disabled
# Do not configure the X Window System
skipx
# System timezone
timezone Asia/Shanghai
# Install OS instead of upgrade
install
# Clear the Master Boot Record
zerombr
# Allow anaconda to partition the system as needed
#autopart
# Partition clearing information
clearpart --all --initlabel
# Disk partitioning information
part /boot --fstype="xfs" --size=
part swap --fstype="swap" --size=
part / --fstype="xfs" --grow --size= %pre
$SNIPPET('log_ks_pre')
$SNIPPET('kickstart_start')
$SNIPPET('pre_install_network_config')
# Enable installation monitoring
$SNIPPET('pre_anamon')
%end %packages
$SNIPPET('func_install_if_enabled')
%end %post --nochroot
$SNIPPET('log_ks_post_nochroot')
%end %post
$SNIPPET('log_ks_post')
# Start yum configuration
$yum_config_stanza
# End yum configuration
$SNIPPET('post_install_kernel_options')
$SNIPPET('post_install_network_config')
$SNIPPET('func_register_if_enabled')
$SNIPPET('download_config_files')
$SNIPPET('koan_environment')
$SNIPPET('redhat_register')
$SNIPPET('cobbler_register')
# Enable post-install boot notification
$SNIPPET('post_anamon')
# Start final steps
$SNIPPET('kickstart_done')
# End final steps
%end

    也可以使用图形化工具生成ks文件

      # system-config-kickstart        #需要在图形化界面运行,需要安装桌面包,然后按提示一步一步生成ks.cfg文件)   VNC配置:http://www.cnblogs.com/weijie0717/p/6746508.html

  7、创建ks文件 ,保存到/var/lib/cobbler/kickstarts/目录内 ,导入系统distro时,系统指定的默认ks文件为/var/lib/cobbler/kickstarts/sample_end.ks,在这里我们需要重新指定ks文件

    # cobbler profile report --name Centos-7-x86_64     ( 查看profile 设置)

    # cobbler distro report --name Centos-7-x86_64  (查看安装镜像文件信息)

    # cobbler profile add --name=Centos-7-x86_64 --distro=Centos-7-x86_64 --kickstart=/var/lib/cobbler/kickstarts/Centos-7.ks    (绑定 profile 和 distro )

    # cobbler profile edit --name=Centos-7-x86_64 --distro=Centos-7-x86_64 --kickstart=/var/lib/cobbler/kickstarts/Centos-7.ks    (编辑 profile 和 distro )

  8、再次执行 cobbler check   看看之前的报错是否的一一解决。

  9、 如果没有任何问题,刷新cobbler 配置:

    # cobbler sync

  10、从起服务器,安装系统:

    centos 7 下 cobbler 安装

四、cobbler  web配置

上一篇:可能将身份验证令牌存储在单独的文件中吗?


下一篇:Spring Security oAuth2 创建项目工程