zoukankan      html  css  js  c++  java
  • heartbeat 非联网安装(通过配置本地yum文件库安装heartbeat)

    软件环境:centos6.5

    一、下载rpm包

    首先找一台联网的centos6.5机器

    安装epel扩展源:

    yum install -y epel-release

    安装yum-plugin-downloadonly:

    yum install yum-plugin-downloadonly

    安装完就可以使用yum只下载不安装功能了

    yum install  --downloadonly  --downloaddir=***  -y  ***

    downloadonly:只下载模式;downloaddir:指定下载目录;-y后面是要安装的软件(会下载下来该软件的rpm包及相关依赖包)

    创建createrepo文件夹(用于配置本地yum源):

    cd /opt/
    mkdir createrepo

    下载createrepo相关软件包:

    yum install --downloadonly --downloaddir=/opt/createrepo/ -y createrepo

    在/opt/下创建rpm文件夹:

    mkdir rpm

    下载heartbeat、libnet、nginx包 :

    yum install --downloadonly --downloaddir=/opt/rpm/ -y heartbeat* libnet* nginx

    截图是一部分

    二、配置本地yum源

    进入到createrepo文件夹下:

    cd /opt/createrepo/

    按照如上顺序安装createrepo:

    rpm -ivh deltarpm-3.5-0.5.20090913git.el6.x86_64.rpm
    
    rpm -ivh python-deltarpm-3.5-0.5.20090913git.el6.x86_64.rpm 

    安装 libxml2-2.7.6-21.el6_8.1.x86_64.rpm 时 报如下错误:

    说明包有冲突,把原来的包卸载:

    yum -y remove libxml2-2.7.6-14.el6.x86_64

    竟然报错!可能要卸载的依赖项包含yum或正在被yum使用,无法卸载

    只卸载 libxml2-2.7.6-14.el6.x86_64,忽略依赖项,使用“–nodeps”参数

    rpm -e --nodeps libxml2-2.7.6-14.el6.x86_64

    然后继续安装:

    rpm -ivh libxml2-2.7.6-21.el6_8.1.x86_64.rpm
    rpm -ivh libxml2-python-2.7.6-21.el6_8.1.x86_64.rpm
    rpm -ivh createrepo-0.9.9-27.el6_9.noarch.rpm

    安装成功后创建yum仓库:

    createrepo /opt/rpm/

    修改repo文件:

    cd /etc/yum.repos.d/

    创建repo_backup目录,然后将所有文件剪切到此目录:

    mkdir repo_backup
    mv *.repo ./repo_backup

    拷贝cp  CentOS-Media.repo :

    cp  ./repo_backup/CentOS-Media.repo  ./

    修改该文件:

    原文件

    修改后

    初始化yum缓存:

    yum clean all
    yum makecache

    yum repolist

    本地仓库搭建完毕。

    三、本地安装

     主副节点都要安装

    yum -y install  heartbeat*

    发现并未安装成功:

    GPG密钥存在的目的是处于安全和规范考虑,RedHat在发布软件包的时候会根据软件包生成对应密钥,当用户安装软件包的时候会根据密钥校验软件包。yum安装的时候就会校验软件包是否是官方发布的。

    可以给yum添加--nogpgcheck来强制安装或者在将源码包加入到仓库中的时候可以提前检验一下源码包的官方性:rpm -K *.rpm

    检测完成后安装:

    yum -y install  heartbeat*
    yum -y install libnet*
    yum -y install nginx --nogpgcheck

    安装成功。 

    四、配置heartbeat

    拷贝配置文件:

    cd /usr/share/doc/heartbeat-3.0.4/
    cp authkeys ha.cf haresources /etc/ha.d/
    cd /etc/ha.d/

    修改authkeys:

    vim authkeys

    修改权限:

    chmod 600 authkeys

    编辑haresources文件:

    vim haresources

    在最后一行加入:

    其中master为主节点hostname,192.168.60.200为vip,/24为掩码为24的网段,eth0:0为vip的设备名,nginx为heartbeat监控的服务(/usr/sbin目录下的)。

    编辑ha.cf修改如下:

    debugfile /var/log/ha-debug
    
    logfile /var/log/ha-log
    
    logfacility local0
    
    keepalive 2
    
    deadtime 30
    
    warntime 10
    
    initdead 60
    
    udpport 694
    
    ucast eth0 192.168.60.137
    
    auto_failback on
    
    node master
    
    node slave
    
    ping 192.168.60.200
    
    respawn hacluster /usr/lib64/heartbeat/ipfail

    配置说明:

    debugfile /var/log/ha-debug该文件保存heartbeat的调试信息。
    logfile /var/log/ha-logheartbeat的日志文件。
    keepalive 2:心跳的时间间隔,默认时间单位为秒s。
    deadtime 30:超出该时间间隔未收到对方节点的心跳,则认为对方已经死亡。
    warntime 10:超出该时间间隔未收到对方节点的心跳,则发出警告并记录到日志中。
    initdead 60:在某系统上,系统启动或重启之后需要经过一段时间网络才能正常工作,该选项用于解决这种情况产生的时间间隔,取值至少为deadtime的2倍。
    udpport 694:设置广播通信使用的端口,694为默认使用的端口号。
    ucast eth0 192.168.60.137:设置对方机器心跳检测的网卡和IP。
    auto_failback on:heartbeat的两台主机分别为主节点和从节点。主节点在正常情况下占用资源并运行所有的服务,遇到故障时把资源交给从节点由从节点运行服务。在该选项设为on的情况下,一旦主节点恢复运行,则自动获取资源并取代从节点,否则不取代从节点。

    ping 192.168.60.200:设置的VIP。
    respawn heartbeat /usr/lib/heartbeat/ipfail:指定与heartbeat一同启动和关闭的进程,该进程被自动监视,遇到故障则重新启动。最常用的进程是ipfail,该进程用于检测和处理网络故障,需要配合ping语句指定的ping node来检测网络连接。如果你的系统是64bit,请注意该文件的路径。

    把主节点的配置文件拷到从节点:

    scp authkeys ha.cf haresources slave:/etc/ha.d/

    编辑从节点的ha.cf文件:

    vi /etc/ha.d/ha.cf

    修改:ucast eth0 192.168.60.139

    五、启动heartbeat服务

    先master启动,后slave启动

    service heartbeat start

    查看ip是否绑定:

    ip add

  • 相关阅读:
    应用部署架构演进【转载】
    TiDB 学习笔记一(运维管理)
    c++ strcmp函数
    C++ sort()函数
    C++ 遍历set的三种方式
    nvcc fatal : '--ptxas-options=-v': expected a number
    PAT A1039 Vector的使用
    C++ set
    C++ int与string互转换
    C++%f和%lf的区别
  • 原文地址:https://www.cnblogs.com/MrZheng/p/9037207.html
Copyright © 2011-2022 走看看