性能分析-nginx

news2024/11/28 18:35:16

tomcat

像kyj项目请求直接对接 tomcat,tomcat的连接池就会直接影响“并发用户数”

如果这种情况下做性能测试的时候,并发用户数不能满足要求,可以适当加大线程池的配置。

如:项目性能测试发现项目所在机器,资源利用率不高,系统的整体负载不高。-------服务器的资源没有得到足够利用。

适当调大线程池的大小,也要去调整堆栈大小,两个一起搭配,才可能让整个tomcat的性能提升。

nginx

目前企业项目做集群的首选软件,但是不是唯一的软件。

反向代理服务器  vs 代理服务器

代理服务器:自己机器的ip,通过一个代理服务器的ip,转发请求包,到另外一个网络中,代理服务 器,会记录从我们机器上发出的所有请求包信息。

反向代理:网络中一个数据包进来,经过反向代理服务器,分发到内部机器上。

数据分发到内部机器是有策略。策略要说:负载均衡

负载均衡不等于平均分配

安装nginx

  • 方法1:用源码包安装------这种方法安装的nginx是可以安装扩展功能,扩展功能主要是可以添加监控
yum install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel -y

# 安装pcre
tar -xzvf pcre-8.44.tar.gz

进入解压后的文件夹
./configure && make && make install

# 下载nginx的包
wget http://nginx.org/download/nginx-1.19.5.tar.gz

解压,进入解压后的文件夹
./configure --prefix=/usr/local/nginx --with-http_stub_status_module --withhttp_ssl_module

make && make install
此时,nginx安装的路径 /usr/local/nginx
启动文件: /usr/local/nginx/sbin/nginx
配置文件: /usr/local/nginx/conf/nginx.conf
检查命令: /usr/local/nginx/sbin/nginx -t
重新加载配置命令:/usr/local/nginx/sbin/nginx -s reload
停止nginx: /usr/local/nginx/sbin/nginx -s stop
  • 方法2:编译包安装------这种方法安装很简单,但是不能安装扩展功能
  • 方法3:dcoker方式安装

这三种方式,配置文件的路径可能都不相同。但是要记住第1种安装方式的配置文件路径。

这个配置文件,就是用于配置nginx集群和反向代理策略的文件。

集群

集群:是相同服务能力输出的服务集合在一起,提供更强能力输出。

相同的服务数量应该在2个以上

nginx配置

nginx+tomcat负载均衡

记录tomcat机器的ip和端口(如果在同一台服务器上记得修改tomcat服务的ip和端口,不然无法启动tomcat服务)

策略:静态策略和动态策略

静态策略:如轮询

动态策略:如iphash

静态策略和动态策略,没有说那种就好或坏,根据业务的实际情况,哪种最合理,相对而言这种就是最 好的。

如果有一个集群,现在要你对这个集群做性能测试,怎么做?

如:kyj的项目,配置了nginx就可以通过ip直接访问项目, kyj的集群是由2个服务构成 如果你自己使用 ip不带端口,这个时候测试的性能,就是2个kyj项目的整体集群的性能。如果我只想测某一个,我可以调整集群的策略

nginx实战

nginx的监控  可以参考这里

nginx的安装必须是源码包安装方式,不能使用rmp包安装方式

安装nginx-module-vts

下载: git clone https://gitee.com/mirrors/nginx-module-vts.git
下载是放在 /opt路径下
进入nginx的解压文件夹
./configure --prefix=/usr/local/nginx --with-http_stub_status_module --withhttp_ssl_module --add-module=/opt/nginx-module-vts/


make && make install

安装 nginx-vts-exporter   默认端口是 9913

wget https://github.com/hnlq715/nginx-vtsexporter/releases/download/v0.10.3/nginx-vts-exporter-0.10.3.linux-amd64.tar.gz

解压
进入解压后的文件夹
nohup ./nginx-vts-exporter -nginx.scrape_uri=http://localhost/status/format/json
&

此时把项目和nginx都启动了,但是访问http://ip:9913,可以正常访问页面,但是页面没有数据。

因为nginx.conf 的配置文件没有修改

http{

vhost_traffic_status_zone;
vhost_traffic_status_filter_by_host on;


server{

location /status {
vhost_traffic_status_display;
vhost_traffic_status_display_format html;

}

}

}

我们搭建监控平台,是把grafana+Prometheus放在同一台机器上,这两个都不要放到被测服务器上

Prometheus数据库,与xxx_exporter所在的机器,网络一定要通。 在Prometheus的机器上,执行

telnet xxexporterIp port

引入模板id:2949

数据基本相同就说明负载均衡一般没有问题。

nginx一般不会成为性能瓶颈,但也不是说,就不会有性能问题。

如果在做性能测试时发现多个接口在某一并发用户数的时候会出错(一小部分)。-----比较明显告诉你

应该是入口地方有性能问题,这个入口很多时候就是nginx。 这种问题大概率就是nginx配置的连 接数不够。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1576804.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

conda创建虚拟环境太慢,Collecting package metadata (current_repodata.json): failed

(省流版:只看加粗红色,末尾也有哦) 平时不怎么用conda,在前公司用服务器的时候用的是公司的conda源,在自己电脑上直接用python创建虚拟环境完事儿,所以对conda的配置并不熟悉~~【狗头】。但是python虚拟环境的最大缺点…

每日面经:计算机网络part1

1. 计算机网络的组成部分有哪些? a. 硬件设备:计算机网络由各种硬件设备组成,包括计算机、服务器、路由器、交换机、网卡等。这些设备通过物理连接(如网线、光纤)相互连接。 b. 协议:计算机网络中的通信需…

二、计算机网络物理层基础知识

一、物理层 物理层接口特性:解决如何在连接各种计算机传输媒体上的传输数据比特流,而不是指具体的传输媒体 物理层的主要任务 :确定与传输媒体接口有关的一些特性>定义标准 1、机械特性:定义物理连接的特性,规定物理…

【C++】RapidJSON 设置支持 std::string,防止编译报错

问题 rapidjson 创建 json 数据,使用 std::string 字符串进行赋值,编译时,抱一堆错误 .... rapidjson/include/rapidjson/document.h:690:5: note: candidate expects 0 arguments, 1 provided [build] make[2]: *** [main/CMakeFiles/ma…

软件杯 深度学习人体语义分割在弹幕防遮挡上的实现 - python

文章目录 1 前言1 课题背景2 技术原理和方法2.1基本原理2.2 技术选型和方法 3 实例分割4 实现效果5 最后 1 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 深度学习人体语义分割在弹幕防遮挡上的应用 该项目较为新颖,适合作为竞…

基于Springboot4S店车辆管理系统

采用技术 基于Springboot4S店车辆管理系统的设计与实现~ 开发语言:Java 数据库:MySQL 技术:SpringBootMyBatis 工具:IDEA/Ecilpse、Navicat、Maven 页面展示效果 管理员功能 首页 销售员管理 维修员管理 客户管理 供应…

前端开发之Element树结构组件el-input的type=“password“时候账号密码自动填充解决方案

Element树结构组件el-input的type“password“时候账号密码自动填充解决方案 前言效果图解决方案 前言 在使用element的input的password当参数和login的参数相同时,在浏览器保存的用户名密码会自动填充,导致input附加上默认值 使用场景一般是在用户管理…

海量智库 | ANY权限原理介绍

ANY权限是Vastbase中的一种特殊的管理权限,用户能够通过ANY权限执行更广泛的操作,更加便利的管理数据库。 本文将为您介绍ANY权限管理的相关原理。 ANY权限管理相关解释 ANY权限管理,是对数据库内的某一类对象的所有实体进行特定的权限管理…

数据产品+AI产品 通关上岸,创建能带来商业价值的AI产品,学习AI产品开发

数据产品 AI产品 通关上岸,创建能带来商业价值的AI产品,学习AI产品开发流程 数据产品+AI产品 通关上岸,创建能带来商业价值的AI产品,学习AI产品开发 - 百创网-源码交易平台_网站源码_商城源码_小程序源码 人工智能快速渗入到各个行业,AI产品经理缺口高达6.8万,成为稀缺…

数字电子基础——编码器

编码器 编码:用文字、符号或数字表示特定对象的过程。在数字电路中,采用二进制进行编码 编码器:实现编码功能的电路 二进制编码器 用 n n n 位二进制代码对 N 2 n N2^n N2n 个信号进行编码的电路 应用举例 【例】设计一个能将 I 0 、…

【cocos creator】【编辑器插件】cocos creator文件复制时,解决cocos creator uuid冲突

!!!修改前先备份 1、将文件夹放在packages文件夹下 2、打开项目,选择要刷新uuid的文件夹 3、菜单栏点击 扩展->refresh-uuid 4、等控制台提示:资源uuid刷新完成,重启项目(!&#…

JavaScript(二)-Web APIS

文章目录 Web API 基本认知作用和分类什么是DOMDOM树DOM对象获取DOM对象操作元素内容操作元素属性操作元素常用属性操作元素样式属性自定义属性 定时器-间歇函数定时器函数的理解定时器函数使用间歇函数 事件监听与绑定事件监听事件监听版本事件类型事件对象什么是事件对象获取…

转让名称带中国的金融控股集团公司要多少钱

随着公司的发展和市场竞争的影响,越来越多的创业者希望注册一家好名称的公司,以提高企业知名度和竞争力。但是,注册中字头无地域公司需要满足一定的条件和流程。本文将对中字头无地域公司注册条件及流程进行详细的介绍。可以致电咨询我或者来…

Sketch是免费软件吗?这款软件支持导入!

Sketch 是一款针对网页、图标、插图等设计的矢量绘图软件。Sketch 的操作界面非常简单易懂,帮助全世界的设计师创作出许多不可思议的作品。但是同时,Sketch 也有一些痛点:使用 Sketch 需要安装 InVision、Abstract 、Zeplin 等插件&#xff0…

粉丝答疑:电脑蓝屏了怎么办?

昨天大白在直播的时候,有粉丝朋友在直播间问到了大白电脑蓝屏了怎么办?今天也特意帮粉丝朋友整理和收集了常见电脑蓝屏代码大全。 电脑蓝屏代码大全及解决办法合集 代码 含意 0 0x00000000 作业完成。 1 0x00000001 不正确的函数。 2 0x00000002 系…

qt自定义窗口在拖动过程中出现抖动且拖动后位置看上去不对

自定义窗口拖动 引言开发环境关键性代码运行结果原因分析改进代码运行结果globalPos()globalPosition()再次修改代码运行结果区别 引言 本文旨在一个问题的记录:自定义窗口拖动的过程中,窗口不能很好的跟随鼠标移动,此外会出现窗口拖动时抖动…

剑指Offer题目笔记29(动态规划矩阵路径问题)

面试题98: 问题: ​ 一个机器人从m x n的格子的左上角出发,它每一步只能向下走或者向右走,计算机器人从左上角到达右下角的路径数量。 解决方案: 机器人每走一步都有两个选择,要么向下走要么向右走。一个任务需要多…

curl下载nexus中的jar包

下载并保持原名称 curl -u admin:password -O "http://127.0.0.1:8081/repository/maven-snapshots/com/edgej/edgej-modules-research/1.0-SNAPSHOT/edgej-modules-research-1.0-20240407.090116-1.jar"下载并重命名 curl -u admin:password -o "edgej-modul…

利用Leaflet + React:构建WEBGIS

React是 Facebook 开发的一个开源库,用于构建用户界面。就其本身而言,Leaflet是一个用于将地图发布到网络的JavaScript 库。这两个工具的组合很简单,允许您创建动态网络地图。在本文中,我们将看到这种组合的一些特征以及一些简单的…

【C++】详解vector二维数组的全部操作(超细图例解析!!!)

目录 一、前言 二、 深度理解vector 的二维数组(重点!) 三、vector 二维数组的空间理解(重点!) ✨问题分析 ✨如何合理定制vector的内存空间 四、vector 二维数组的初始化 五、vector 二维数组的 添加…