秒杀系统服务器部署及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月以来,多地金融监管部门对部分中小银行、消金公司下达...
朱鸿接任陈航,担任钉钉科技有限... 消费日报-今朝新闻讯 天眼查显示,6月23日,钉钉科技有限公司发生工商变更,陈航卸任法定代表人、董事...
3日累跌超20%,德创环保:公... 6月25日, 德创环保(603177.SH)公告,公司股票于2026年6月23日、6月24日和6月2...
北京发布2026年第七轮拟供商... 央广网北京6月25日消息(记者门庭婷)6月25日,北京市规划和自然资源委员会网站发布了2026年第七...
开放麦 | 启明创投胡奇:从A... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
腾讯孙忠怀:在行业转身处 6月24日,2026腾讯视频年度发布在上海举行。腾讯公司副总裁、腾讯在线视频董事长孙忠怀以《在行业转...
加息,突变!美联储,重磅传来!... 美联储政策路径突生变数。 美国商务部经济分析局最新公布的数据显示,5月个人消费支出(PCE)物价指数...
6月合肥上门收金必看!5步避坑... 2026年6月,合肥黄金市场持续高位运行,不少市民翻出家里闲置的旧金饰、投资金条想变现,上门回收因为...
潮汕女富豪挂帅后加码液冷!祥鑫... 潮汕女强人,带着百亿公司加码液冷散热。 6月24日晚间,祥鑫科技(002965.SZ)公告称,公司董...
马斯克向太空要电,GobiX ... 一场关于「去哪里找电」的全球竞赛,正在朝两个方向展开。 作者|周永亮 编辑| 郑玄 「太空光伏是不是...
原料药行业陷入周期低谷 有药企... 每经记者|许立波 每经编辑|魏文艺 “过完年到现在,我们整个团队每个月都在出差,跑遍了亚非拉、欧美市...
家门口筛查白内障!永顺泽家镇暖... 大众卫生报·新湖南客户端6月25日讯(通讯员 彭雪姣)为切实解决辖区老年性白内障患者异地就医奔波、就...
终于等到!油价马上再大跌,这个... 点击添加图片描述(最多60个字) 编辑 各位车主朋友,好消息接二连三! 继6月18日油价大幅下调...
丈量出海新路 世界酒庄影响力指... 长期以来,全球酒庄评价体系由西方机构主导,且大多局限于单一酒种、单一评价维度,这一局面正逐渐被打破。...
峰瑞资本创始合伙人李丰:从资本... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
原创 A... 迈向成熟,还有茁壮成长的机会。 作者 | 方璐 编辑丨于婞 来源 | 野马财经 2026年6月21日...
为企业解锁出海新通道!亚太中小... 6月24日下午,作为2026年APEC中小企业工商论坛的重要组成部分,亚太中小企业国际化合作发展论坛...
君赛生物港股IPO,增聘兴证国... 跟丰宜科技一样,正冲刺港股IPO的上海君赛生物股份有限公司(简称“君赛生物”)增聘一位整体协调人。 ...
圣邦股份明日上市:暗盘涨24%... 雷递网 雷建平 6月25日 圣邦微电子(北京)股份有限公司(简称:“圣邦股份”,股票代码:“0366...
科技“吃肉”,券商跟着“喝汤”... 当科技持续成为市场核心主线,押中硬科技项目的券商也成为被追逐的焦点。 6月24日,半导体零部件概念股...