系统访问量上去遇到了性能瓶颈,解决方法一般都是从两个方向入手Scale Up 和Scale Out。Scale Up适用于哪些钱多的系统,因为Scale Up其实就是直接升级硬件,CPU、内存、IO哪个不够了就升级哪个,随着计算能力的升级系统的容量自然就上来了。但是为什么Scale Up只适用于有钱人,很简单因为硬件是越高级越贵啊,而且不只是线性的增长,因为有时候2倍的IO性能可能需要花费你10倍的钱呢,而且Scale Up还不利于利旧这一(“穷人”)原则,淘汰下来的硬件环境难道都拿来做开发测试环境?。在云时代就先不详细讨论Scale Up的方法了,我们考虑一下Scale Out,Scale Out方案是入门门槛低,旧的环境都可以充分利用,因为Scale out就是横向扩展,系统压力上来了,你只需要拼机器(不是拼爹)。

基于Http的Scale Out的方案有挺多的,性能和口碑都不错的Nginx,Windows上面 IIS微软直接支持的Application Request Router都挺好,在BingoCC上面还可以直接的下单订购http的弹性支持负载均衡。不过客户的需求是无限的,这两天客户就希望我们能够同时支持http和TCP的负载均衡,因为客户有个消息推送服务是基于TCP协议开发的,如果要改造成http的比较麻烦。之前都是采用nginx的,不过nginx对TCP的支持模块不是包含在原生的发布包里面的,所以暂时没考虑。另外找到了haproxy,准备测试验证一下需求是否满足。

1.验证环境的考虑

带WEB网站+TCP的端口开放魔兽私服是一个不错的验证环境,因为私服需要有账号注册的网站,也有游戏客户端登陆游戏的TCP链接。

WEB网站:开放8888端口的PHP注册网站

验证服务:3724端口

游戏服务:8085端口

2.搭建环境:

购买两台Windows 的服务器

最后订单下来后是购买了两台服务器的参数


状态:运行中   存储:(无)

按需: 1.00元/小时

私有IP:172.167.1.238

公网IP:(无) 绑定


状态:运行中   存储:(无)

按需: 1.00元/小时

私有IP:172.167.1.239

公网IP:(无) 绑定

2.1 配置Wow测试服务器

我用来测试的Wow服务器是从网上下载回来的TrinityCore环境,可以一键把MySQL,和WEB还有游戏的世界服务器都搭建起来,下面的配置只是针对测试环境的要求对配置进行了一些更改。

一键安装完之后系统就会自动启动了Apache的Php环境,通过IE访问http://localhost:8888 的话就可以看到游戏账号的注册页面了。

2.2配置MySQL

为了测试多台服务器公用一套用户数据,需要将MySQL的账号允许多台机器访问,所以要执行一下下面的命令:

GRANT ALL PRIVILEGES ON *.* TO 'trinity'@'%' IDENTIFIED BY 'trinity' WITH GRANT OPTION;
FLUSH RIVILEGES;

2.3修改Wow的AuthServer和World Server配置

AuthServer.conf里面的配置
LoginDatabaseInfo = "127.0.0.1;3306;trinity;trinity;logon"

修改为:

LoginDatabaseInfo = "172.167.1.239;3306;trinity;trinity;logon"

worldserver.conf的配置修改为

LoginDatabaseInfo     = "172.167.1.239;3306;trinity;trinity;logon"
WorldDatabaseInfo     = "172.167.1.239;3306;trinity;trinity;world"
CharacterDatabaseInfo = "172.167.1.239;3306;trinity;trinity;chars"

2.4一台linux服务器连公网IP

因为我们是通过这台linux里面的haproxy反向代理背后的两台Windows服务器的,所以只需要一个公网IP就好了。

linux服务器的配置信息:


状态:运行中   存储:(无)

包天: 10.00元/天

私有IP:172.167.1.237

公网IP:电信独享2M 113.108.230.97

2.5haproxy的配置

用putty链接到Cent OS的服务器:

cd /tmp

wget http://haproxy.1wt.eu/download/1.4/src/haproxy-1.4.22.tar.gz

tar zxvf haproxy-1.4.22.tar.gz

cd haproxy-1.4.22.tar.gz

make install

cd examples

mkdir /etc/haproxy

cp haproxy.cfg /etc/haproxy/

cd /ect/haproxy

vim haproxy.cfg

然后根据需要把配置分别改为下面这些部分

http的配置

listen  appli1-rewrite 0.0.0.0:80
        option httplog
        cookie  SERVERID rewrite
        balance roundrobin
        server  app1_1 172.167.1.238:8888 cookie app1inst1 check inter 2000 rise 2 fall 5

server  app1_1 172.167.1.239:8888 cookie app1inst1 check inter 2000 rise 2 fall 5

TCP的配置方法,TCP因为涉及到验证端口和游戏端口所以有两部分配置

验证端口配置

listen wowauth 0.0.0.0:3724
        mode tcp
        option tcplog
        tcp-request inspect-delay 5s
        server appwow 172.167.1.238:3724

server appwow2 172.167.1.239:3724

游戏端口配置

listen  Wow 0.0.0.0:8085
        mode tcp
        option tcplog
        tcp-request inspect-delay 5s
        option tcpka
        server appwow 172.167.1.238:8085

server appwow2 172.167.1.239:8085

2.6启动haproxy

haproxy –f haproxy.cfg –p hap.pid

注意:-p参数,因为只有这样你下次更新配置是才能通过haproxy –f haproxy.cfg –p hap.pid –sf $(cathap.pid)命令行实现,否者你要手动Kill

3.验证

验证WEB

访问http://113.108.230.97 这个地址我们可以看到了游戏账号的注册界面,在windows服务器上配置的是8888端口,通过haproxy后我们通过80端口就可以访问了,反向代理成功

验证游戏服务器

启动Wow.exe,输入刚才注册的账号密码,登陆成功。

让另外一个同事也登陆该服务器,结果也登陆成功了,不过可惜的是因为TrinityCore是不支持Scale Out的,haproxy把我的同事的游戏账号分配到另外一个WoW世界服务器去了,虽然他能够加我的账号为好友,但是我们同时在世界里喊话是无法收到的。可见haproxy是可以帮你把TCP请求均衡到了不同的服务器上的。

4.测试结果

haproxy能够轻松通过配置完成WEB和TCP的反向代理完成负载均衡的任务。可惜的是Wow服务器不支持服务器间的数据同步(可能由于游戏本身的对数据的实时性要求比较高吧),否则我们可以通过云主机的横向扩展创建个万人在线服务器玩玩了。

5.技巧

由于你没有为后端的两台Windows服务器购买外网IP,所以没法通过RDP链接到这服务器上,你是没法安装Wow服务器的你可以

  1. 购买个按需的IP绑定到服务器上面,用完之后释放,这样的话你能够在一小时内搞定,你只需要花1块钱。
  2. 利用Haproxy,做远程桌面端口的反向代理,这样你就可以通过一个IP链接两台windows服务器了

Windows的远程桌面RDP配置

listen  RemoteDesktop 0.0.0.0:3389
        mode tcp
        option tcplog
        tcp-request inspect-delay 5s
        tcp-request content accept if RDP_COOKIE
        persist rdp-cookie
        balance rdp-cookie
        option tcpka
        server appRD 172.167.1.238:3389

listen  RemoteDesktop 0.0.0.0:5000
        mode tcp
        option tcplog
        tcp-request inspect-delay 5s
        tcp-request content accept if RDP_COOKIE
        persist rdp-cookie
        balance rdp-cookie
        option tcpka
        server appRD 172.167.1.239:3389

转载于:https://www.cnblogs.com/firewing/archive/2012/11/06/2756553.html

利用Haproxy实现http和TCP反向代理和负载均衡(入门和技术验证)相关推荐

  1. [转]nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件

    文章目录 前言 一.nginx简介 1. 什么是 nginx 和可以做什么事情 2.Nginx 作为 web 服务器 3. 正向代理 4. 反向代理 5. 负载均衡 6.动静分离 二.Nginx 的安 ...

  2. nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件,很全

    文章目录 前言 一.nginx简介 1. 什么是 nginx 和可以做什么事情 2.Nginx 作为 web 服务器 3. 正向代理 4. 反向代理 5. 负载均衡 6.动静分离 二.Nginx 的安 ...

  3. Nginx反向代理与负载均衡应用实践

    本链接转载自:https://www.cnblogs.com/chensiqiqi/p/9162926.html 仅供自学使用. 1.1 集群简介 简单地说,集群就是指一组(若干个)相互独立的计算机, ...

  4. Nginx 反向代理、负载均衡、页面缓存、URL重写、读写分离及简单双机热备详解...

    大纲 一.前言 二.环境准备 三.安装与配置Nginx  (windows下nginx安装.配置与使用) 四.Nginx之反向代理 五.Nginx之负载均衡  (负载均衡算法:nginx负载算法 up ...

  5. Nginx反向代理与负载均衡应用实践(二)

    Nginx反向代理与负载均衡应用实践(二) 链接:https://pan.baidu.com/s/1xB20bnuanh0Avs4kwRpSXQ 提取码:migq 复制这段内容后打开百度网盘手机App ...

  6. Nginx 反向代理、负载均衡、页面缓存、URL重写及读写分离详解

    标签:读写分离 页面缓存 URL重写 Nginx 反向代理 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://freeloda.bl ...

  7. nginx做为反向代理实现负载均衡的例子 .

    我们介绍了nginx这个轻量级的高性能server主要可以干的两件事情: >直接作为http server(代替apache,对PHP需要FastCGI处理器支持,这个我们之后介绍): > ...

  8. Nginx 反向代理、负载均衡、页面缓存、URL重写及读写分离详解【转载】

    本文只为备份,以防失效.原文请看https://blog.51cto.com/freeloda/1288553 补充说明:部分图片为测试图片,未完全复制,参考文字描述即可. Nginx 反向代理.负载 ...

  9. Nginx反向代理、负载均衡、页面缓存、URL重写及读写分离详解

    大纲 一.前言 二.环境准备 三.安装与配置Nginx 四.Nginx之反向代理 五.Nginx之负载均衡 六.Nginx之页面缓存 七.Nginx之URL重写 八.Nginx之读写分离 注,操作系统 ...

最新文章

  1. 二叉树-路径总和(递归)
  2. pytorch Flatten展平
  3. Vue 组件间的通讯
  4. Git与GitHub的使用
  5. 胡伟 | 面向多实体人机协作消解的对比表生成自动化方法
  6. 没错!Python杀死了Excel!
  7. 数据结构之算法与线性表
  8. MyBatis的ResultMaps之一对一关系
  9. Qualcomm Atheros ar9285 连不上 tp link无线 的 问题
  10. SQL Server 2014如何导出数据库
  11. 如何用python制作二维码照片_利用Python制作二维码
  12. 玩转百度语音识别,就是这么简单
  13. 【傅里叶变换】离散傅里叶正变换和离散傅里叶逆变换
  14. 怎么样把计算机桌面的图标改小,怎样将电脑桌面图标变小_三招搞定桌面图标太小问题-系统城...
  15. 在linux终端下使用scp与远程windows传输文件
  16. 432.4 FPS 快STDC 2.84倍 | LPS-Net 结合内存、FLOPs、CUDA实现超快语义分割模型
  17. 5.入律古风、排律与柏梁体
  18. 《朱赟的技术管理课》核心笔记
  19. 2022基于微信小程序的图书馆座位预约管理系统.rar(论文+程序设计源码+数据库)毕业设计
  20. 【eclipse技巧记录】eclipse字体设置

热门文章

  1. 单片机基础:什么是中断系统、中断系统如何用(附中断系统应用实例)
  2. 语音信号处理-语音信号的预处理
  3. matlab根据数值画等高线,关于matlab画等高线图
  4. n的阶乘c语言程序迭代,C语言实现N阶乘的程序代码
  5. 用Matlab进行部分分式展开
  6. 债券定价模型与价值影响因素分析
  7. SQL 游标使用示例
  8. 字符型常量与字符串常量的深度解析
  9. SpringCloud微服务项目下的权限校验
  10. PHP采集程序原理分析篇