cobbler深入学习

时间:2022-08-29 16:08:38

cobbler重要目录和cobbler各对象的关系

/var/www/cobbler/ks_mirror 存放操作系统镜像
/var/www/cobbler/repo_mirror 存放仓库镜像
/var/lib/cobbler/kickstarts 存放kickstarts文件
/var/lib/cobbler/loaders 存放启动时需要的文件
/var/lib/cobbler/snippets 存放脚本
/etc/cobbler 存放cobbler的配置文

cobbler深入学习

自定义yum源

cobbler可以管理yum源,以使用阿里云的openstack为例

http://mirrors.aliyun.com/centos/7.2.1511/cloud/x86_64/openstack-mitaka/

1) 添加openstack仓库源

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

2) 同步 cobbler reposync

cobbler深入学习

3) 将openstack-mitaka在安装centos 7时,默认导入安装

cobbler profile edit --name=CentOS-7.1-x86_64 --repos="openstack-mitaka"

cobbler profile report CentOS-7.1-x86_64 查看仓库源

cobbler深入学习

vim /etc/cobbler/settings  可以查看到yum_post_install_mirror默认开启

cobbler深入学习

4) 修改kickstart文件

vim /var/lib/cobbler/kickstarts/CentOS-7-x86_64.cfg

cobbler深入学习

#Kickstart Configurator for cobbler by Jason Zhao
#platform=x86, AMD64, or Intel EM64T
#System language
lang en_US
#System keyboard
keyboard us
#Sytem timezone
timezone Asia/Shanghai
#Root password
rootpw --iscrypted $default_password_crypted
#Use text mode install
text
#Install OS instead of upgrade
install
#Use NFS installation Media
url --url=$tree
#System bootloader configuration
bootloader --location=mbr
#Clear the Master Boot Record
zerombr
#Partition clearing information
clearpart --all --initlabel
#Disk partitioning information
part /boot --fstype xfs --size 1024 --ondisk sda
part swap --size 16384 --ondisk sda
part / --fstype xfs --size 1 --grow --ondisk sda
#System authorization infomation
auth --useshadow --enablemd5
#Network information
$SNIPPET('network_config')
#network --bootproto=dhcp --device=em1 --onboot=on
# Reboot after installation
reboot
#Firewall configuration
firewall --disabled
#SELinux configuration
selinux --disabled
#Do not configure XWindows
skipx
#Package install information
%pre
$SNIPPET('log_ks_pre')
$SNIPPET('kickstart_start')
$SNIPPET('pre_install_network_config')
# Enable installation monitoring
$SNIPPET('pre_anamon')
%end %packages
@ base
@ core
sysstat
iptraf
ntp
lrzsz
ncurses-devel
openssl-devel
zlib-devel
OpenIPMI-tools
mysql
nmap
screen
%end %post
systemctl disable postfix.service $yum_config_stanza
%end

5) 添加定时任务,定期同步repo

echo "1 3 * * * /usr/bin/cobbler reposync --tries=3 --no-fail" >> /var/spool/cron/root

cobbler深入学习

cobbler深入学习

自动化装机

之前通过cobbler操作的安装并没有完全的自动化,需要在页面进行选择,我们在实现真正的自动化安装前,需要清楚整体流程。

下图参考

cobbler深入学习

在自动化安装操作系统,需要做的几件事:

1、存在硬件设备,如果虚拟机要创建完一个虚拟机,分配好内存、CPU、硬盘等资源

cobbler深入学习

2、分配IP、域名、子网掩码、网关、DNS、MAC地址,以虚拟机为例

cobbler深入学习

获取MAC地址为:00:50:56:3F:1B:9E

IP:192.168.137.51

主机名:cobbler-auto

子网掩码:255.255.255.0

网关:192.168.137.2

DNS:192.168.137.2

备注:MAC地址必须是唯一的,通过配置MAC地址才能进行自动化安装。

cobbler system list

cobbler system add --name=cobbler-auto --mac=00:50:56:3F:1B:9E \
--profile=CentOS-7.1-x86_64 \
--ip-address=192.168.137.51 --subnet=255.255.255.0 --gateway=192.168.137.2 --interface=eth0 \
--static=1 --hostname=cobbler-auto --name-servers="192.168.137.2 114.114.114.114" \
--kickstart=/var/lib/cobbler/kickstarts/CentOS-7-x86_64.cfg cobbler system list

cobbler深入学习

cobbler sync

cobbler深入学习

cobbler深入学习

cobbler深入学习

安装成功

cobbler深入学习

安装 成功的主机中已经添加了openstack-mitaka的yum源

cobbler深入学习

Cobbler API

cd /etc/httpd/conf.d

cat cobbler.conf

cobbler深入学习

通过上图标红处,可以看到cobbler API是通过http调用

如下为python调用样例脚本

#!/usr/bin/python
import xmlrpclib
import time
server = xmlrpclib.Server("http://192.168.137.10/cobbler_api")
print server.get_distros()
time.sleep(1)
print server.get_profiles()
time.sleep(1)
print server.get_systems()
time.sleep(1)
print server.get_images()
time.sleep(1)
print server.get_repos()
time.sleep(10)

实现上面命令的一个完整脚本

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import xmlrpclib class CobblerAPI(object):
def __init__(self,url,user,password):
self.cobbler_user= user
self.cobbler_pass = password
self.cobbler_url = url def add_system(self,hostname,ip_add,mac_add,profile):
'''
Add Cobbler System Infomation
'''
ret = {
"result": True,
"comment": [],
}
#get token
remote = xmlrpclib.Server(self.cobbler_url)
token = remote.login(self.cobbler_user,self.cobbler_pass) #add system
system_id = remote.new_system(token)
remote.modify_system(system_id,"name",hostname,token)
remote.modify_system(system_id,"hostname",hostname,token)
remote.modify_system(system_id,'modify_interface', {
"macaddress-eth0" : mac_add,
"ipaddress-eth0" : ip_add,
"dnsname-eth0" : hostname,
}, token)
remote.modify_system(system_id,"profile",profile,token)
remote.save_system(system_id, token)
try:
remote.sync(token)
except Exception as e:
ret['result'] = False
ret['comment'].append(str(e))
return ret def main():
cobbler = CobblerAPI("http://192.168.137.10/cobbler_api","cobbler","cobbler")
ret = cobbler.add_system(hostname='cobbler-api-test',ip_add='192.168.137.111',mac_add='00:50:56:25:C2:AA',profile='CentOS-7.1-x86_64')
print ret if __name__ == '__main__':
main()

执行上面的脚本,通过cobbler system list命令可以看到多出cobbler-api-test这项,这是通过cobbler API实现添加

cobbler深入学习

电源管理

增加

cobbler system edit --name=cobbler-auto --power-address=192.168.138.51 \
--power-type='ipmilan' --power-user=ipmi -power-pass=ipmi

常用命令

cobbler system poweroff
cobbler system powon
cobbler system powerstatus
cobbler system reboot

重启服务器并从PXE引导启动,并指定安装的操作系统配置。

cobbler system edit --name=cobbler-auto --netboot-enabled=1 --profile=CentOS-7.1-x86_64

  

官网文档

对于cobbler,如果要做一些个性化配置,可以参考官方文档进行实现。

如下图是官网给出的示例,如何去实现双网卡绑定。

http://cobbler.github.io/manuals/2.8.0/4/1/1_-_Bonding.html

cobbler深入学习

cobbler深入学习的更多相关文章

  1. Cobbler学习之二--Cobbler的Web管理和维护

    Cobbler的Web管理模块和命令行模块是可以分开工作的,没有依赖关系. 1 WebUI的功能 查看所有的对象和配置文件 添加或者删除system,distro, profile 执行“cobble ...

  2. Cobbler学习之一--Fedora17下配置Cobbler安装环境

    1:Cobbler是什么 Cobbler是一大Linux装机利器,可以快速的建立网络安装环境. 2:安装Cobbler需要的组件 createrepo httpd (apache2 for Debia ...

  3. cobbler学习

    note.youdao.com/share/?id=2f8383d6e9824929012b041f069da26e&type=note#/ IPADDR=192.168.86.4 TYPE= ...

  4. 关于OpenStack的学习路线及相关资源汇总

    首先我们想学习openstack,那么openstack是什么?能干什么?涉及的初衷是什么?由什么来组成?刚接触openstack,说openstack不是一个软件,而是由多个组件进行组合,这是一个更 ...

  5. 自动化运维工具ansible学习+使用ansible批量推送公钥到远程主机

    目录: 一.ansible简介 1.1.ansible是什么 1.2.ansible如何工作 1.3.ansible优缺点 1.4.ansible安装方式 1.5.ansible文件简单介绍 1.6. ...

  6. kvm cobbler无人值守批量安装操作系统

    kvm cobbler无人值守批量安装操作系统 cobbler:一个自动网络安装系统的工具,集成PEX.dhcp.dns.tftpd.sync等服务.可以供大家管理安装操作系统 kvm:Linux系统 ...

  7. cobbler无人值守批量安装Linux系统

    本文目录: 1.1 pxe安装系统 1.2 cobbler基本介绍 1.3 安装和配置cobbler 1.3.1 安装cobbler 1.3.2 配置dhcp和tftp 1.4 cobbler从本地光 ...

  8. cobbler部署安装CentOS6.8

    Linux运维:cobbler : 矮哥linux运维群:93324526 学习cobbler的话,必须先搞懂kickstart,原理不是,不懂如何排错. kickstart部署请点击这里 1. Co ...

  9. Linux 系统化学习系列文章总目录(持续更新中)

    本页内容都是本人系统化学习Linux 时整理出来的.这些文章中,绝大多数命令类内容都是翻译.整理man或info文档总结出来的,所以相对都比较完整. 本人的写作方式.风格也可能会让朋友一看就恶心到直接 ...

随机推荐

  1. T-SQL 将动态SQL的结果集赋值到变量

    1. 使用输出变量 ) ) DECLARE @counts int SET @city = 'New York' SET @sqlCommand = 'SELECT @cnt=COUNT(*) FRO ...

  2. node-webkit 使用requirejs 小结

    1. node-webkit 启动页使用requrejs 将webapp中的require改为requirejs,因为requirejs本来就应该用requirejs的,require只是requir ...

  3. HDU 4162 最小表示法

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=4162 题意:给定一个只有0-7数字组成的串.现在要由原串构造出一个新串,新串的构造方法:相邻2个位置的数字 ...

  4. ffrpc相关文章列表

    ffrpc 是异步c++通信库.可以说是传统rpc模式和zeromq模式的一个结合,采用broker模式封装client和server之间的拓扑关系,而client和server的通信仍然按照请求应答 ...

  5. JavaBean在JSP中显示时间

    创建DateTimeBean的类,将其放置于org.caiduping.bean的包中,实现时间,星期的封装. package org.caiduping.bean; import java.text ...

  6. 空对象模式(Null Object Pattern)

    空对象模式:用一个空对象来取代null实例的检查,空对象实现一个不做任何动作的关系.(消除如if(Object == null) 这样的检查null实例代码) 例子: public abstract ...

  7. 在 Windows Azure 上部署预配置 Oracle VM

    Microsoft 和 Oracle 近期宣布建立战略合作伙伴关系,基于此,我们将通过 Windows Azure 镜像库推出多种常用的 Oracle 软件配置.即日起,客户可以在 Windows S ...

  8. C# 创建windows 服务

    1.      新建项目 1.1 右键解决方案 – 添加 – 新建项目 1.2 已安装模板 - windows  -  windows服务 – 输入名称 – 点击 ”确定” 2.      添加相应的 ...

  9. Hdu3363 Ice-sugar Gourd 2017-01-16 11:39 43人阅读 评论(0) 收藏

    Ice-sugar Gourd Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  10. 如何查看ETW Trace?

    三种方法: LogParser Tractrpt - C:\Windows\System32 SvcTraceViewer.exe   后面的链接中有使用的详细步骤.   参考资料 ========= ...