秒杀系统服务器部署及jmeter压测工具使用

1.安装jdk

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

rpm -ivh 文件名

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

cd ~
vim .bash_profile

增加以下命令

JAVA_HOME=/usr/java/jdk1.8.0_65
PATH= P A T H : PATH: PATH:JAVA_HOME/bin

之后使用

source .bash_profile

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

2.安装数据库环境

安装mysql的所有依赖

yum install mysql*

扫描二维码关注公众号,回复: 14774225 查看本文章

安装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

		<plugin>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-maven-plugin</artifactId>
        </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
后续:在同一个专栏里

猜你喜欢

转载自blog.csdn.net/weixin_51405802/article/details/129627775
今日推荐