cobbler高可用方案
一、环境准备
| 主网IP | 私网IP | 主机名 | 角色 | VIP |
|---|---|---|---|---|
| 10.203.178.125 | 192.168.10.2 | node1 | 主 | 10.203.178.137,192.168.10.1 |
| 10.203.178.127 | 192.168.10.3 | node2 | 备 | - |
二、安装配置dhcp
1、10.203.178.125 配置dhcp服务
a、dhcp服务软件安装
yum install -y dhcpd
b、修改配置文件
vim /etc/dhcp/dhcpd.conf
# cobbler slave dhcpd
ddns-update-style interim;
allow booting;
allow bootp;
ignore client-updates;
set vendorclass = option vendor-class-identifier;
option pxe-system-type code 93 = unsigned integer 16;
subnet 192.168.10.0 netmask 255.255.254.0 {
option routers 192.168.10.1;
option domain-name-servers 10.202.32.100;
option subnet-mask 255.255.254.0;
range dynamic-bootp 192.168.10.10 192.168.10.199;
default-lease-time 7200;
max-lease-time 14400;
next-server 10.203.178.137;
class "pxeclients" {
match if substring (option vendor-class-identifier, 0, 9) = "PXEClient";
if option pxe-system-type = 00:02 {
filename "ia64/elilo.efi";
} else if option pxe-system-type = 00:06 {
filename "grub/grub-x86.efi";
} else if option pxe-system-type = 00:07 {
filename "grub/grub-x86_64.efi";
} else {
filename "pxelinux.0";
}
}
}
c、启动dhcpd服务:
service dhcpd restart
service dhcpd status
2、10.203.178.127 配置dhcp服务
a、安装dhcp服务
同上
b、配置dhcp服务
同上,但修改下列行到另一个c类地址段
range dynamic-bootp 192.168.11.10 192.168.11.199;
c、启动dhcpd服务:
同上
三、安装配置cobbler
yum install -y cobbler
四、安装配置keepalived
1、10.203.178.125安装keepalived服务
a、软件安装
yum install -y keepalived
b、配置keepalived
vim /etc/keepalived/scripts/keepalived.conf
global_defs {
router_id pribms.dev
}
vrrp_script chk_http1 {
script "/etc/keepalived/scripts/check_healthy.sh"
interval 2
}
vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id 137
priority 100
nopreempt
advert_int 1
authentication {
auth_type PASS
auth_pass 1qaz@WSX
}
virtual_ipaddress {
10.203.178.137
}
track_script {
chk_http1
}
master_notify /etc/keepalived/scripts/restart_cobblerd.sh
}
vrrp_instance VI_2 {
state BACKUP
interface eth3
virtual_router_id 101
priority 100
nopreempt
advert_int 1
authentication {
auth_type PASS
auth_pass 2wsx#EDC
}
virtual_ipaddress {
192.168.10.1
}
}
c、创建 keepalived 健康检查脚本
vim /etc/keepalived/scripts/check_healthy.sh
#!/bin/bash
stop_keepalived() {
service keepalived stop
exit 1
}
nc -w 10 -z 127.0.0.1 80 || service httpd restart
nc -w 10 -z 127.0.0.1 8080 || /bin/bash /app/cloud-pri-bms/code/run_app.sh restart
sleep 2
nc -w 10 -z 127.0.0.1 80 || stop_keepalived
nc -w 10 -z 127.0.0.1 8080 || stop_keepalived
d、创建 keepalived 角色切换为主之后的触发脚本
vim /etc/keepalived/scripts/restart_cobblerd.sh
#!/bin/bash
#Auther: Harry
#Date: 2019-09-12
/etc/init.d/cobblerd restart
/usr/bin/cobbler sync
e、启动keepalived并设置开机启动
# 启动服务
service keepalived start
ip a
# 打开开机自启动并验证:
chkconfig keepalived on
chkconfig keepalived --list
2、10.203.178.127安装keepalived服务
a、软件安装
同上
b、配置keepalived
同上
# 修改
priority 99
# 删除
nopreempt
c、创建keepalived监控检查脚本
同上
d、创建 keepalived 角色切换为主之后的触发脚本
同上
e、启动keepalived并设置开机启动
同上
五、安装配置rsync服务:
功能:rysnc客户端可以将指定目录中的文件同步到rsync服务器端
1、10.203.178.125配置rsync服务
a、安装rsync、xinetd、inotify-tools软件
yum install -y rsync xinetd inotify-tools
b、编辑rsyncd.conf配置文件
vim /etc/cobbler/rsync.template
在前面插入下面这段
log file = /var/log/rsyncd.log
pidfile = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
secrets file = /etc/rsync.pass
motd file = /etc/rsyncd.Motd
[systems]
path = /app/cobbler/config/systems.d/
comment = systemd
uid = root
gid = root
use chroot = no
read only = no
list = no
max connections = 200
timeout = 600
auth users = appfiles_user
hosts allow = 10.203.178.127
[tftpboot]
path = /app/tftpboot/
comment = tftpboot
uid = root
gid = root
use chroot = no
read only = no
list = no
max connections = 200
timeout = 600
auth users = appfiles_user
hosts allow = 10.203.178.127
同步到/etc/rsyncd.conf配置文件中
cobbler sync
c、设置rsync同步的账号和密码
echo "appfiles_user:123456" > /etc/rsync.pass
chmod 600 /etc/rsyncd.conf
chmod 600 /etc/rsync.pass
d、配置rsync同步密码
echo 123456> /etc/keepalived/passwd.txt
chmod 600 /etc/keepalived/passwd.txt
e、设置rsync服务开机自启动
chkconfig rsync on
chkconfig rsync --list
f、配置rsync_inotify.sh脚本文件
同步路径:
src1=/app/cobbler/config/systems.d/
src2=/app/tftpboot/
vim /opt/rsync_scripts/rsync_inotify.sh
#!/bin/bash
#20150608
export PATH=$PATH:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/binsbin:/bin:/usr/sbin:/usr/bin:/root/bin
src1=/app/cobbler/config/systems.d/
src2=/app/tftpboot/
des1=systems
des2=tftpboot
passwdfile=/etc/keepalived/passwd.txt
ip=10.203.178.127
logfile=/var/log/rsync_app.log
if ! grep -q 8192000 /proc/sys/fs/inotify/max_user_watches ; then
echo 8192000 > /proc/sys/fs/inotify/max_user_watches
fi
/usr/bin/inotifywait -mrq --timefmt '%Y-%m-%d %H:%M' --format '%T %w%f %e' -modify,delete,create,attrib $src1 | \
while read file ; do
rsync -vzrtopg --delete --progress $src1 appfiles_user@$ip::$des1 --passworfile=$passwdfile
echo "$file was synced" >> ${logfile} 2>&1
done &
/usr/bin/inotifywait -mrq --timefmt '%Y-%m-%d %H:%M' --format '%T %w%f %e' -modify,delete,create,attrib $src2 | \
while read file ; do
rsync -vzrtopg --delete --progress $src2 appfiles_user@$ip::$des2 --passworfile=$passwdfile
echo "$file was synced" >> ${logfile} 2>&1
done &
sleep 2
date '+%Y-%m-%d %H:%M:%S' >> /var/log/rync_date.log
wait
2、10.203.178.127配置rsync服务
a、安装rsync、xinetd、inotify-tools软件
同上
b、编辑rsyncd.conf配置文件
vim /etc/cobbler/rsync.template
同上
# 修改
hosts allow = 10.203.178.125
同步到/etc/rsyncd.conf配置文件中
同上
c、设置rsync同步的账号和密码
同上
d、配置rsync同步密码
同上
e、重启xinetd服务并设置rsync服务开机自启动
chkconfig rsync on
chkconfig rsync --list
service xinetd restart
f、配置rsync_inotify.sh脚本文件
同上
#修改
ip=10.203.178.125
六、故障恢复:
1、场景简介
正常情况下,10.203.178.125作为主节点提供服务
10.203.178.127作为备节点
主节点上的数据实时同步到备节点
2、主节点10.203.178.125宕机的情况
a、恢复10.203.178.125服务
检查httpd服务
service httpd status
service httpd start
检查cobbler服务
service cobblerd status
service cobblerd start
检查api服务
telnet 127.0.0.1 8080
/bin/bash /app/cloud-pri-bms/code/run_app.sh start
b、同步10.203.178.127数据到10.203.178.125
10.203.178.125检查并启动xinetd服务
/etc/init.d/xinetd status
/etc/init.d/xinetd start #未启动则手动启动服务
10.203.178.127执行同步脚本并创建文件
nohup sh /opt/rsync_scripts/rsync_inotify.sh >>/app/clog/rsync.log 2>&1 &
touch /app/cobbler/config/systems.d/1111.txt
touch /app/tftpboot/2222.txt
10.203.178.125上验证是否同步:
ll /app/cobbler/config/systems.d/
ll /app/tftpboot/
10.203.178.127上删掉刚才创建的文件
rm /app/cobbler/config/systems.d/1111.txt
rm /app/tftpboot/2222.txt
c、启动10.203.178.125高可用服务
检查keepalived服务并启动
service keepalived status
service keepalived start
3、备节点10.203.178.127宕机的情况
a、恢复10.203.178.127服务
检查httpd服务
service httpd status
service httpd start
检查cobbler服务
service cobblerd status
service cobblerd start
检查api服务
telnet 127.0.0.1 8080
/bin/bash /app/cloud-pri-bms/code/run_app.sh start
b、同步10.203.178.125数据到10.203.178.127
10.203.178.127检查并启动xinetd服务
service xinetd status
service xinetd start
10.203.178.125执行同步脚本并创建文件
touch /app/cobbler/config/systems.d/1111.txt
touch /app/tftpboot/2222.txt
10.203.178.127上验证是否同步
ll /app/cobbler/config/systems.d/
ll /app/tftpboot/
10.203.178.125上删掉刚才创建的文件
rm /app/cobbler/config/systems.d/1111.txt
rm /app/tftpboot/2222.txt
10.203.178.127重启cobbler服务并同步
service cobblerd restart
cobbler sync
c、启动10.203.178.127高可用服务
检查keepalived服务并启动
service keepalived status
service keepalived start
cobbler高可用方案的更多相关文章
- MySQL高可用方案
高可用架构对于互联网服务基本是标配,无论是应用服务还是数据库服务都需要做到高可用.虽然互联网服务号称7*24小时不间断服务,但多多少少有一些时候服务不可用,比如某些时候网页打不开,百度不能搜索或者无法 ...
- [转]MYSQL高可用方案探究(总结)
前言 http://blog.chinaunix.net/uid-20639775-id-3337432.htmlLvs+Keepalived+Mysql单点写入主主同步高可用方案 http://bl ...
- Sentinel-Redis高可用方案(一):主从复制
引言 大概是因为Redis是个人开发的产品,所以Redis的高可用方案是被分成了几块来实现:主从复制.主从切换以及虚拟IP或客户端方案. 从Redis 2.8开始加入对Sentinel机制从而实现了服 ...
- Redis之高可用方案
Redis之高可用方案 Redis以其高效的访问速度著称.但由于官方还未发布redis-cluster,而redis的replica又有诸多不便:比如一组master-slave的机器,如果之间有 ...
- mysql高可用方案总结性说明
MySQL的各种高可用方案,大多是基于以下几种基础来部署的(也可参考:Mysql优化系列(0)--总结性梳理 该文后面有提到)1)基于主从复制:2)基于Galera协议(PXC):3)基于NDB引 ...
- 大型网站系统架构实践(五)深入探讨web应用高可用方案
从上篇文章到这篇文章,中间用了一段时间准备,主要是想把东西讲透,同时希望大家给与一些批评和建议,这样我才能有所进步,也希望喜欢我文章的朋友,给个赞,这样我才能更有激情,呵呵. 由于本篇要写的内容有点多 ...
- [转载] MySQL高可用方案选型参考
原文: http://imysql.com/2015/09/14/solutions-of-mysql-ha.shtml?hmsr=toutiao.io&utm_medium=toutiao. ...
- 分布式数据存储 - MySQL主从复制高可用方案
前面几篇文章说道MySQL数据库的高可用方案主从复制.主从复制的延迟产生原因.延迟检测及延迟解决方案(并未从根本上解决),这种主从复制方案保证数据的冗余的同时可以做读写分离来分担系统压力但是并非是高可 ...
- (转)基于Redis Sentinel的Redis集群(主从&Sharding)高可用方案
转载自:http://warm-breeze.iteye.com/blog/2020413 本文主要介绍一种通过Jedis&Sentinel实现Redis集群高可用方案,该方案需要使用Jedi ...
随机推荐
- 8.15 day33 进程池与线程池_协程_IO模型(了解)
进程池和线程池 开进程开线程都需要消耗资源,只不过两者比较的情况线程消耗的资源比较少 在计算机能够承受范围之内最大限度的利用计算机 什么是池? 在保证计算机硬件安全的情况下最大限度地利用计算机 ...
- temperatureConversion2
Solution: #方法一:字符串与列表的相互转换和它们的基本函数操作 n = input() if n[0] in {"C","c"}: a= list(n ...
- 在Docker for Windows中运行GUI程序
Docker运行GUI原理 Docker目前大多应用在服务器领域,那么在Docker中可以运行GUI程序吗?怀着好奇心google了一番,还真有人写了一篇文章 running-gui-applicat ...
- Ubuntu系统开发环境完整搭建
安装搜狗输入法 点击我下载哦 idea快捷键冲突 输入发占用快捷键.撤掉输入法的快捷键.还有系统自带快捷键也要取消. 安装deepin-terminal 在tools工具包中找到deepin-term ...
- wcf项目跨域问题处理
最近做了一个wcf项目,请求发起的项目是一个webform项目,所以这是分开的两个项目端口必然不一样,理所当然存在跨域问题. 有的人当下就反应过来jsonp,jsonp只能用于get请求,对于参数比较 ...
- odoo模板中的t-标签用法
在OpenERP中,通过QWeb来对模板进行渲染后加载到浏览器中,而模板中有许多的标签来定制各种需求变化,在这里记录学习过程中碰到的标签定义,以方便查询. 模板中的标签统一都是以"t-&qu ...
- Redis学习总结(七)--Redis集群之客户端访问
我们来试试进行数据的存储 127.0.0.1:7000> set name marklogzhu OK 127.0.0.1:7000> get name "marklogzhu& ...
- jqGrid根据数据动态设置rowList
superme.rowList = [10,20,50,100]; superme.rowNum = 20; 全局属性 loadComplete : function (data) { if(data ...
- 安排:《蚂蚁花呗1234面:Redis+分布式架构+MySQL+linux+红黑树》
前言: 大厂面试机会难得,为了提高面试通关率,建议朋友们在面试前先复盘自己的知识栈,依据掌握程度划分重要.优先级,系统地去学习!如果不准备充分就去参加面试,既会失去进入大厂的机会,更是对自己的不负责. ...
- Java集合框架之Map接口浅析
Java集合框架之Map接口浅析 一.Map接口综述: 1.1java.util.Map<k, v>简介 位于java.util包下的Map接口,是Java集合框架的重要成员,它是和Col ...