(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锁定在这个版本
安装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 ‘新的密码’;
本地服务器的备份、上传、恢复
将数据库数据库备份,并且输入密码,即将被备份的数据库名称为miaosha,备份文件被命名为miaosha.sql
/usr/local/mysql/bin/mysqldump -uroot -p --databases miaosha > ~/Downloads/miaosha.sql
将备份的sql文件上传到云端
使用下面的命令将数据库备份恢复
mysql -uroot -proot1234 < /tmp/miaosha.sql
在项目的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
服务端springboot配置文件application.properties里面的配置可能随着设备环境不同而变化,每次直接修改源码又很复杂,为了让云端的项目自己寻找相应的启动端口和sql地址,需要写一个外挂配置文件,表明这个项目的对应的各种配置
1.在.jar文件的同目录下,新建一个application.properties外挂配置文件,修改文件,里面可以指定服务器端口server.port = 80或者其他操作
执行下列命令
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文件,这个文件是动态的。
jmeter安装启动教程:https://www.jianshu.com/p/bce9077d883c
启动jmeter之后,新建线程组,在线程组下面新建http请求、查看结果树、聚合报告
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
keepAliveTimeOut 多少毫秒不响应之后断开keepalive maxKeepAliveRequests
多少次请求后keepalive断开失效
在idea中修改
使用WebServerFactoryCustomer 定制化内嵌Tomcat
单Web容量上限
(1)线程数量:4核cpu 8G内存单进程调度线程数为800-1000以上后即花费巨大的时间在cpu调度上
(2)等待队列长度:队列做缓冲池用,但也不能无限长,消耗内存,出队入队也耗cpu
主键查询:千万级别数据 = 1-10ms
唯一索引查询:千万级别数据 = 10-100ms
非唯一索引查询:千万级别数据 = 100-1000ms
无索引:百万条数据 = 1000ms +
非插入更新删除操作:同查询
插入操作:1w~10w tps
后续:
在同一个专栏里