阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

HaProxy+Varnish+LAMP集群实现动静分离

481次阅读
没有评论

共计 10826 个字符,预计需要花费 28 分钟才能阅读完成。

一、简介

Haproxy 一个高性能的负载均衡服务软件,它可基于四层和七层之间进行调度,而且对各个节点具有健康状态检测的功能,当后端服务器故障时,会自动标记为不可用状态,当服务器上线时还会自动将后端主机上线。比起 lvs 其配置简单,且引入了 frontend,backend,listen 等功能,frontend 可添加 acl 规则,可根据 HTTP 请求头做规则匹配,然后把请求定向到相关的 backend。

二、配置相关参数详解

haproxy 主要分为 global、defaults、front、backend、listen 几段,配置文件详细说明如下:
#———————————————————————
# Global settings #全局配置段
#———————————————————————
global #全局配置段
    # to have these messages end up in /var/log/haproxy.log you will
    # need to:
    #
    # 1) configure syslog to accept network log events.  This is done
    #    by adding the ‘-r’ option to the SYSLOGD_OPTIONS in
    #    /etc/sysconfig/syslog
    #
    # 2) configure local2 events to go to the /var/log/haproxy.log
    #  file. A line like the following can be added to
    #  /etc/sysconfig/syslog
    #
    #    local2.*  /var/log/haproxy.log #如需保存日志文件需修改 /etc/rsyslog.cfg 添加此项至配置问文件中重启 rsyslog
    #
    log        127.0.0.1 local2      #日志将通过 rsyslog 进行记录
    chroot      /var/lib/haproxy      #运行的安装路径
    pidfile    /var/run/haproxy.pid      #运行时的 pid 进程文件
    maxconn    4000            #最大连接数
    user        haproxy        #运行以 haproxy 用户
    group      haproxy          #运行以 haproxy 用户
    daemon                    #以守护进程的方式运行 haproxy   
    # turn on stats unix socket
    stats socket /var/lib/haproxy/stats
#———————————————————————
# common defaults that all the ‘listen’ and ‘backend’ sections will
# use if not designated in their block
#———————————————————————
defaults
    mode                    http    #工作模式
    log                    global  #记录日志级别为全局
    option                  httplog  #详细的 http 日志
    option                  dontlognull
    option http-server-close   
    option forwardfor      except 127.0.0.0/8  #传递客服端 IP 
    option                  redispatch
    retries                3      #失败后重试次数 
    timeout http-request    10s            #http 请求超时时长   
    timeout queue          1m
    timeout connect        10s   
    timeout client          1m
    timeout server          1m
    timeout http-keep-alive 10s
    timeout check          10s                #心跳信息检测超时时长     
    maxconn                3000
#———————————————————————
# main frontend which proxys to the backends
#———————————————————————
listen stats
    mode http
    bind *:1080
    stats enable
    stats hide-version
    stats uri    /admin
    stats realm  Haproxy\ Statistics
    stats auth    admin:admin
    stats admin if TRUE
frontend  main 
    bind *:80
    #定义 acl 规则
    acl url_static      path_beg      -i /static /images /javascript /stylesheets #请求报文中以此类开头的都定义为 uri_static
    acl url_static      path_end      -i .jpg .gif .png .css .js .html .ico  #不区分大小写一此类.* 结尾的都定义为 url_static
    acl  url_dynamic            path_end              -i .php .jsp .asp #不区分大小写以此类开头的定义为动态资源组
    use_backend static      if url_static        #调用后端服务器并检测规则
    use_backend  bynamic        if url_dynamic        #调用后端服务器并检查规则
    default_backend          static                #使用默认规则
#———————————————————————
# static backend for serving up images, stylesheets and such
#———————————————————————
backend static #后端调度
    balance      roundrobin  #调度算法,除此外还有 static-rr,leaseconn,first,source,uri 等
    server  static 192.168.10.125:80 inter 1500 rise 2 fall 3  check 
    rspadd X-Via:static #启用响应报文首部标志,以便观察是静态服务器反馈的
#———————————————————————
# round robin balancing between the various backends
#———————————————————————
backend dynamic
    balance    source
    server      s2 172.16.10.12:80 check inter 1500 rise 2 fall 3 
#check inter 1500 是检测心跳频率
#rise2 2 次正确认为服务器可用
#fall3 3 次失败认为服务器不可用
#———————————————————————
# round robin balancing listen option
#———————————————————————
listen statistics
    mode http                #http 7 层模式
    bind *:9988              #监听地址
    stats enable              #启用状态监控
    stats auth admin:admin        #验证的用户与密码
    stats uri /admin?stats        #访问路径
    stats hide-version            #隐藏状态页面版本号
    stats admin if TRUE          #如果验证通过了就允许登录
    stats refresh 3s            #每 3 秒刷新一次
    acl allow src 192.168.18.0/24    #允许的访问的 IP 地址
    tcp-request content accept if allow  #允许的地址段就允许访问
    tcp-request content reject      #拒绝非法连接

    三、haproxy+varnish 实现动静分离小案例
    实验架构拓扑图:

HaProxy+Varnish+LAMP 集群实现动静分离

    架构说明:用户请求到达前端,通过 haproxy 调度到 varnish 缓存服务器上,当缓存服务器上的资源命中且未过期时直接叫资源响应改用户,当未命中时通过在两台 varnish 服务器上设置匹配规则将其转发至后端响应的动态和静态服务器上,后端动态或静态服务器均使用 nfs 网络文件共享使用同一个资源目录,同时将使用同一台厚分离出来的 mysql 服务器作为存储数据使用,考虑单点故障的瓶颈,mysql 服务器将使用主从两台实现高可用主负责读写均可,但从服务器为只读,同理路由需要也可在前端 haproxy 代理提供冗余。

实验环境如下:

前端:HAProxy
        1、调度服务器:Varnish1、Varnish2
        2、调度算法一致性 URL 哈希:URL_Hash_Consistent
      3、集群统计页:ipaddr/haproxy?admin
缓存服务器:Varnish
    1、VarnishServer01
    2、VarnishServer02
    3、开启健康状态探测,提供高可用
    4、负载均衡后端 Web 服务器组
    5、动静分离后端服务器,并动静都提供负载均衡效果
后端服务器:
    StaticServer01
    StaticServer02
    DynamicServer01
    DynamicServer02
Mysql 服务器:
    MysqlServer-master
    MysqlServer-slave

haproxy 配置如下:

#———————————————————————
# Global settings
#———————————————————————
global
    # to have these messages end up in /var/log/haproxy.log you will
    # need to:
    #
    # 1) configure syslog to accept network log events.  This is done
    #    by adding the ‘-r’ option to the SYSLOGD_OPTIONS in
    #    /etc/sysconfig/syslog
    #
    # 2) configure local2 events to go to the /var/log/haproxy.log
    #  file. A line like the following can be added to
    #  /etc/sysconfig/syslog
    #
    #    local2.*                      /var/log/haproxy.log
    #
    log        127.0.0.1 local2
    chroot      /var/lib/haproxy
    pidfile    /var/run/haproxy.pid
    maxconn    4000
    user        haproxy
    group      haproxy
    daemon
    # turn on stats unix socket
    stats socket /var/lib/haproxy/stats
#———————————————————————
# common defaults that all the ‘listen’ and ‘backend’ sections will
# use if not designated in their block
#———————————————————————
defaults
    mode                    http
    log                    global
    option                  httplog
    option                  dontlognull
    option http-server-close
    option forwardfor      except 127.0.0.0/8
    option                  redispatch
    retries                3
    timeout http-request    10s
    timeout queue          1m
    timeout connect        10s
    timeout client          1m
    timeout server          1m
    timeout http-keep-alive 10s
    timeout check          10s
    maxconn                3000
#———————————————————————
# main frontend which proxys to the backends
#———————————————————————
frontend web *:80
#acl url_static path_beg-i /static /images /javascript /sytlesheets
#acl url_static path_end -i .jpg .gif .png .css .js
#use_backend staticif url_static
use_backendvarnish_srv
#———————————————————————
# vanrnish server balance method
#———————————————————————
backend    varnish_srv #定义 varnish 后端主机组
balance    uri    #一致性 hash   
hash-type  consistent  #一致性 hash url   
servervarnish1 10.1.10.6:9988 check  #varnish 服务器 1,并添加健康状态检测
servervarnish2 10.1.10.7:9988 check  #varnish 服务器 02,并添加健康状态检测
listen stats      #定义状态监控管理页
bind:9002
stats uri /alren?admin #页面 URL
stats hide-version    #影藏版文本信息
stats  authadmin:alren #提供认证页面
stats  admin if TRUE #认证通过则条状到相应页面

varnish 配置如下:
# This is an example VCL file for Varnish.
#
# It does not do anything by default, delegating control to the
# builtin VCL. The builtin VCL is called when there is no explicit
# return statement.
#
# See the VCL chapters in the Users Guide at https://www.varnish-cache.org/docs/
# and http://varnish-cache.org/trac/wiki/VCLExamples for more examples.
# Marker to tell the VCL compiler that this VCL has been adapted to the
# new 4.0 format.
vcl 4.0; #版本信息
import directors; #导入模块
acl purges {#定义修剪规则
    “127.0.0.1”; 
    “10.1.10.0”;
}
backend web1 {
    .host = “10.1.10.68:80”;
    .port = “80”;
        .url =”/heath.php”;
        .timeout = 2s;
        .interval = 1s;
        .window = 6; 
        .threshold = 3; 
        .expected_response = 200;
        .initial = 2;
}
backend web2 {
    .host = “10.1.10.69:80”;
    .port = “80”;
        .url =”/heath.php”;
        .timeout = 2s;
        .interval = 1s;
        .window = 6; 
        .threshold = 3; 
        .expected_response = 200;
        .initial = 2;
}
backend app1 {
    .host = “10.1.10.70:80”;
    .port = “80”;
        .url =”/heath.html”;
        .timeout = 2s;
        .interval = 1s;
        .window = 6; 
        .threshold = 3; 
        .expected_response = 200;
        .initial = 2;
}
backend app2 {
    .host = “10.1.10.71:80”;
    .port = “80”;
        .url =”/heath.html”;
        .timeout = 2s;
        .interval = 1s;
        .window = 6; 
        .threshold = 3; 
        .expected_response = 200;
        .initial = 2;
}
sub vcl_init {
    new webcluster = directors.round_robin();
    webcluster.add_backend(web1);
    webcluster.add_backend(web2);
   
    new appcluster = directors.round_robin();
    appcluster.add_backend(app1);
    appcluster.add_backend(app2);
}
sub vcl_recv {
    if (req.method == “PURGE”){
      if(!client.ip ~ purges){
        return(synth(408,”you don’t have permission purge ” + client.ip));
      }
return (purge);
    }
    if (req.url ~ “(?i)\.(php|asp|aspx|jsp)($|\?)”) {
set req.backend_hint = appcluster.backend();
    }
  if (req.method != “GET” &&
      req.method != “HEAD” &&
      req.method != “PUT” &&
      req.method != “POST” &&
      req.method != “TRACE” &&
      req.method != “OPTIONS” &&
      req.method != “PATCH” &&
      req.method != “DELETE”) {
      return (pipe);
  } 
  if (req.method != “GET” && req.method != “HEAD”) {
        return (pass);
    }
  if (req.http.Authorization || req.http.Cookie) {
        return (pass);
    }
  if (req.http.Accept-Encoding) {
        if (req.url ~ “\.(bmp|png|gif|jpg|jpeg|ico|gz|tgz|bz2|tbz|zip|rar|mp3|mp4|ogg|swf|flv)$”) {
            unset req.http.Accept-Encoding;
        } elseif (req.http.Accept-Encoding ~ “gzip”) {
            set req.http.Accept-Encoding = “gzip”;
        } elseif (req.http.Accept-Encoding ~ “deflate”) {
            set req.http.Accept-Encoding = “deflate”;
        } else {
            unset req.http.Accept-Encoding;
        }
    }
        return (hash);
}
sub vcl_pipe {
return (pipe);
}
sub vcl_miss {
return(fetch);
}
sub vcl_hash {
    hash_data(req.url);
    if (req.http.host) {
        hash_data(req.http.host);
    } else {
        hash_data(server.ip);
    }
    if (req.http.Accept-Encoding ~ “gzip”) {
        hash_data (“gzip”);
    } elseif (req.http.Accept-Encoding ~ “deflate”) {
        hash_data (“deflate”);
    }
}
sub vcl_backend_response {
    if (beresp.http.cache-control !~ “s-maxage”) {
      if (bereq.url ~ “(?i)\.(jpg|jpeg|png|gif|css|js|html|htm)$”) {
          unset beresp.http.Set-Cookie;
          set beresp.ttl = 3600s;
      }
    }
}
sub vcl_purge {
return(synth(200,”Purged”));
}
sub vcl_deliver {
    if (obj.hits > 0) {
        set resp.http.X-Cache = “HIT via ” + req.http.host;
        set resp.http.X-Cache-Hits = obj.hits;
    } else {
        set resp.http.X-Cache = “MISS via ” + req.http.host;
    }
}

上述完成后,配置 web 服务,使用 nfs 网络文件系统并且提供实时数据同步(rsync+inotify),启动 mysql 进行授权用户和创建数据库,搭建 WordPress 或其他应用程序,此过程简单就不啰嗦,此架构存在一定的不足之处,即单点故障会导致用户请求失败。
实现效果如下所示:

HaProxy+Varnish+LAMP 集群实现动静分离

将 nfs 服务端停止后实验图:

HaProxy+Varnish+LAMP 集群实现动静分离

缓存服务器 Varnish 概念篇 http://www.linuxidc.com/Linux/2014-05/101389.htm

缓存服务器 Varnish 概念篇 http://www.linuxidc.com/Linux/2014-05/101389.htm

Varnish Cache 的架构笔记 http://www.linuxidc.com/Linux/2013-10/91016.htm

CentOS 5.8 下 Varnish-2.1.5 的安装配置 http://www.linuxidc.com/Linux/2013-09/89916.htm

RedHat 脚本改用 CentOS 源更新安装 Nginx、PHP 5.3、Varnish http://www.linuxidc.com/Linux/2012-07/65801.htm

利用 Varnish 构建 Cache 服务器笔记 http://www.linuxidc.com/Linux/2012-07/65234.htm

缓存服务 Varnish 安装配置 http://www.linuxidc.com/Linux/2012-07/65228.htm

Varnish 编译安装所需准备 http://www.linuxidc.com/Linux/2012-07/65230.htm

Linux 下 Varnish 缓存的配置优化 http://www.linuxidc.com/Linux/2012-03/56435.htm

Linux 中 Varnish 基础应用  http://www.linuxidc.com/Linux/2016-08/134025.htm

Varnish 的详细介绍:请点这里
Varnish 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-11/137148.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计10826字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
7981675
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
支付宝、淘宝、闲鱼又双叕崩了,Cloudflare也瘫了连监控都挂,根因藏在哪?

支付宝、淘宝、闲鱼又双叕崩了,Cloudflare也瘫了连监控都挂,根因藏在哪?

支付宝、淘宝、闲鱼又双叕崩了,Cloudflare 也瘫了连监控都挂,根因藏在哪? 最近两天的互联网堪称“故障...
在Windows系统中通过VMware安装苹果macOS15

在Windows系统中通过VMware安装苹果macOS15

在 Windows 系统中通过 VMware 安装苹果 macOS15 许多开发者和爱好者希望在 Window...
升级自动部署更新SSL证书系统、申请godaddy的APIKEY

升级自动部署更新SSL证书系统、申请godaddy的APIKEY

升级自动部署更新 SSL 证书系统、申请 godaddy 的 APIKEY 公司之前花钱购买的 ssl 证书快...
免费领取huggingface的2核16G云服务器,超简单教程

免费领取huggingface的2核16G云服务器,超简单教程

免费领取 huggingface 的 2 核 16G 云服务器,超简单教程 前言 HuggingFace.co...
终于收到了以女儿为原型打印的3D玩偶了

终于收到了以女儿为原型打印的3D玩偶了

终于收到了以女儿为原型打印的 3D 玩偶了 前些日子参加某网站活动,获得一次实物 3D 打印的机会,于是从众多...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
300元就能买到的”小钢炮”?惠普7L四盘位小主机解析

300元就能买到的”小钢炮”?惠普7L四盘位小主机解析

  300 元就能买到的 ” 小钢炮 ”?惠普 7L 四盘位小主机解析 最近...
Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集 在云原生体系中,Prometheus 已成为最主流的监控与报警...
星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛 NAS-12:开源笔记的进化之路,效率玩家的新选择 前言 如何高效管理知识与笔记,已经成为技术...
颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

  颠覆 AI 开发效率!开源工具一站式管控 30+ 大模型 ApiKey,秘钥付费 + 负载均衡全...
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...