准备环境:MySQL、Redis、注册中心、RocketMQ、sentinel流控jar包部署、Jemter环境及脚本
注意事项:白名单、安全组、端口、镜像容器、压测脚本
压测场景:20万用户,在10秒处理完,每个用户每秒5次请求,共计一千万次请求,OPS是100万。
首先将项目打成jar包,然后在同层目录下创建Dockerfile文件,执行构建镜像容器,然后运行镜像容器进行测试项目能否正常运行。
创建Dockerfile:
# 使用openjdk:8作为基础镜像 FROM openjdk:8 # 将app.jar文件拷贝到/tmp目录下 COPY red-packet-rain-0.0.1.jar /tmp # 设置工作目录为/tmp WORKDIR /tmp # 运行命令,启动Java应用程序 CMD java -jar red-packet-rain-0.0.1.jar
构建镜像容器:
docker build -t red-packet-rain-0.0.1.jar:1.0 .
运行镜像容器:
docker run --name red-packet-rain -p 8097:8097 red-packet-rain-0.0.1.jar:1.0
有红框标识出现说明正常启动了
浏览器访问:http://139.224.1.121:8097/api/v3/test
jemter压测受限的因素有很多,如果是本地机器运行jemter进行压测,主要受限于带宽。云服务器压测主要受限于云盘。由于我本地用的是手机热点,带宽不够,所以压不到过万的请求,更别说千万级别的请求了,所以将压测服务弄到云服务器上。
vim /etc/profile
将jdk和jemter添加到文件尾部:
export JAVA_HOME=/opt/jdk1.8.0_291 export JMETER_HOME=/opt/app/JMeter5.4.1/apache-jmeter-5.4.1 export PATH=$JMETER_HOME/bin:$PATH export PATH=$JAVA_HOME/bin:$PATH
使其生效:
source /etc/profile
配置好相关的jemter压测文件,然后上传到云服务器上,执行以下命令
jmeter -n -t /opt/app/JMeter5.4.1/apache-jmeter-5.4.1/testpain/1.jmx -l redtest1.jtl
推送到阿里云仓库文档:
https://cr.console.aliyun.com/repository/cn-shanghai/red_packet_rain/red_packet_rain/details
docker login --username=javaliaozhiwei registry.cn-shanghai.aliyuncs.com docker tag [ImageId] registry.cn-shanghai.aliyuncs.com/red_packet_rain/red_packet_rain:[镜像版本号] docker push registry.cn-shanghai.aliyuncs.com/red_packet_rain/red_packet_rain:[镜像版本号]
找另一台机器拉取镜像测试是否可用:
docker pull registry.cn-shanghai.aliyuncs.com/red_packet_rain/red_packet_rain:1.0
复制镜像容器
搜索ACK创建集群
创建后不可用
分别看诊断结果
第一个问题是拉取镜像失败
判断应该是权限认证没有配置,使用免密组件拉取容器镜像,文档地址:
第二个问题是Pod不满足调度约束无法被调度,在异常页面左边有一个节点池,点伸缩就可以扩容,伸缩是目标的节点数,不是伸缩多少台。2个节点只能有一个镜像容器,多了会提示资源不够,4个节点只能有3个镜像容器,多了也是一样提示资源不够,5个节点则是最多4个镜像容器,后面以此类推。
然后又提示Pod的Sandbox容器创建失败
容器网络FAQ文档地址:https://help.aliyun.com/zh/ack/ack-managed-and-ack-dedicated/user-guide/faq-about-container-networks
等待工单回复,后期继续更新