首页 > Windows开发 > 详细

在Windows进下build 高可用负载均衡与反向代理神器:HAProxy

时间:2020-11-14 17:28:49      阅读:38      评论:0      收藏:0      [点我收藏+]

前言

HAProxy是一个款基于Linux的开源高可用的负载均衡与反向代理工具,与Nginx大同小异。
搜遍了全网,几乎都是基于Linux平台。Windows平台的要么就是多年前的旧版本,要么就是不兼容OpenSSL,无法进行HTTPS请求,要么就是花钱买但又觉得不一定适用。
索性花了小半天时间研究了下,成功build出基于windows的haproxy2.2.4(最新版是2.2.5,担心最新版的稳定性,所以选了前面一个小版本)。

安装cygwin

  1. 下载cygwin(https://cygwin.com/install.html)。
  2. 安装cygwin。
  3. 设置下载源的时候简易使用网易源(http://mirrors.163.com/cygwin/)。
    技术分享图片
  4. 选择Category 并且搜索gcc,点击Devel。
    技术分享图片
  5. 重复上一步骤,搜索并安装make tools,这个是OPENSSL所必需的,否则将会报错(多么痛的领悟)。

安装HAProxy

  1. 下载haproxy (https://www.haproxy.org/download/2.2/src/),这个是所有2.2大版本的目录,博主选择V2.2.4。
  2. 下载完成后,拷贝到cygwin的home目录下,并运行cygwin.bat,解压命令:tar -zxvf haproxy-2.2.4.tar.gz。
    技术分享图片
  3. 然后输入命令:make TARGET=cygwin USE_PCRE=1 USE_REGPARM=1 USE_STATIC_PCRE=1 USE_OPENSSL=1,后面几个参数很重要,都是OPENSSL加密所需。
    技术分享图片
  4. 然后输入命令:make install,之后在解压文件夹里即可找到haproxy.exe。
  5. 将haproxy.exe文件和cygwin1.dll文件拷贝到一个新文件夹(haproxy-openssl-2.2.4)。

运行haproxy

1.创建一个config文件

global
nbproc 1
daemon
ssl-default-bind-options force-tlsv12

defaults
timeout connect 90000ms
timeout client 90000ms
timeout server 90000ms

frontend HaProxy
bind *:80
redirect scheme https if !{ ssl_fc }
bind *:443
mode http
default_backend AlphaServer

backend OmniServer
mode http
balance roundrobin
server AlphaServer localhost:10086

listen admin_status
bind *:1188
mode http
stats refresh 30s
stats uri /
stats auth haproxy:haproxy
stats admin if TRUE

关于配置文件的含义,就不具体解释了,朋友们可以网上查一查。

2.创建start/stop的bat文件

这个应该很简单,也不一一赘述了。

3.测试

  1. 当启动haproxy的时,可以通过config文件的listen的端口,查看haproxy的traffic stats。
  2. 本地新建一个网站,这个网站的端口不能和haproxy fontend 的端口冲突,否则haproxy将启动失败,之后浏览器访问fontend端口将全部跳转到backend端口。
  3. 当有多个backend时,会根据配置的算法将请求分发出去,以达到load balance。

测试的时候忘了截图,有点干,朋友将就将就。

在Windows进下build 高可用负载均衡与反向代理神器:HAProxy

原文:https://www.cnblogs.com/shy-huang/p/13973382.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!