Nginx-代理apache负载均衡

Nginx-代理apache负载均衡一、什么是负载均衡        当一台服务器单位时间访问量越大时,服务器压力就越大,大到超过自身承受能力时,服务器就容会崩掉。为了避免服务器崩溃,让用户有更好的体验,我们通过负载均衡的方式来分担服务器压力。        我们可以建立多个服务器,组成一个服务器集群,当用户访问网站时,先访问中间服务器,再让这个中间服务器在服务器集群中选择一个压力

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、什么是负载均衡

        当一台服务器单位时间访问量越大时,服务器压力就越大,大到超过自身承受能力时,服务器就容会崩掉。为了避免服务器崩溃,让用户有更好的体验,我们通过负载均衡的方式来分担服务器压力。
        我们可以建立多个服务器,组成一个服务器集群,当用户访问网站时,先访问中间服务器,再让这个中间服务器在服务器集群中选择一个压力较小的服务器,然后将该访问请求引入该服务器。如此以来,用户的每次访问,都会保证服务器集群中的每个服务器压力趋于平衡,既分担了服务器压力,有避免了服务器崩溃的情况

二、Nginx负载均衡的实现

必备条件

        ① 至少三台服务器(虚拟机),本次使用的虚拟机如下:

虚拟机名称 IP 备注
本地centos3(nginx) 192.168.254.132 事先安装好nginx,下文此服务器叫132
本地centos4(apache) 192.168.254.134 事先安装好apache,下文此服务器叫134
本地centos5(apache) 192.168.254.135 事先安装好apache,下文此服务器叫135

1.apache启动并部署页面

        134135服务器分别启动apache,代码如下:

systemctl start httpd

        分别检查一下apache的状态,代码如下:

systemctl status httpd

        结果如下( active(running) 说明已经跑起来):
在这里插入图片描述
        访问apache首页:192.168.254.134/135,页面如下:
在这里插入图片描述

        在 /var/www/html 简单写个test.html,代码如下(写两份,一个134一个135):

<!DOCTYPE html>
<html>
<head>
	<title>负载均衡</title>
</head>
<body>
这是192.168.254.134服务器!你好!!!
<!-- 这是192.168.254.135服务器!你好!!! -->
</body>
</html>

        访问 192.168.254.134/test.html192.168.254.135/test.html ,页面如下:在这里插入图片描述
在这里插入图片描述

2.nginx启动

        132服务器分别启动nginx,代码如下:

systemctl start nginx

        检查一下nginx的状态,代码如下:

systemctl status nginx

        结果如下( active(running) 说明已经跑起来):
在这里插入图片描述

3.nginx配置反向代理

        132服务器,进入 /etc/nginx 然后 ls :
在这里插入图片描述
        我们需要修改的是nginx.conf配置文件,替换80端口location节点下的内容,修改内容如下:

location / { 
   
      proxy_pass http://192.168.254.134:80;
}

        保存文件后,重载nginx,代码如下:

systemctl reload nginx

        为防止修改配置文件后出现问题,再检查一下nginx的状态:

systemctl status nginx

在这里插入图片描述
        那么现在,当你访问192.168.254.132:80/test.html的时候,其实你访问到的是192.168.254.134:80/test.html,如下图:在这里插入图片描述
        反向代理配置完成,接下来我们来配置负载均衡。

4.nginx配置负载均衡

        还是修改nginx.conf配置文件,在配置文件的80的server节点上新增upstream节点,代码如下:

upstream test{ 
   
    server 192.168.254.134:80;
    server 192.168.254.135:80;
}

        修改第二步中提到的location节点内容,将proxy_pass指向upsteam节点的名字test,代码如下:

location / { 
   
    proxy_pass http://test;
}

        保存文件,重载nginx,代码如下:

systemctl reload nginx

        此时我们再访问192.168.254.132:80/test.html,这是你发现一会访问到的是192.168.254.134:80/test.html,一会访问到的是192.168.254.135:80/test.html
,如果如下;
请添加图片描述
请添加图片描述
        那么这样也就是实现了通过nginx代理apache,实现轮询策略的负载均衡。收工!!!

附:nginx负载均衡的几种策略

1、轮询(默认,也就是本片文章实现的策略)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

upstream test{ 
    
	server 192.168.254.134:80; 
	server 192.168.254.135:80; 
} 

2、指定权重
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

upstream test{ 
    
	server 192.168.254.134:80 weight=8; 
	server 192.168.254.135:80 weight=10; 
} 

3、IP绑定 ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

upstream test{ 
    
	ip_hash; 
	server 192.168.254.134:80; 
	server 192.168.254.135:80;
} 

4、fair
按后端服务器的响应时间来分配请求,响应时间短的优先分配。

upstream test{ 
    
	server 192.168.254.134:80; 
	server 192.168.254.135:80;
	fair; 
} 

5、url_hash
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。

upstream test{ 
    
	server 192.168.254.134:80; 
	server 192.168.254.135:80; 
	hash $request_uri; 
	hash_method crc32; 
} 

其他参数说明:

	server 192.168.254.134:80 down; (down 表示当前的server暂时不参与负载) 
	server 192.168.254.135:80 backup; (其它所有的非backup机器down或者忙的时候,请求backup机器) 
} 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195825.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • kettle工具实现数据清洗「建议收藏」

    kettle工具实现数据清洗「建议收藏」一、Excel输入2.设置参数3.查看被选中的文件名称。单击【显示文件名称…】按钮,弹出【文件读取】对话框,查看被选中读取的文件,如图所示。4.设置工作表5.【字段】选项卡参数6.预览记录二、生成记录1.加入控件3.预览记录三、生成随机数1.加入控件2.配置控件3.预览记录四、获取系统信息1.加入控件2.配置控件3.预览记录五、排序记录1.建…

    2022年10月10日
    1
  • Visual Studio中C++关于Unicode字符集和多字节字符集

    Visual Studio中C++关于Unicode字符集和多字节字符集1.Unicode字符集  原本标准字符集为8位的ASCII码,但世界上的书写语言不能简单地用256个8位代码即一字节表示,就试更宽的值,例如16位值。这就是Unicode非常简单的原理。与混乱的256字符代码映射,以及含有一些单字节代码和一些双字节代码的双字节字符集不同,Unicode是统一的16位系统,这样就允许表示65536个字符。在这里会高兴地告诉你前128个Unicode字符(1

    2025年7月24日
    3
  • 【JAVA学习】单例模式的七种写法

    【JAVA学习】单例模式的七种写法

    2022年1月24日
    38
  • 值得推荐的Idea十几大优秀插件

    值得推荐的Idea十几大优秀插件最近,闲来无事,为了改变一下枯燥的编程环境,特地搜寻了下有助提升代码功力的插件,够装逼,够狂,拽,屌~绚丽的画面,多彩的跳动,让你区别其他程序猿。产品,测试,开发看到你的界面,眼睛都会发光~算了,我实在是编不下去,自己去体验吧~PS:☆半星★一星主要是以狂拽屌指数来排名12、Stackoverflow这个插件其实是最实用的插件,程序猿遇到的问题…

    2022年6月16日
    127
  • 关于pycharm安装第三方库的一些方法_pycharm安装本地第三方库

    关于pycharm安装第三方库的一些方法_pycharm安装本地第三方库问题集合记得关梯子记得关梯子记得关梯子要是遇到pip命令报错,或者在pycharm中无法下载第三方库,首先检查一下梯子是否开了的。我的环境:pycharm+anaconda虚拟环境问题1:问题:WARNING:Youareusingpipversion21.2.4;however,version21.3.1isavailable.Youshouldconsiderupgradingviathe’D:\anaconda\envs\py36\python.e

    2022年8月28日
    2
  • 博客营销BlogUp

    博客营销BlogUp九丁博客群发工具BlogUp是一款强大的博客营销工具,具有博客全自动群发、博客帐号辅助群建、帐号分组管理、博客文章可视化管理、文章伪原创、超链接自动插入、文章自动采集、关键词设置、标签设置、自动更换IP等核心功能。是商家、站长、写手、个人、公司等用于网络营销、软文推广、博客写作、网络推广、SEO的绝佳工具。利用BlogUp可以帮您增加搜索引擎信息收录量,提高搜索引擎排名,快速提高产品、网站、文章等…

    2022年7月14日
    17

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号