美文网首页
docker搭建图片压测QPS3000+服务器(ftp+ngin

docker搭建图片压测QPS3000+服务器(ftp+ngin

作者: 言午日尧耳总 | 来源:发表于2022-07-26 08:56 被阅读0次

docker搭建图片压测QPS3000+服务器(ftp+nginx)

  1. 在针对图片算法服务进行压力测试时,需要高性能的图片服务器
  2. 自己编写的图片应用性能不一定能达到要求
  3. 可能因为图片应用自身达不到压测要求,影响算法服务的压测数据

准备工作

需要在服务器先安装好docker,性能结果看文章结尾

步骤

  • 参数
项目 key value
地址 IP 192.168.0.2
ftp用户名 FTP_USERNAME ftpuser
ftp密码 FTP_PASSWORD abc@123
宿主机保存目录 FTP_PATH /var/ftp
ftp地址 FTP_URL ftp://192.168.0.2/
图片请求地址 PHOTO_URL http://192.168.0.2/ftpuser/**
  • shell中设置变量(根据自己的实际参数去设置)
export IP=192.168.0.2       # 服务器ip
export FTP_USERNAME=ftpuser # ftp账号
export FTP_PASSWORD=abc@123 # ftp密码
export FTP_PATH=/var/ftp   # 图片上传根目录
export FTP_DOCKER_NAME=ftp  # ftp容器名称
export NGINX_DOCKER_NAME=nginx  # nginx容器名称

安装ftp

  • 创建文件目录
mkdir ${FTP_PATH}
  • 启动容器
docker pull fauria/vsftpd
docker run -d \
    --name ${FTP_DOCKER_NAME} \
    --restart=always \
    -p 20:20 \
    -p 21:21 \
    -p 21100-21110:21100-21110 \
    -v ${FTP_PATH}:/home/vsftpd \
    -e FTP_USER=${FTP_USERNAME} \
    -e FTP_PASS=${FTP_PASSWORD} \
    -e PASV_ADDRESS=${IP} \
    -e PASV_MIN_PORT=21100 \
    -e PASV_MAX_PORT=21110 \
    fauria/vsftpd

安装nginx

容器启动命令

docker pull nginx:latest
docker run -d \
    --name ${NGINX_DOCKER_NAME} \
    --restart=always \
    -p 80:80 \
    -v ${FTP_PATH}/${FTP_USERNAME}:/usr/share/nginx/html/${FTP_USERNAME} \
    nginx:latest

重要配置!(nginx)

  • 通过ftp上传的图片,访问会报403无权限错误

进入nginx容器,打开/etc/nginx/nginx.conf文件

user nginx;

改为

user root;

重启nginx容器

使用

  • 打开文件资源管理器,地址栏输入ftp地址,输入账号密码,即可上传图片
ftp://${IP}/
# 即
ftp://192.168.0.2/
  • 在浏览器中输入网页地址,,即可获取到图片
http://${IP}/${FTP_USERNAME}/${对应图片路径}
# 即
http://192.168.0.2/ftpuser/${对应图片路径}

性能

使用测试jmeter进行压力测试,返回200状态码判定为成功。

图片上传了1000张图片,循环获取持续3分钟

服务器配置

项目 配置
系统 Ubuntu22.04
CPU 4核
内存 8G
硬盘 120G
网络 万兆内网
软件 新系统系统,仅安装docker

Jmeter、图片参数

项目
线程数 1000
时长 180s(3min)
图片分辨率 640*352
图片平均大小 30 - 40 kb/张

Jmeter结果

由于是单个请求,QPS=TPS=3257.8/sec

该压测过程中,运行Jmeter的电脑CPU 100%,所以可能是运行电脑性能问题降低了压测结果,所以该结果仅供参考

Jmeter原始报告如下:

Label Sample Average Min Max std.Dev. Error% Throughput Received KB/sec Sent KB/sec Avg. Bytes
TOTAL 591303 302 1 70716 341.85 0.00% 3257.8/sec 102582.08 555.42 32243.4

服务器参数

以下统计使用MobaXterm软件连接工具数值,非专业工具,仅供参考

项目 状态 数值
CPU 压测前 0%
CPU 压测中 40% - 70%
内存 压测前 0.76G
内存 压测中 0.77G
总内存 - 7.75G
Upload 压测前 0.01 Mb/s
Upload 压测中 965.55 Mb/s
Download 压测前 0.01 Mb/s
Download 压测中 1871.02 Mb/s

总结

该方式搭建的图片服务器可以满足大部分压测场景,服务器CPU资源要求很高,内存资源要求低。

相关文章

  • docker搭建图片压测QPS3000+服务器(ftp+ngin

    docker搭建图片压测QPS3000+服务器(ftp+nginx) 在针对图片算法服务进行压力测试时,需要高性能...

  • Jmeter基于Docker的分布式压测

    Jmeter基于Docker的分布式压测 Jmeter基于docker分布式压测的测试环境搭建 在本机按照自己的习...

  • Docker安装Minio

    使用Minio搭建图片服务器,相比fastdfs使用Minio搭建文件服务器更方便。记得先安装docker。 官方...

  • SSH免密登录

    简单说下背景,这两天在搭建压测环境时,通过jenkins将项目部署到压测服务器,其中的一步就是设置ssh免密登录。...

  • 压测

    压测流程规范: 1. 压测机器申请 压测域名: 询问运维人员 压测机器: 看公司使用的服务器 例如:服务机器(...

  • 分布式压力测试-代码篇

    说明 主要用途是想用多机压测服务器端 可以组合任何平台,任意语言,任意压测方法,任意电脑等对服务器进行压测 设计思...

  • 游戏技术精华分享之游戏服务器压测

    游戏技术精华分享之游戏服务器压测 压测概述 早知道早幸福——从压测工具谈并发、压力、吞吐量 当压测遇见奥运 ——游...

  • 【5.2】portainer的使用 仓库配置

    docker的仓库搭建参考 【3.2】服务器安装 Docker中 仓库搭建[https://www.jiansh...

  • docker registry搭建及配置用户认证

    搭建Registry 服务器ip为:172.16.77.71 安装Docker Registry,Docker版本...

  • jmeter分布式压测练习(Windows)

    1 压测的接口: www.baidu.com 2 压测的服务器(目标机) 百度的服务器 3 相关配置: 3.1主控...

网友评论

      本文标题:docker搭建图片压测QPS3000+服务器(ftp+ngin

      本文链接:https://www.haomeiwen.com/subject/vcfoirtx.html