【ACK秒级部署】20万用户在10秒处理所有请求每个用户每秒5次请求

2023-12-02 12:30

本文主要是介绍【ACK秒级部署】20万用户在10秒处理所有请求每个用户每秒5次请求,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

准备环境: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创建集群
文档与视频操作:https://help.aliyun.com/zh/ack/ack-managed-and-ack-dedicated/getting-started/getting-started-with-ack-using-kubectl?spm=a2c4g.11186623.0.0.72e11a99VUIajK

在这里插入图片描述在这里插入图片描述创建后不可用
在这里插入图片描述分别看诊断结果

第一个问题是拉取镜像失败
在这里插入图片描述在这里插入图片描述判断应该是权限认证没有配置,使用免密组件拉取容器镜像,文档地址:
https://help.aliyun.com/zh/ack/ack-managed-and-ack-dedicated/user-guide/use-the-aliyun-acr-credential-helper-component-to-pull-images-without-using-secrets?spm=a2c4g.11186623.0.0.8dc32dbfDVQbco

第二个问题是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

等待工单回复,后期继续更新

这篇关于【ACK秒级部署】20万用户在10秒处理所有请求每个用户每秒5次请求的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/445346

相关文章

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以