在大型网站中,负载均衡是有想当必要的。尤其是在同一时间访问量比较大的大型网站,例如网上商城,新闻等CMS系统,为了减轻单个服务器的处理压力,我们引进了负载均衡这一个概念,将一个服务器的压力分摊到几个服务器上,一方面减轻了宕机的几率,另一方面也使得宕机后还要其他服务器可以继续稳定运行,提高了系统的健壮性。
这篇文章将要介绍的主要内容如下:
1、配置三台服务器
2、分别在三台服务器上部署同样的服务代码
3、使用Nginx实现负载均衡
我们的Nginx负载均衡器将部署在一台交互服务器上,配置与其他两台服务器的连接,所有的请求直接访问Nginx服务接口,然后Nginx负载均衡器将自行选择真实调用的服务器端口。
开发环境:Windows 7 x64 sp1 英文版
VisualStudio 2017
部署环境:阿里云 ECS实例 windows server 2012 x64
IIS 7.0
ASP.NET WebApi2(其他的Java服务也一样可以)
使用ASP.NET webapi2 写一个简单地返回json的接口,为了展示我们调用的是不同服务器上的接口,我们以数字形式分别生成三个接口服务,并且分别部署到三台服务器的iis中。
public IHttpActionResult GetTest(){//throw new Exception_DG_Internationalization(1001);string ip = Request.GetIpAddressFromRequest();return OK("Test Api . Client Ip Address is -> "+ip+" The Server is ===== 333 =====");}
我部署的三台服务器后面的数字分别是 111,222,333
注:return OK是本人自定义的返回格式,具体简单代码可以直接return Json();
Request.GetIpAddressFromRequest();是本人扩展的获取ip地址的方法,具体实现请按自身情况实现。
我们将三个后台代码生成后,分别部署到三个服务器上。
为了保密服务器信息,以下我的所有ip地址都将以ip_A,ip_B,ip_C来标识
本文转载自微信公众号「咸鱼正翻身」,作者MDove。转载本文请联系咸鱼正翻身公众...
房地美公司的新任首席信息官弗兰克纳扎罗知道他必须采用不同的软件开发方法。该...
由于疫情持续,最大的文化转变之一是全球员工转向远程办公。数以千计的公司已被...
随着经济全球化,越来越多的企业和产品走向国外市...
如果你在公路两旁看到一排树结满了李子,却无人上前采摘,不用尝就能知道这李子...
【51CTO.com原创稿件】上一篇我们讲解了 Redis 哨兵的工作原理,哨兵主要针对单...
因为电子商务网站的浏览量较为大,因此网站的速度、安全系数都不可忽视。而服务...
Redis具有很多值得推荐的功能,包括速度,可伸缩性和可用性。但是,有一个问题是...
爱因斯坦在给他的第一个传记作者卡尔-塞利格的信中说:我没有什么特殊的才能,我...
阿里云开发者4月走进厦门和无锡 更有阿里云、滴滴等大牛面对面交流 陪你度过这不...