学堂 学堂 学堂公众号手机端

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

lewis 5年前 (2020-06-12) 阅读数 7 #技术
docker搭建图片压测QPS3000+服务器(ftp+nginx)在针对图片算法服务进行压力测试时,需要高性能的图片服务器自己编写的图片应用性能不一定能达到要求可能因为图片应用自身达不到压测要求,影响算法服务的压测数据准备工作

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

步骤参数项目keyvalue地址IP192.168.0.2ftp用户名FTP_USERNAMEftpuserftp密码FTP_PASSWORDabc@123宿主机保存目录FTP_PATH/var/ftpftp地址FTP_URLftp://192.168.0.2/图片请求地址PHOTO_URLhttp://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.04CPU4核内存8G硬盘120G网络万兆内网软件新系统系统,仅安装dockerJmeter、图片参数项目值线程数1000时长180s(3min)图片分辨率640*352图片平均大小30 - 40 kb/张Jmeter结果

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

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

Jmeter原始报告如下:

LabelSampleAverageMinMaxstd.Dev.Error%ThroughputReceived KB/secSent KB/secAvg. BytesTOTAL591303302170716341.850.00%3257.8/sec102582.08555.4232243.4服务器参数

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

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

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

版权声明

本文仅代表作者观点,不代表博信信息网立场。

热门