热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Centos7上如何配置nginx的负载均衡

Centos7上如何配置nginx的负载均衡,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单

Centos7上如何配置nginx的负载均衡,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

Centos7上配置nginx的负载均衡

前言

在配置nginx负载均衡前.我们需要明白几个名词的概念

注: 如果不小心忘了tomcat和nginx的启动,关闭命令,可参考写在文章最后的命令

一 重要的概念理解

1 什么是nginx呢?

Nginx是一个web服务器和反向代理服务器,用于HTTP、HTTPS、SMTP、POP3和IMAP协议.

2 什么是反向代理呢?

反向代理隐藏了真实的服务端,当我们请求 www.baidu.com 的时候,就像拨打10086一样,背后可能有成千上万台服务器为我们服务,但具体是哪一台,你不知道,也不需要知道,你只需要知道反向代理服务器是谁就好了,www.baidu.com 就是我们的反向代理服务器,反向代理服务器会帮我们把请求转发到真实的服务器那里去。Nginx就是性能非常好的反向代理服务器,用来做负载均衡。

3 什么是负载均衡呢?

负载均衡(Load Balancing)是一种将任务分派到多个服务端进程的方法。例如,将一个HTTP请求派发到实际的Web服务器中执行的过程就涉及负载均衡的实现。一个HTTP请求到达Web服务器,这中间涉及多个过程,也存在多种不同负载均衡的方法。

4 负载均衡有什么作用呢?

  1. 转发功能
    按照一定的算法【权重、轮询】,将客户端请求转发到不同应用服务器上,减轻单个服务器压力,提高系统并发量。

  2. 故障移除
    通过心跳检测的方式,判断应用服务器当前是否可以正常工作,如果服务器期宕掉,自动将请求发送到其他应用服务器。

  3. 恢复添加
    如检测到发生故障的应用服务器恢复工作,自动将其添加到处理用户请求队伍中。

5 负载均衡的分发策略是什么呢?

Nginx 的 upstream目前支持的分配算法:
1)、轮询 ——1:1 轮流处理请求(默认)

每个请求按时间顺序逐一分配到不同的应用服务器,如果应用服务器down掉,自动剔除,剩下的继续轮询。

2)、权重 ——you can you up

通过配置权重,指定轮询几率,权重和访问比率成正比,用于应用服务器性能不均的情况。

3)、ip_哈希算法

每个请求按访问ip的hash结果分配,这样每个访客固定访问一个应用服务器,可以解决session共享的问题。

二 配置负载均衡

此次模拟就不在多个机器上配了,我们把三个tomcat都装到一台机器上的不同目录下,分别给他们不同的端口,修改下
他们的首页,模拟一下负载均衡

First: 准备工作

一个nginx服务器,三个tomcat服务器

nginx的安装我前面有写过,同志们可参考这篇文章
tomcat就更简单了,直接上传解压,就可以在浏览器访问ip使用了,打不开,关闭下防火墙试试

我的安装目录
nginx /opt/nginx/nginx-1.8.0
tomcat /opt/tomcat/apache-tomcat-7.0.57
test1号tomcat /opt/tomcattest1/apache-tomcat-7.0.57
test2号tomcat /opt/tomcattest2/apache-tomcat-7.0.57

我们用tomcat来给test1号和test2号做负载均衡
Centos7上如何配置nginx的负载均衡

Second: 修改1号,2号tomcat的配置文件和首页

一 1号tomcat

注意: 修改tomcat的配置文件前,如果启动了tomcat,就关了再修改

1 先修改端口
vi /opt/tomcattest1/apache-tomcat-7.0.57/conf/server.xml

改三个地方,把三个没加注释的端口全部加1

注意: 要改没加注释的,加了注释的改了也没用
8005->8006
8080->8081
8009->8010
Centos7上如何配置nginx的负载均衡

Centos7上如何配置nginx的负载均衡
Centos7上如何配置nginx的负载均衡

2 再修改一下首页,主要为了做区分
cd /opt/tomcattest1/apache-tomcat-7.0.57/webapps/ROOT
vi index.jsp
在标签下加个h2标签作区分
位置: 
 
        

111111111111111111111111111111

3 启动tomcat

在浏览器访问

http://192.168.220.111/8081       用你自己的ip

二 2号tomcat

跟上面一样,把要修改的三个端口都加2 就行了

注意: 要改没加注释的,加了注释的改了也没用
8005->8007
8080->8082
8009->8011

浏览器访问

http://192.168.220.111/8082       用你自己的ip

Third: 配置负载均衡

注意: 修改nginx的配置文件前,如果启动了nginx,就关了再修改

修改nginx配置文件

vi /usr/local/nginx/conf/nginx.conf

shift+g 跳到最下边,在最后的 } 前加入

upstream tomcatserver1 {
        server 192.168.220.111:8081 ;
         server 192.168.220.111:8082 ;
    }
  server {
        listen       80;
        server_name  love.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcatserver1;
            index  index.html index.htm;
        }


    }

解释一下
一个upstream 对应一个server
当我们在浏览器输入 love.com (自己随便写个喜欢的域名),会先找到location里的 proxy_pass 后面的 http://tomcatserver1,
再找到tomcatserver1对应的相同名字的upstream ,然后进去找代理的ip

此时还需要在本地hosts里加上我们的ip就可以在浏览器访问了
在windows系统下,进入

C:\Windows\System32\drivers\etc 目录下,打开hosts文件,在最下边加上

192.168.220.111 love.com

你自己的ip   和你自己配置的域名

然后启动nginx

在浏览器输入 http://192.168.220.111
不停的刷新页面,会发现1号tomcat 和2 号tomcat近乎于交替出现,也就是最开始我们提到的负载均衡的三种分发策略中的轮询,
近乎1:1出现

扩展:

然而在现实开发中,假设我们的多台服务器的性能好坏不一样,我们希望性能较好的1 号服务器多代理点url,就可以进行
权重或hash配置

----------------------------

这里附上几条可能会用到的命令
Tomcat常用命令

启动Tomcat:
进入tomcat目录/bin,然后./startup.sh

停止Tomcat:
进入tomcat目录/bin,然后./shutdown.sh

Nginx 常用命令

注意nginx的配置端口的配置文件在  /usr/local/nginx/conf
并不是在解压目录下

启动nginx
cd usr/local/nginx/sbin/
./nginx


重启nginx
有两种方法
1 先关闭再重启
./nginx -s quit   或者 ./nginx -s stop
./nginx

2 直接重启
./nginx -s reload


检查是否已经安装有nginx及对应目录
find /|grep nginx.conf

查看nginx占用的的端口
ps -ef| grep nginx

需要杀掉的话
kill -9 xx

关于Centos7上如何配置nginx的负载均衡问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程笔记行业资讯频道了解更多相关知识。


推荐阅读
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了Windows操作系统的版本及其特点,包括Windows 7系统的6个版本:Starter、Home Basic、Home Premium、Professional、Enterprise、Ultimate。Windows操作系统是微软公司研发的一套操作系统,具有人机操作性优异、支持的应用软件较多、对硬件支持良好等优点。Windows 7 Starter是功能最少的版本,缺乏Aero特效功能,没有64位支持,最初设计不能同时运行三个以上应用程序。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • 本文总结了淘淘商城项目的功能和架构,并介绍了传统架构中遇到的session共享问题及解决方法。淘淘商城是一个综合性的B2C平台,类似京东商城、天猫商城,会员可以在商城浏览商品、下订单,管理员、运营可以在平台后台管理系统中管理商品、订单、会员等。商城的架构包括后台管理系统、前台系统、会员系统、订单系统、搜索系统和单点登录系统。在传统架构中,可以采用tomcat集群解决并发量高的问题,但由于session共享的限制,集群数量有限。本文探讨了如何解决session共享的问题。 ... [详细]
  • 关于CMS收集器的知识介绍和优缺点分析
    本文介绍了CMS收集器的概念、运行过程和优缺点,并解释了垃圾回收器的作用和实践。CMS收集器是一种基于标记-清除算法的垃圾回收器,适用于互联网站和B/S系统等对响应速度和停顿时间有较高要求的应用。同时,还提供了其他垃圾回收器的参考资料。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • GreenDAO快速入门
    前言之前在自己做项目的时候,用到了GreenDAO数据库,其实对于数据库辅助工具库从OrmLite,到litePal再到GreenDAO,总是在不停的切换,但是没有真正去了解他们的 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
author-avatar
程序员那些事
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有