性能测试之tomcat+nginx负载均衡
off999 2025-01-07 14:56 27 浏览 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定向到同一个后端服务器,要配合缓存命中来使用
- 上一篇:如何对ESB平台进行性能测试
- 下一篇:PHP运行时性能基准测试
相关推荐
- 怎么查询家里wifi密码(怎么查询家里wifi密码是多少)
-
一、通过已连接wifi的电脑查看1、找到电脑右下角的无线网图标,就是类似信号的图标,点开;2、然后右键自己的wifi名称,选择“属性”;3、进去之后勾选“显示字符”,然后就可以看见密码框的密码以数字显...
- 分区工具diskgenius怎么合并分区
-
DiskGenius是一款功能全面的磁盘管理工具,其可以帮助我们进行磁盘分区管理,包括创建新分区、删除分区、扩展分区等。如果您想要合并分区到C盘,可以按照以下步骤进行操作:1.打开DiskGeniu...
- windows10易升怎么用(微软windows10易升使用教程)
-
windows10易升是微软官方的。windows10易升是微软官方发布的升级助理或者叫升级助手(官方下载),帮助你升级到win10最新版本,同时也帮助Win7Win8.1用户升级到Windows1...
- 300兆光纤买什么路由器(300兆光纤买3000m的路由器有用吗)
-
对于300Mbps的网速,推荐选择支持AC750及以上的路由器型号。比如TP-LinkArcherC20、D-LinkDIR-816、NetgearR6020等,都是性价比不错的选择。此类路由...
- windows10产品密钥查询(查看windows10产品密钥)
-
要查看电脑上Windows10的产品密钥,你可以按照以下步骤进行操作:打开“开始”菜单,然后点击“设置”图标(齿轮状图标)。在“设置”窗口中,点击“更新和安全”选项。在左侧导航栏中,选择“激活”选项...
- 电脑总死机卡住不动怎么办(电脑老是死机卡住)
-
如果你的电脑经常卡死,而且只能强制关机,别忘了说明电脑这个配置不够造成的,你需要提高一下它的配置,比如说加一个内存条或者换一个固态硬盘,这样才能够正常运行,不然的话这种电脑是没有办法使用的,现在电脑都...
- win10自动修复死循环无法开机
-
答:1、请确保电脑有充足的电源供应,确保电源可以正常供电;2、检查U盘是否正常安装;3、检查是否有新的软硬件设备接入;4、运行chkdsk,检查硬盘并修复文件系统;5、检查Windows更新,如果存在...
-
- 查看台式电脑ip地址(查询台式电脑ip地址)
-
如何查看主机名和IP地址:右击我的电脑-属性-网络标识(win2000)/计算机名(winxp)-完整的计算机名称后面的就是你的主机名.右击网上邻居-,属性-右击本地连接-属性-双击INTERNET协议(tcp/ip)就可以看到自己的I...
-
2025-12-15 19:03 off999
- windows7 ultimate(windows7ultimate无法启动)
-
32位的。1、在下载操作系统镜像的时候,带有x86标识的一般是32位系统,指的是CPU地址总线是32位、fetch、decode解压指令时也按32位字长来进行。x64一般表示系统为64位。2、x86是...
- 雨林系统u盘安装步骤(雨林重装系统)
-
如果是ISO镜像那就刻盘安装,如果不想刻盘,就硬盘安装。问题又来了,大部分的都是GHOST的系统,还有就是纯安装版的。我只说一下GHOST的,先把ISO文件给解压了,然后里边会有占主要空间大小的.GH...
-
- 0xc000021a手动修复(修复0xc0000225)
-
出现这样的问题很常见,用以下方法及解决方案就可以解决1、错误代码0xc000021a表示用户模式子系统有所损坏。一般按照蓝屏提示重启系统,即可正常运行。2、如果重启没能解决,则建议通过“最后一次正确的配置”方式启动系统。3、如果系统文件被破...
-
2025-12-15 17:51 off999
-
- windows7网络驱动(win7网络驱动在哪个文件夹)
-
1.Networkcarddriver。2.右键我的电脑,点击“属性”,选择左侧“设备管理器”3.点击“网络适配器”,如果方框内没有驱动,请下载驱动精灵安装网卡驱动。在Windows7操作系统中,网络驱动程序的名称通常以网络适配器的品...
-
2025-12-15 17:03 off999
- diskgenius的功能介绍(diskgenius是什么)
-
先打开DiskGenius(如果系统打不开了,可以在PE下运行),在弹出分区工具Diskgenius工具中,依次点击“硬盘——重建主引导记录(MBR)”选项,无需理会弹出的提示窗口,直接按下“是”即可...
- 网速快但是打开网页慢(网速快但是打开网页慢怎么回事)
-
原因有很多,有可能是路由器的原因,也有可能是其他原因,总的来说,网速慢的常见原因有以下几种:1.wifi被人蹭网,别人占用了带宽或者给你限速了,可以登录路由器管理页面查看连接的设备数。2.路由器性能...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
