一 基础准备

1.1 部署环境及说明

系统OS:CentOS 6.8 64位
HAProxy软件:HA-Proxy version 1.5.18
Keepalived软件:keepalived-1.3.6.tar.gz
官方链接:http://www.haproxy.org/ (国内可能无法打开)
下载连接:http://pkgs.fedoraproject.org/repo/pkgs/haproxy/
部署说明:当用户访问对应的域名时,HAProxy能将请求发送到对应的后端主机上,同时当主HAProxy服务器发生故障后,能立刻将负载均衡服务切换到备用HAProxy服务器上。
主机名
主机IP地址
集群角色
虚机IP/域名
master
172.24.8.10
主HAProxy服务器
172.24.8.100
backup
172.24.8.11
备HAProxy服务器
webapp1
172.24.8.30
后端web服务器
www.lz.com
webapp2
172.24.8.31
static.lz.com
webapp3
172.24.8.32
video.lz.com

1.2 架构规划

二 后端httpd集群部署

2.1 部署httpd集群

 [root@webapp1 ~]# yum -y install httpd
[root@webapp1 ~]# vi /var/www/html/index.html
This is my www.lz.com!
[root@webapp1 ~]# vi /var/www/html/index.html
This is my static.lz.com!
[root@webapp1 ~]# vi /var/www/html/index.html
This is my video.lz.com!
[root@webapp1 ~]# systemctl start httpd.service
[root@webapp1 ~]# systemctl enable httpd.service
[root@webapp1 ~]# systemctl stop firewalld.service
[root@webapp1 ~]# systemctl disable firewalld.service
[root@webapp1 ~]# vi /etc/selinux/config
SELINUX=disabled
[root@webapp1 ~]# setenforce 0 #关闭SELinux及防火墙
 
注意:后端real server节点都需要安装,本环境针对httpd简单安装即可,无需过多配置。

三 基础NTP部署

3.1 NTP部署

 [root@webapp1 ~]# yum -y install ntp
[root@webapp1 ~]# systemctl start ntpd.service
 
建议:替换附件中的ntp配置文件,建议采用阿里云时钟进行同步。
注意:为了保证集群的稳定性,强烈建议在所有节点均部署NTP同步服务,保证所有时钟一致。

四 Keepalived部署

4.1 编译环境

安装基础环境及依赖:
 # yum -y install gcc gcc-c++ make kernel-devel kernel-tools kernel-tools-libs kernel libnl libnl-devel libnfnetlink-devel openssl-devel wget openssh-clients

4.2 安装Keepalived

 [root@haproxy_master ~]# wget http://www.keepalived.org/software/keepalived-1.3.6.tar.gz
[root@haproxy_master ~]# tar -zxvf keepalived-1.3.6.tar.gz
[root@haproxy_master ~]# cd keepalived-1.3.6/
[root@lvsmaster keepalived-1.3.6]# ./configure --prefix=/usr/local/keepalived
[root@haproxy_master keepalived-1.3.6]# make && make install
 
注意:CentOS6.8安装高于1.3.6版本会出现未知错误。

4.3 添加Keepalived启动相关服务

 [root@haproxy_master ~]# mkdir /etc/keepalived
[root@haproxy_master ~]# cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
[root@haproxy_master ~]# cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
[root@haproxy_master ~]# cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
[root@haproxy_master ~]# vi /etc/init.d/keepalived #创建Keepalived启动脚本,见附件
[root@haproxy_master ~]# chmod u+x /etc/rc.d/init.d/keepalived
 

4.4 配置Keepalived

 [root@haproxy_master ~]# vi /etc/keepalived/keepalived.conf
global_defs {
notification_email {
#……
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 192.168.200.1
smtp_connect_timeout 30
router_id LVS_DEVEL
} vrrp_script check_haproxy {
script "/usr/bin/killall -0 haproxy"
interval 2
weight 21
} vrrp_instance HAProxy_HA {
state BACKUP #在HAProxy主备均设置为BACKUP
interface eth0
virtual_router_id 80
priority 100
advert_int 2
nopreempt #不抢占模式
authentication {
auth_type PASS
auth_pass 1111
} notify_master "/etc/keepalived/master.sh"
notify_backup "/etc/keepalived/backup.sh"
notify_fault "/etc/keepalived/fault.sh" track_script {
check_haproxy
} virtual_ipaddress {
172.24.8.100 dev eth0
}
}
 

4.5 编写Keepalived脚本

 [root@haproxy_master ~]# vi /etc/keepalived/master.sh
#!/bin/bash
LOGFILE=/var/log/keepalived-mysql-state/log
date >>$LOGFILE
echo "[Master]" >>$LOGFILE
[root@haproxy_master ~]# vi /etc/keepalived/backup.sh
#!/bin/bash
LOGFILE=/var/log/keepalived-mysql-state/log
date >>$LOGFILE
echo "[BACKUP]" >>$LOGFILE
[root@haproxy_master ~]# vi /etc/keepalived/fault.sh
#!/bin/bash
LOGFILE=/var/log/keepalived-mysql-state/log
date >>$LOGFILE
echo "[FAULT]" >>$LOGFILE
[root@haproxy_master ~]# chmod u+x /etc/keepalived/backup.sh
[root@haproxy_master ~]# chmod u+x /etc/keepalived/master.sh
[root@haproxy_master ~]# chmod u+x /etc/keepalived/fault.sh
 
提示:本环境采用测试脚本,真实环境建议采用自动发送邮件通知运维员的脚本。

4.5 Bakcup节点配置

 [root@haproxy_master ~]# scp /etc/keepalived/keepalived.conf 172.24.8.11:/etc/keepalived/keepalived.conf    #将配置好的Master节点的配置文件复制到Backup节点
[root@haproxy_slave ~]# vi /etc/keepalived/keepalived.conf
state BACKUP
priority 80
 
注意:在HAProxy备节点也设置为BACKUP,priority修改为低于HAProxy主角色的优先级即可,同时去掉nopreempt。
 [root@haproxy_master ~]# scp /etc/keepalived/*.sh 172.24.8.11:/etc/keepalived/
#将对应的脚本也复制至backup节点。
 

五 HAProxy部署

5.1 HAProxy安装

 [root@haproxy_master ~]# yum -y install haproxy
提示:需要在主备HAProxy节点都安装。

5.2 HAProxy配置

 [root@haproxy_master ~]# vi /etc/haproxy/haproxy.cfg
global
log 127.0.0.1 local0 info
chroot /var/lib/haproxy
pidfile /var/run/haproxy.pid
maxconn 4096
user haproxy
group haproxy
daemon
nbproc 1
defaults
mode http
log global
retries 3
timeout connect 5s
timeout client 30s
timeout server 30s
timeout check 2s
frontend www
bind 172.24.8.100:80
mode http
option httplog
option forwardfor
log global acl host_www hdr_dom(host) -i www.lz.com #配置不同域名分发不同后端策略
acl host_static hdr_dom(host) -i static.lz.com
acl host_video hdr_dom(host) -i video.lz.com use_backend server_www if host_www #配置不同域名分发不同后端策略
use_backend server_static if host_static
use_backend server_video if host_video
backend server_www #后端真是服务器
mode http
option redispatch
option abortonclose
balance roundrobin
option httpchk GET /index.html
server webapp1 172.24.8.30:80 weight 6 check inter 2000 rise 2 fall 3
backend server_static #后端真是服务器
mode http
option redispatch
option abortonclose
balance roundrobin
option httpchk GET /index.html
server webapp2 172.24.8.31:80 weight 6 check inter 2000 rise 2 fall 3
backend server_video #后端真是服务器
mode http
option redispatch
option abortonclose
balance roundrobin
option httpchk GET /index.html
server webapp3 172.24.8.32:80 weight 6 check inter 2000 rise 2 fall 3
[root@haproxy_master ~]# scp /etc/haproxy/haproxy.cfg root@172.24.8.11:/etc/haproxy/haproxy.cfg #将配置文件复制至HAProxy备节点
 

5.3 打开转发

 [root@haproxy_master ~]# vi /etc/sysctl.conf
net.ipv4.ip_nonlocal_bind = 1
[root@haproxy_master ~]# sysctl -p
 
注意:绑定非本机的IP必须在sysctl.conf文件中配置。

六 启动服务

 [root@webapp1 ~]# systemctl start httpd
提示:三个节点的httpd服务均启动。
 [root@haproxy_master ~]# service haproxy start
提示:必须先启动HAProxy服务,之后启动Keepalived,因为Keepalived会先检测HAProxy服务进程。
 [root@haproxy_master ~]# service keepalived start

七 验证测试

7.1 高可用验证

 [root@haproxy_master ~]# ip add
 [root@haproxy_master ~]# service haproxy stop		#停止HAProxy主节点的HAProxy进程
[root@haproxy_master ~]# tail -f /var/log/messages #观察HAProxy主节点日志
 
 [root@haproxy_slave ~]# ip addr				#查看备HAProxy节点的IP
结论:通过测试可知当主HAProxy节点服务异常,Keepalived会检测到,同时HAProxy会将vip从主节点移除,备HAProxy会接管。
 [root@haproxy_master ~]# service haproxy start
结论:由于配置了非抢占模式,主HAProxy恢复进程之后,依旧由备HAProxy提供服务,vip不会切回至主HAProxy。

7.2 负载均衡测试

主机hosts中添加如下解析:
 172.24.8.100	www.lz.com
172.24.8.100 static.lz.com
172.24.8.100 video.lz.com
 
浏览器分别访问不用的三个域名:
 
 
 
 

005.HAProxy+Keepalived高可用负载均衡的更多相关文章

  1. 案例一(haproxy+keepalived高可用负载均衡系统)【转】

    1.搭建环境描述: 操作系统: [root@HA-1 ~]# cat /etc/redhat-release CentOS release 6.7 (Final) 地址规划: 主机名 IP地址 集群角 ...

  2. HAProxy+Keepalived 高可用负载均衡

    转自 https://www.jianshu.com/p/95cc6e875456 Keepalived+haproxy实现高可用负载均衡 Master backup vip(虚拟IP) 192.16 ...

  3. 基于HAProxy+Keepalived高可用负载均衡web服务的搭建

    一 原理简介 1.HAProxyHAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAProxy特别适用于那些负载特大的web ...

  4. HAProxy+Keepalived高可用负载均衡

    一 基础准备 1.1 部署环境及说明 系统OS:CentOS 6.8 64位 HAProxy软件:HA-Proxy version 1.5.18 Keepalived软件:keepalived-1.3 ...

  5. Haproxy+Keepalived高可用负载均衡详细配置

    本文所使用的环境: 10.6.2.128    centos6.5 10.6.2.129    centos6.5 VIP  为10.6.2.150 要实现的目标: 实现10.6.2.128和10.6 ...

  6. 测试LVS+Keepalived高可用负载均衡集群

    测试LVS+Keepalived高可用负载均衡集群 1. 启动LVS高可用集群服务 此时查看Keepalived服务的系统日志信息如下: [root@localhost ~]# tail -f /va ...

  7. LVS+Keepalived高可用负载均衡集群架构实验-01

    一.为什么要使用负载均衡技术? 1.系统高可用性 2.  系统可扩展性 3.  负载均衡能力 LVS+keepalived能很好的实现以上的要求,LVS提供负载均衡,keepalived提供健康检查, ...

  8. 使用Ansible实现nginx+keepalived高可用负载均衡自动化部署

    本篇文章记录通过Ansible自动化部署nginx的负载均衡高可用,前端代理使用nginx+keepalived,端web server使用3台nginx用于负载效果的体现,结构图如下: 部署前准备工 ...

  9. Keepalived+HAProxy 搭建高可用负载均衡

    转载自:https://mp.weixin.qq.com/s/VebiWftaRa26x1aA21Jqww 1. 概述 软件负载均衡技术是指可以为多个后端服务器节点提供前端IP流量分发调度服务的软件技 ...

随机推荐

  1. 允许远程用户登录访问mysql的方法

    需要手动增加可以远程访问数据库的用户. 方法一.本地登入mysql,更改 "mysql" 数据库里的 "user" 表里的 "host" 项 ...

  2. UML和模式应用5:细化阶段(6)---操作契约

    1.前言 操作契约使用前置和后置条件,描述领域模型里对象的详细变化,作为系统操作的结果. 操作契约可以作为有用的OOA相关的制品. 操作契约可以视为UP用例模型的一部分,它是对用例之处的系统操作的效用 ...

  3. WIN10 ISO 官方

    WIN10   ISO  官方: https://www.microsoft.com/zh-cn/software-download/windows10ISO/

  4. 巧用CASE WHEN 验证用户登录信息

    最近逛博客园的时候偶然看到一个很巧妙的SQL,巧妙利用CASE WHEN 实现一个简单的 SQL 同时验证用户帐号是否存在.密码是否正确.晓菜鸟之前的做法都是根据用户名和密码一起验证,如果验证失败直接 ...

  5. MPI 在Windows10 上安装,使用VS2013编译生成可执行程序

    原文地址:http://www.cnblogs.com/leijin0211/p/6851789.html 参考博客: http://www.cnblogs.com/shixiangwan/p/662 ...

  6. C:详解C中volatile关键字

    原文地址:http://www.cnblogs.com/yc_sunniwell/archive/2010/06/24/1764231.html volatile提醒编译器它后面所定义的变量随时都有可 ...

  7. 开发使用tomcat生产使用weblogic造成jar包冲突如何解决?

    问题描述开发时新增了jar包,当将增量包部署到测试服务器后启动应用出现如下错误提示:java.lang.LinkageError: loader constraint violation: loade ...

  8. PYTHON-模块time&datetime+ 目录规范

    1.目录规范 ***** (1)文件夹的规范写法 bin 可执行文件 conf 配置文件 core 主要业务逻辑 db 数据文件 lib 库 (公共代码 第三方模块) log 日志文件 readme ...

  9. layui上传文件配合进度条

    首先看一下效果图: 修改layui的源文件upload.js 1.打开layui/modules/upload.js 2.搜索ajax 3.找到url: 4.添加以下代码: ,xhr:l.xhr(fu ...

  10. 并发之volatile关键字

    volatile关键字 volatile关键字是什么 在上一章我们讲到了并发的的三个概念,那么今天在讲解下在java中可以保证可见性和有序性的一个关键字. volatile关键字 :当变量的值被该关键 ...