秒杀系统服务器部署及jmeter压测工具使用
创始人
2025-05-30 00:09:48
0

1.安装jdk

(1)使用rpm后缀的文件,进行安装

rpm -ivh 文件名

文件自动安装在/usr/java文件夹下
(2)安装完成之后进入根目录

cd ~
vim .bash_profile

增加以下命令

JAVA_HOME=/usr/java/jdk1.8.0_65
PATH=PATH:PATH:PATH:JAVA_HOME/bin

之后使用

source .bash_profile

更新环境变量,使得系统使用的java锁定在这个版本

2.安装数据库环境

安装mysql的所有依赖

yum install mysql*

安装mariadb-server去代替原本的mysql-server

yum install mariadb-server --allowerasing

使用下面的命令启动mariadb-server

systemctl start mariadb.service

mysql默认启动3306端口,可以使用下面的命令查看端口是否被占用

netstat -anp | grep 3306

将mysql的root用户的密码重置为root1234

mysqladmin -u root password root1234

若之后想更改root的密码,需要登陆进sql中,执行下面的代码

alter user ‘root’@‘localhost’ identified by ‘新的密码’;

3.数据库部署

本地服务器的备份、上传、恢复

将数据库数据库备份,并且输入密码,即将被备份的数据库名称为miaosha,备份文件被命名为miaosha.sql

/usr/local/mysql/bin/mysqldump -uroot -p --databases miaosha > ~/Downloads/miaosha.sql

将备份的sql文件上传到云端

使用下面的命令将数据库备份恢复

mysql -uroot -proot1234 < /tmp/miaosha.sql

4.应用程序打包上传

在项目的pom.xml中的中间加上下面的代码,这是打包的plugin

		org.springframework.bootspring-boot-maven-plugin
1234

进入项目的根目录~/IdeaProjects/miaosha,使用下面的命令进行打包

mvn clean package

然后进入target目录,可以发现已经打包好的项目miaosha-1.0-SNAPSHOT.jar和miaosha-1.0-SNAPSHOT.jar.original

java -jar miaosha-1.0-SNAPSHOT.jar

就可以运行程序了

将这个打包好的程序上传到云端

存放在云端的/var/www/miaosha中,改名为miaosha.jar

执行下列命令,就可以将项目启动在云端

java -jar miaosha.jar

之后,外部浏览器预览http://目标域名:8090

5.deploy脚本启动

服务端springboot配置文件application.properties里面的配置可能随着设备环境不同而变化,每次直接修改源码又很复杂,为了让云端的项目自己寻找相应的启动端口和sql地址,需要写一个外挂配置文件,表明这个项目的对应的各种配置

1.在.jar文件的同目录下,新建一个application.properties外挂配置文件,修改文件,里面可以指定服务器端口server.port = 80或者其他操作
tomcat配置
执行下列命令

java -jar miaosha.jar --spring.config.addition-location=/var/www/miaosha/application.properties

2.新建deploy.sh文件,编辑nohup指令,设置最大/最小堆栈为400m,JVM新生代200m,最大新生代大小200m,指定额外配置文件

nohup java -Xms400m -Xmx400m -XX:NewSize=200m -XX:MaxNewSize=200m -jar miaosha.jar --spring.config.addition-location=/var/www/miaosha/application.properties
1

3.后台方式启动应用程序 ./deploy.sh & 避免关闭控制台,应用程序关闭的风险。输出nohup.out文件,这个文件是动态的。

6.压测工具Jmeter

jmeter安装启动教程:https://www.jianshu.com/p/bce9077d883c
启动jmeter之后,新建线程组,在线程组下面新建http请求、查看结果树、聚合报告

7.并发容量问题

Linux命令:

ps -ef | grep java 查看正在进行的名为java的进程

netstat -anp | grep 端口号 查看该端口号情况

pstree - p 进程号 查看该进程号进程下的所有线程(线程树)

pstree -p 进程号 | wc - l 统计进程下的线程数

top H 查看cpu进程情况

在这里插入图片描述

·cpu us : 用户空间cpu使用情况(用户态进程占比)
·cpu sy:内核空间cpu使用情况(核心态进程占比)
·load average:1分钟/5分钟/15分钟负载load平均值,跟着核系数变化,0表示正常,1表示cpu打满,1+代表等待阻塞
·memory:free 空闲内存,used使用内存

查看springboot的配置
在spring-configuration-metadata.json文件下,可以看到tomcat配置,就是服务端线程数配置,

server.tomcat.accept-count 等待队列长度,默认100
server.tomcat.max-connections 最大可被连接数,默认10000
server.tomcat.max-threads 最大工作线程数,默认200//四核8G内存的经验值是800
server.tomcat.min-spare-threads 最小空闲工作线程数,默认10

默认配置下,链接超过10000后出现拒绝链接情况
默认配置下,触发的请求超过200+100后拒绝处理

可以在外挂配置文件application.properties里面更改相应配置

server.tomcat.accept-count=1000		
server.tomcat.max-threads=800	
server.tomcat.min-spare-threads=100
123

8.定制化内嵌Tomcat配置

keepAliveTimeOut 多少毫秒不响应之后断开keepalive maxKeepAliveRequests
多少次请求后keepalive断开失效

在idea中修改
使用WebServerFactoryCustomer 定制化内嵌Tomcat

9.容量问题

响应时间变长,TPS上不去

单Web容量上限
(1)线程数量:4核cpu 8G内存单进程调度线程数为800-1000以上后即花费巨大的时间在cpu调度上
(2)等待队列长度:队列做缓冲池用,但也不能无限长,消耗内存,出队入队也耗cpu

MySQL数据库QPS容量问题

主键查询:千万级别数据 = 1-10ms
唯一索引查询:千万级别数据 = 10-100ms
非唯一索引查询:千万级别数据 = 100-1000ms
无索引:百万条数据 = 1000ms +

MySql数据库TPS容量问题

非插入更新删除操作:同查询
插入操作:1w~10w tps
后续:在同一个专栏里

相关内容

热门资讯

阿联酋最大银行及另两家中东银行... 观点网讯:5月8日,路透社报道指,阿联酋最大银行第一阿布扎比银行(First Abu Dhabi B...
深圳239亿地王易主,再造万象... 2017年,世茂集团豪掷239.43亿元拿下世茂深港国际中心地块,曾规划建筑高度达700米的深圳第一...
蔚来在安庆成立新能源科技公司 ... 天眼查App显示,近日,安庆蔚来新能源科技有限公司成立,法定代表人为姚蒀,注册资本500万人民币,经...
美国牛肉商期盼峰会重启对华出口 据路透社5月8日报道,美国牛肉生产商正期待特朗普与中国于5月14日至15日的峰会推动对华出口许可恢复...
创业板首家未盈利企业,市值突破... 5月8日,大普微总市值正式突破2000亿元大关。截至午间收盘,大普微涨14.07%,报493.1元/...
招商证券:董事长霍达因工作变动... 招商证券公告,公司董事长霍达因工作变动申请辞去董事长、执行董事等全部职务,辞任自辞呈送达董事会之日生...
原创 中... 【阅读须知】本文所引用的所有信息和数据,均为作者通过查阅官方资料与网络公开数据整理、分析而成,旨在为...
原创 从... 2026年5月5日,中国商务部发布了一项具有划时代意义的专项阻断禁令,这份公告让一向倚仗长臂管辖的美...
布米普特拉北京投资基金管理有限... 美国圣路易斯联邦储备银行总裁穆萨莱姆周三发出明确信号,美联储货币政策面临的潜在风险正在发生关键转向。...
加工的秘密:超精加工设备如何做... 你知道吗? 一根头发丝的直径大约0.07毫米,也就是70微米。 超精加工设备,可切出表面,其尺寸为0...
招商证券董事长霍达因工作变动离... 北京商报讯(记者 刘宇阳 实习生 王思奕)5月8日,招商证券发布关于公司董事长离任暨推举董事代行董事...
华帝股份营收创近3年新低,37... 乐居财经李兰近日,华帝股份(002035.SZ)发布2025年年度报告。 2025年,华帝股份实现营...
大模型融资杀疯了!月之暗面狂揽... 图源:视觉中国 5月7日,据华峰资本官微消息,国内头部大模型公司月之暗面(Kimi)于近日完成新一轮...
扎根长宁二十余载,仲利国际融资... 作为总部扎根上海长宁的优质台资金融企业,仲利国际融资租赁有限公司深耕融资租赁行业二十余载,始终坚守金...
估值210亿!李彦宏又将收获一... 来源:直通IPO,文/王非 国产GPU上市潮仍然汹涌,继两家登陆A股、两家登陆H股后,这家公司正推进...
基金“盲盒”拆了 公募基金正在迎来一场让投资者“看得懂”的变革。 近日,华夏、易方达、南方、招商等12家头部及特色基金...
原创 2... 前言 十年间,中国企业在印尼镍产业链累计砸下超过140亿美元,电厂、公路、码头和全套生产线,硬生生...
原创 欧... 俄罗斯卫星通讯社5月6日报道,欧盟宣布禁止欧洲银行为含有来自不可靠供应商的关键部件的可再生能源项目提...
原创 余... 2026年5月2日,在中国理财市场扎根十三年的余额宝,终于触碰到了一个让所有人错愕的数字——7日年化...
银华基金增聘谭普景共同管理银华... 来源:新浪基金∞工作室 5月8日,银华基金管理股份有限公司发布公告称,为银华中证机器人交易型开放式指...