一、准备:

1.1 安装依赖软件 如果系统为基本文本安装,需要安装一下软件 

yum -y install ipvsadm

yum -y install kernel kernel-devel

reboot   重启系统切换内核

yum -y install openssl-devel

1.2 安装好这些软件之后,注意看是否安装好了GCC这些编译器,如果没有,安装GCC编译器

yum -y install gcc
yum -y install gcc-c++
yum install make
-- 或者
yum groupinstall "Development Tools"
-- 或者
yum install gcc gcc-c++ kernel-devel
 
二、安装Keepalived软件
下载地址:http://www.keepalived.org/download.html
选择最新keepalived,当前选用版本为 Keepalived for Linux - Version 1.2.19 - July 07, 2015
下载成功后,将软件上传,进行安装。
本次将软件上传至路径 /soft/keepalived 路径下
cd /soft/keepalived
tar -xvf keepalived-1.2.19.tar.gz
cd /soft/keepalived/keepalived-1.2.19
ln -s /usr/src/kernels/(你系统下面的一个内核版本)     /usr/src//linux  -- 这个需要配置,不然会报错
./configure  --prefix=/usr  --sysconf=/etc

make

make install

完成安装

三、配置keepalived

配置keepalived之前先了解配置文件中的一些属性的含义,配置文件为keepalived.conf

! Configuration File for keepalived

#全局定义块,包含邮件定义部分,
global_defs {
  notification_email {
    acassen@firewall.loc
    failover@firewall.loc
    sysadmin@firewall.loc
  }
  notification_email_from Alexandre.Cassen@firewall.loc
  smtp_server 192.168.200.1
  smtp_connect_timeout 30
  router_id LVS_DEVEL  //负载均衡器标识,在一个网络内,它应该是唯一的
}

#VRRP实例定义块,负责负载均衡器之间的失败切换
vrrp_instance VI_1 {
    state MASTER                      //只有MASTER和BACKUP 2种状态,主为MASTER,从为BACKUP,使用大写                                        
    interface eth0                    //监控的网络接口                                              
    virtual_router_id 51              //同一实例下virtual_router_id必须相同                          
    priority 100                      //定义优先级,数字越大,优先级越高                            
    advert_int 1                      //MASTER与BACKUP负载均衡器之间同步检查的时间间隔,单位是秒      
    authentication {                  //验证类型和密码                                                
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {                //虚拟ip地址virtual_ipaddress,可以定义多个
        192.168.200.16
        192.168.200.17
        192.168.200.18
    }
}

#虚拟服务器定义块
virtual_server 192.168.200.100 443 {                              //定义虚拟服务器                                          
    delay_loop 6                                                  //delay_loop,健康检查时间间隔,单位是秒                                    
    lb_algo rr                                                    //负载调度算法,这里设置为rr,即轮询算法,互联网应用常使用wlc或rr                      
    lb_kind NAT                                                    //负载均衡转发规则。一般包括DR,NAT,TUN3种,在我的方案中,都使用DR的方式  
    nat_mask 255.255.255.0                                        //子网掩码      
    persistence_timeout 50                                        //会话保持时间,单位是秒(可以适当延长时间以保持session)                                
    protocol TCP                                                  //转发协议类型,有tcp和udp两种 
                                                                                    
    real_server 192.168.201.100 443 {                              //真实服务器IP及端口                                            
        weight 1                                                  //默认为1,0为失效                          
        SSL_GET {                                                                  
            url {                                                                  
              path /                                                                
              digest ff20ad2481f97b1754ef3e12ecd3a9cc                              
            }
            url {
              path /mrtg/
              digest 9b3a0c85a887a256d6939da88aabd8cd
            }
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
}

直接拷贝是无效的,没有全部将配置文件中的属性拷贝出来,这里的热备主要注意点是,虚拟IP就是以后给用户访问的IP,而实际IP则是本机IP,interface eth0 这里的表示网卡,如果你使用的不是eth0则需要修改,不然,热备无法生效,real_server,virtual_ipaddress

还需要注意点:

vrrp_instance VI_1 {
    state MASTER

这个属性,如果热备,将备服务器上的配置文件修改为BACKUP,不然,热备也不生效。

实际,Keepalived热备的效果就是将两台服务器指向同一个虚拟IP,而对外提供的IP就是这个虚拟IP,如果一台服务器宕机,不能提供IP访问,那么,将有备服务器指向改IP并提供IP服务

 

四、Keepalived日志查询

路径:/var/log/messages 文件

CentOS下安装keepalived 进行服务器热备的更多相关文章

  1. 阿里云服务器centos下安装配置svn服务器

      阿里云服务器centos下安装配置svn服务器 1.安装svn服务器端yum install subversion      从镜像下载安装svn服务器端中间会提示是否ok,输入y,确认安装成功提 ...

  2. CentOS下安装配置Samba服务器

    0 环境介绍 VMWARE12下安装的CENTOS7虚拟机.宿主机为WIN7. 1 离线安装 费了九牛二虎之力,下载各种依赖,还是有问题,转向在线安装. 2 在线安装 虚拟机采用默认的配置: 其次,网 ...

  3. CentOS下安装配置SVN服务器并自动同步到web目录

    一.安装 yum install subversion测试是否安装成功 /usr/bin/svnserve --version如提示以下内容,说明已安装成功 svnserve,版本 1.6.11 (r ...

  4. Mysql+Keepalived双主热备高可用操作记录

    我们通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务.当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短.MySQL双主复制,即互为Mast ...

  5. Lvs+keepalived+mysql主从热备

    p.MsoNormal,li.MsoNormal,div.MsoNormal { margin: 0cm; margin-bottom: .0001pt; text-align: justify; f ...

  6. keepalived+nginx双机热备+负载均衡

    Reference: http://blog.csdn.net/e421083458/article/details/30092795 keepalived+nginx双机热备+负载均衡 最近因业务扩 ...

  7. 使用keepalived实现双机热备

    通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务.当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短.下面来以keepalived结合tom ...

  8. CentOS下安装hadoop

    CentOS下安装hadoop 用户配置 添加用户 adduser hadoop passwd hadoop 权限配置 chmod u+w /etc/sudoers vi /etc/sudoers 在 ...

  9. CentOS下安装使用start-stop-daemon

    CentOS下安装使用start-stop-daemon 在centos下下了个自启动的服务器脚本 执行的时候发现找不到start-stop-daemon命令 好吧 执行手动编译一下 加上这个命令 w ...

随机推荐

  1. BZOJ1727 [Usaco2006 Open]The Milk Queue 挤奶队列

    贪心...我怎么不会QAQ[捂脸熊] 对于1.2两头牛,如果1号牛要排在2号牛前面才能时间更少,则 $$max(A_1 + B_1 + B_2, \ A_1 + A_2 + B_2) \le max( ...

  2. Can't connect to local MySQL server through socket 问题解决

    Fedora8启动mysql 报错:ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/lib/m ...

  3. 搭建SSH框架所需Jar包及其解释

    SSH2 ----struts2.1.8---- struts2-core-2.1.8.1.jar struts2核心包 struts2-json-plugin-2.1.8.1.jar struts2 ...

  4. 解决Putty连接不上服务器的方法

    1.vi /etc/ssh/sshd_config 将PermitRootLogin的注释取消,或者将no改为yes. 2.service sshd restart 3.setup命令进入将防火墙关闭 ...

  5. 优化MYSQL数据库的方法

    1.选取最适用的字段属性,尽可能减少定义字段长度,尽量把字段设置NOT NULL,例如'省份,性别',最好设置为ENUM2.使用连接(JOIN)来代替子查询: a.删除没有任何订单客户:DELETE ...

  6. iOS 登陆的实现四种方式

    iOS 登陆的实现四种方式 一. 网页加载: http://www.cnblogs.com/tekkaman/archive/2013/02/21/2920218.ht ml [iOS登陆的实现] A ...

  7. EntityFramework查询oracle数据库时报ora-12704: character set mismatch

    1.这段linq,执行期间报ora-12704:character set mismatch错误. var query = from m in ctx.MENU where (m.SUPER_MENU ...

  8. tomcat http 文件下载

    tomcat作为http的下载服务器,网上有很多办法 但我认为最简单的是: 1.直接把文件放在 tomcat6/webapps/ROOT 目录下, 2.然后在网址中访问: http://120.194 ...

  9. java.net.SocketException: Too many open files

    1.ps -ef|grep java 2.lsof -p 32636 3.lsof -p 20812|wc –l   这个也可以看一个进程打开的文件数 4.ulimit –a c3p0官方提供了两个参 ...

  10. Android 自动朗读(TTS)

    在Android应用中,有时候需要朗读一些文本内容,今天介绍一下Android系统自带的朗读TextToSpeech(TTS).自动朗读支持可以对指定文本内容进行朗读,还可以把文本对应的音频录制成音频 ...