百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

性能测试之tomcat+nginx负载均衡

off999 2025-01-07 14:56 16 浏览 0 评论

nginx tomcat 配置

准备工作:两个tomcat 执行命令 cp -r apache-tomcat-8.5.56 apache-tomcat-8.5.56_2

修改被复制的tomcat2下conf的server.xml 的端口号,不能与tomcat1的端口号重复,不然会启动报错 ,一台电脑上想要启动多个tomcat,需要修改server.xml文件的3个端口

分别修改tomcat1和tomcat2 端口,这里有三个端口需要修改,分别如下:   
    
shutdown 端口:8005  主要负责启动关闭.   
    
ajp端口:8009 主要负责通过ajp均衡(常用于apache和tomcat整合)   
    
http端口:8080 可以通过web页面直接访问(nginx+tomcata整合)   

tomcat2的http端口修改为888】1

tomcat2的ajp端口修改为8010

tomcat2的shutdown端口修改为8006

分别在每个tomca的bin目录下启动服务 startup

使用 lsof -f:8080 lsof -f:8881 查看是否端口被占用,得知项目已经成功被启动

两个端口访问都是正常的



nginx conf文件讲解

  • 全局块:配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker process数等
  • events块:配置影响nginx服务器或与用户的网络连接有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网路连接,开启多个网络连接序列化等。
  • http块;可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等
  • server块:配置虚拟主机的相关参数,一个http中可以有多个server
  • location块:配置请求的路由,以及各种页面的处理情况配置负载均衡

worker_processes 设置nginx工作的进程数,一般设置与cpu核数相等或2倍


events {

use epoll;

worker_connections 1024;

}

epoll 事件模型,处理效率高

worker_connections 单个worker进程允许客户端最大连接数,实际最大值=work_processes * worker_connections

multi_accept 告诉nginx收到一个新连接的通知后接受尽可能多的连接,默认是on,设置为on后,多个worker按串行方式来处理连接,也就是一个连接只有一个worker被唤醒,其他的处于休眠状态,设置为off后,多个worker按并行方式来处理连接,也就是一个连接会唤醒所有的worker,直到连接分配完毕,没有取得连接的继续休眠。参数只针对非常大量连接有优化作用。


  • Include mime.types : 媒体类型include 只是一个在当前文件中包含另一个文件内容的指令。
  • default_type application/octet-stream :默认媒体类型足够支持所以请求。
  • sendfIle on:开启高效文件传输模式,sendfle指令指定nginx是否调用sendfle数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络IO处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。
  • tcp_nopush on:必须在sendfle开启模式才有效,防止网络阻塞,积极的减少网络报文段的数量(将响应头和正文的开始部分一起发送,而不一个接一个的发送)
  • keepalive_timeout 网络会话保持时间
  • tcp_nodelay:也是防止网络阻塞,需要开启keepalive参数才有效
  • client header buffer size 4k:客户端请求头部的缓冲区大小,这个可以根据你的系统分页大小来设置,一般一个请求头的大小不会超过1k,不过由于一般系统分页都要大于1k,所以这里设置为分页大小。分页大小可以用命令getconf PAGESIZE取得
  • open file cache max=102400 inactive=20s : 为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive 是指经过多长时间文件没被请求后删除缓存
  • open file cache valid 30s:这个是指检查一次缓存的有效信息的频率
  • open file cache min uses 1: open file cache指今中的inactive 参数时间内文件的最少使用次数,如果超过这数字,文件描述符一直是在缓存中打开的,如上,如果有一个文件在inactive 时间内一次没被使用,它将被移除
  • client header timeout : 设置请求头的超时时间。我们也可以把这个设置低一些如果超过这个时间没有发送任何数据,nginx 将返回request time out的错误
  • client body timeout :设置请求体的超时时间。可以把这个设置低一些,超过这个时间没有发送任何数据,和上面一样的错误提示
  • reset timeout connection : 通知nginx关闭未响应的客户端连接,会释放那个客户端所占有的内存空间
  • send timeout:响应客户端超时时间,这个超时时间仅限于两个活动之间的时间,如果超过这个时间,客户端没有任何活动,nginx关闭连接。
  • server tokens:并不会nginx执行的速度更快,但它可以关闭在错误页面中的nginx版本信息,更安全
  • client max body size:上传文件大小的限制

配置负载均衡

在nginx.conf 配置

upstream zcz_app {
server 192.168.43.138:8080 weight=1 max_fails=2 fail_timeout=30s;
server 192.168.43.138:8881 weight=1 max_fails=2 fail_timeout=30s;
}

负载均衡以upstream为模块定义,后面跟模块名称

  • server ip地址:服务端口:
  • 均衡策略: weight 权重
  • 轮询次数:max_fails
  • 轮询时长:fail_timeout

在location模块下使用负载均衡,注解自带的location,新增上面定义的负载均衡

location / {
proxy_next_upstream http_502 http_504 error timeout invalid_header;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://zcz_app;
root html;
index index.html index.htm;
}

重新加载配置文件

/usr/local/nginx/sbin/nginx -s reload

未负载均衡前需要加上端口号

负载均衡后访问不需要加端口号

负载均衡的几种方式

轮询:默认策略,如果服务器down掉了,会自动删除该服务器;此策略适合服务器配置相当,无状态且短平快的服务使用

iphash依据ip分配 :iphash不能与backup同时使用:此策略适合有状态服务,比如session; 服务器需要别除,必须手动停掉 (常用于灰度发布,通过配置iphash 实现)

least conn最小连接 :此负载均衡策略适合请求处理时间长短不一造成服务器过载的情况

weight权重 :权重越高分配到需要处理的请求越多;此策略可以与least conn和ip hash结合使用,此策略比较适合服务器的硬件配置差别比较大的情况

fair响应时间 :负载均衡策略的实现需要安装第三方插件;按照服务器端的响应时间来分配请求,响应时间短的优先分配

url_hash依据URL分配 :按访问ur的hash结果来分配请求,使每个url定向到同一个后端服务器,要配合缓存命中来使用

相关推荐

全网第一个讲清楚CPK如何计算的Step by stepExcel和Python同时实现

在网上搜索CPK的计算方法,几乎全是照搬教材的公式,在实际工作做作用不大,甚至误导人。比如这个又比如这个:CPK=min((X-LSL/3s),(USL-X/3s))还有这个,很规范的公式,也很清晰很...

[R语言] R语言快速入门教程(r语言基础操作)

本文主要是为了从零开始学习和理解R语言,简要介绍了该语言的最重要部分,以快速入门。主要参考文章:R-TutorialR语言程序的编写需要安装R或RStudio,通常是在RStudio中键入代码。但是R...

Python第123题:计算直角三角形底边斜边【PythonTip题库300题】

1、编程试题:编写一个程序,找出已知面积和高的直角三角形的另外两边(底边及斜边)。定义函数find_missing_sides(),有两个参数:area(面积)和height(高)。在函数内,计算另外...

Tensor:Pytorch神经网络界的Numpy

TensorTensor,它可以是0维、一维以及多维的数组,你可以将它看作为神经网络界的Numpy,它与Numpy相似,二者可以共享内存,且之间的转换非常方便。但它们也不相同,最大的区别就是Numpy...

python多进程编程(python多进程进程池)

forkwindows中是没有fork函数的,一开始直接在Windows中测试,直接报错importosimporttimeret=os.fork()ifret==0:...

原来Python的协程有2种实现方式(python协程模型)

什么是协程在Python中,协程(Coroutine)是一种轻量级的并发编程方式,可以通过协作式多任务来实现高效的并发执行。协程是一种特殊的生成器函数,通过使用yield关键字来挂起函数的执行...

ob混淆加密解密,新版大众点评加密解密

1目标:新版大众点评接口参数_token加密解密数据获取:所有教育培训机构联系方式获取难点:objs混淆2打开大众点评网站,点击教育全部,打开页面,切换到mobile模式,才能找到接口。打开开发者工具...

python并发编程-同步锁(python并发和并行)

需要注意的点:1.线程抢的是GIL锁,GIL锁相当于执行权限,拿到执行权限后才能拿到互斥锁Lock,其他线程也可以抢到GIL,但如果发现Lock仍然没有被释放则阻塞,即便是拿到执行权限GIL也要立刻...

10分钟学会Python基础知识(python基础讲解)

看完本文大概需要8分钟,看完后,仔细看下代码,认真回一下,函数基本知识就OK了。最好还是把代码敲一下。一、函数基础简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运行。...

Python最常见的170道面试题全解析答案(二)

60.请写一个Python逻辑,计算一个文件中的大写字母数量答:withopen(‘A.txt’)asfs:count=0foriinfs.read():ifi.isupper...

Python 如何通过 threading 模块实现多线程。

先熟悉下相关概念多线程是并发编程的一种方式,多线程在CPU密集型任务中无法充分利用多核性能,但在I/O操作(如文件读写、网络请求)等待期间,线程会释放GIL,此时其他线程可以运行。GIL是P...

Python的设计模式单例模式(python 单例)

单例模式,简单的说就是确保只有一个实例,我们知道,通常情况下类其实可以有很多实例,我们这么来保证唯一呢,全局访问。如配置管理、数据库连接池、日志处理器等。classSingleton: ...

更安全的加密工具:bcrypt(bcrypt加密在线)

作为程序员在开发工作中经常会使用加密算法,比如,密码、敏感数据等。初学者经常使用md5等方式对数据进行加密,但是作为严谨开发的程序员,需要掌握一些相对安全的加密方式,今天给大家介绍下我我在工作中使用到...

一篇文章搞懂Python协程(python协程用法)

前引之前我们学习了线程、进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位。按道理来说我们已经算是把cpu的利用率提高很多了。但是我们知道无论是创建多进程还是创建多线...

Python开发必会的5个线程安全技巧

点赞、收藏、加关注,下次找我不迷路一、啥是线程安全?假设你开了一家包子铺,店里有个公共的蒸笼,里面放着刚蒸好的包子。现在有三个顾客同时来拿包子,要是每个人都随便伸手去拿,会不会出现混乱?比如第一个顾...

取消回复欢迎 发表评论: