设为首页 收藏本站
查看: 1769|回复: 0

[经验分享] 实现高可用集群(一)

[复制链接]

尚未签到

发表于 2019-1-7 13:50:49 | 显示全部楼层 |阅读模式
  Heartbeat介绍
heartbeat的三个版本
# heartbeat  v1版本,资源管理器:haresources 配置接口:haresource文件
# heartbeat  v2版本,资源管理器:crm         配置接口:crm(shell),heartbeat-GUI图形界面化
# heartbeat  v3版本,资源管理器:pacemaker   配置接口:(1)CLI:crm,pcs (2)GUI:hawk,LCMC,pacemaker-mgmt
heartbeat特性:
#(1)侦听在udp/694端口
#(2)在meesage layer传送各个节点的信息与事务信息,一般用udp --信息量较少,传输速度快无需tcp协议的三次握手
#(3)同时支持在两个网卡传送信息、支持多播,广播,单播、支持串行口(主机)  安装配置高可用集群必备步骤
  

1、节点名称:集群每个节点的名称都得能互相解析
#  /etc/hosts的主机名的正反解析结果必须跟"uname -n"的结果保持一致;
2、时间必须得同步
#  使用网络事件服务器同步时间
3、并非必须:各节点能基于ssh密钥认证通信;
#   工具:ansible(大部分使用它)、fabric--------多节点时使用  

  

  

  双节点实现高可用集群
  

  

使用hearbeat v1版本实现高可用集群,集群资源为VIP,filesystem,httpd
#上述已经说到,heartbeat v1版本的资源管理器为haresources;配置接口:haresources配置文件  

  

  

1、准备工作
#配置epel源
#启用epel源rpm -ivh http://download.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
#导入key rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6  

  

2、节点规划
#node1 192.168.1.97 网页服务器 node1.linux.com
#node2 192.168.1.98 网页服务器 node2.linux.com
#NFS Ser 192.168.1.100 文件共享服务器
# VIP  192.168.1.200  

  


  

  

  

3 、配置node1、node2
配置node1
第一步 设置主机名
#vim  /etc/sysconfig/network
hostname=node1.linux.com
#vim /etc/hosts
192.168.1.97 node1.linux.com node1
192.168.1.98 node2.linux.com node2
#pin node1.linux.com 查看解析情况
第二步 时间要同步
# ntpdate time.windows.com 与windows主机时间保持一致,此处可以自己设置一台时间服务器
# crontab -e 配置周期性任务
*/5 * * * * /usr/sbin/ntpdate time.windows.com &> /dev/null 每5s与windows主机同步一次
第三步 双方互给自己的公钥,保证双方ssh通信部再需要密码
# ssh-keygen -t rsa -P '' 生成空密码密钥
# ssh-copy -i .ssh/id_rsa.pub root@node2.linux.com
配置node2
#node2的配置同node1配置,此处不再演示
注意!!以上三步为必要步骤,而且都要在双方节点上执行  


  主机解析已成功,时间已同步,ssh通信已无需输入密码
  

  

4 、node1、node1上安装heartbeat
解决依赖关系
#yum -y install per-TimeDate PyXML libnet-snmp-libs libnet-devel
安装heartbeat
#rpm -ivh heartbeat-2.1.4-12.el6.x86_64.rpm heartbeat-pils-2.1.4-12.el6.x86_64.rpm heartbeat-stonith-2.1.4-12.el6.x86_64.rpm
#注意:要安装heartbeat程序,heartbeat-pils集群粘合器,heartbeat-stonith代理资源类别,由于我们使用了2个节点,需要资源隔离  

  

  

  

5 、node1上编辑ha.cf文件、resources文件、authkey文件
(1)提供三个文件
# cp /usr/share/doc/heartbeat-2.1.4/{authkeys,ha.cf,haresources} /etc/ha.d   ----拷贝上述三个文件到/etc/ha.d
# cd /etc/ha.d
(2)编辑 authkeys   ####保证各个节点点间通信安全
# openssl rand -hex 8 ----生成8位十六进制随机数
2432c681e77162e3
# vim authkeys       -----提供消息认证密码HMAC单向,内容如下
auth 2
2   sha1 2432c681e77162e3
# chmod 600 authkeys  -----必须设置权限为600或者400
(3)编辑ha.cf  ###层heartbeat的配置文件
# vim ha.cf   内容如下
logfile /var/log/ha-log    集群日志;或者使用#logfacility
keepalive 1000ms           保持时间
deadtime 8                 时间
warntime 4                 时间
mcast eth0 225.0.0.1 694 1 0 组播地址
auto_failback on           节点恢复后,资源自动迁移
node    node2.linux.com    添加节点
node    node1.linux.com    添加节点
ping 192.168.1.1           节点仲裁,此处我们使用网关即默认路由
compression     bz2        信息,事务信息的压缩格式
compression_threshold 2    压缩的门槛
(4)编辑haresource  ###资源管理器;配置接口
# vim haresources
node1.linux.com 192.168.1.200/24/eth0 Filesystem::192.168.1.100:/www/htdocs::/var/www/html::nfs httpd
# DC  :node1.linux.com
# VIP : 192.168.1.200/24/eth0
# NFS :Filesystem::192.168.1.100:/www/htdocs::/var/www/html::nfs
# httpd :httpd属于LSB资源代理类别,没有其他参数
node2上编辑ha.cf文件、resources文件、authkey文件
#无需编辑,将node1上的文件拷贝过去即可
# scp -p authkeys haresources ha.cf node1:/etc/ha.d/  

6、 node1,node2编辑网页
node1
#vim /var/www/html/index.html
node1.linux.com
#service httpd stop   关闭服务
#chkconfig httpd off  开机不启动
node2
#vim /var/www/html/index.html
/node2.linux.com
#service httpd stop
#chkconfig httpd off  

  

7、配置NFS服务器
#vim /etc/exports 配置文件内容如下
/var/htdocs  192.168.0.0/16(rw)
#mkdir -pv /var/htdocs
#vim /var/htdocs/index.html
Page On NFS Server!!!
#setfacl -m u:apache:rwx /var/htdocs ---设置apache用户对该目录就有读写执行权限
#serivce nfs start  --启动服务  

  

  

8、node1、node2启动heartbeat
#service heartbeat start
#ssh node2.linux.com 'server heartbeat start'  

  

9、客户端测试 IP 192.168.1.101  


  

#我们设置的DC节点为node1,此时我们将node1设置为备用
# /usr/share/heartbeat/hb_standby
再次测试  


  

  

  

总结:使用heartbeat v1版本实现node1、node2双节点高可用集群,关闭node服务或者hb_standby为备用,网页依然可以访问,资源自动切换到node2上。  

  PS:水平有限,请指教。 关于heartbeat v2版本实现HA马上推出,敬请期待!




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-660399-1-1.html 上篇帖子: 34补1 下篇帖子: HA集群错误排障以及相关配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表