【小实验】使用 wrk 的 docker 容器来压测另一个容器
作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢!
GET 请求
想压测容器环境的服务性能,发现两个麻烦:
- 本地使用 wrk,由于本地网络和容器服务器很远,压测效果不好;
- wrk 找不到一个独立的二进制版本可以下载;go-wrk 完全不可用。
然后发现 hub.docker.com 上有 wrk 的镜像。
于是用下面的方法启动容器进行压测:
pod_wrk.yaml
apiVersion: v1
kind: Pod
metadata:
name: wrk
labels:
app.kubernetes.io/name: proxy
spec:
containers:
- name: wrk
image: williamyeh/wrk:4.0.2 # hub.docker.com 上的镜像
command: ["/usr/local/bin/wrk"]
args: ["-t10","-c600","-d120s","--latency","-H","X-Forwarded-proto: http","-H","X-Forwarded-For: 220. xxx.1.xxx,xxxx","-H","Host: 1.a.com","http://xx.xxx.0.71:32101/abc?size=10"]
resources:
requests:
memory: "512Mi"
cpu: "2"
limits:
memory: "2048Mi"
cpu: "2"
然后用下面的方法启动容器:
kubectl apply -f stress_test/pod_wrk.yaml --namespace=my-test-devops
压测时间是 120 秒,过后容器会再次启动。不需要压测的时候可以这样删除:
kubectl delete pods wrk --namespace=my-test-devops
POST 请求
wrk 的 post 请求要用到 Lua。
Lua 的文件内容可以放到 configMap 中。
下面是一个完整的例子:
pod_wrk.yaml
apiVersion: v1 # 第一段建一个 congfigMap
data:
post_json.lua: |
wrk.method = "POST"
wrk.body = "{\"param1\":\"123\",\"param2\":\"456\",\"client_ip\":\"10.xx.0.71\",\"extra_args\":\"\",\"path\":\"\",\"schema\":\"\"}"
wrk.headers["Content-Type"] = "application/json"
kind: ConfigMap
metadata:
name: wrk-lua-post-json
---
apiVersion: v1 # 第二段建立容器
kind: Pod
metadata:
name: wrk
labels:
app.kubernetes.io/name: wrk
spec:
containers:
- name: wrk
image: williamyeh/wrk:4.0.2
command: ["/usr/local/bin/wrk"]
args: ["-t10","-c500","-d60s","--latency","http://10. xxx.0.71/api/v1/GetURL","-s", "/app/lua/post_json.lua"]
resources:
requests:
memory: "512Mi"
cpu: "4"
limits:
memory: "2048Mi"
cpu: "4"
volumeMounts:
- name: config-volume
mountPath: /app/lua/
volumes:
- name: config-volume
configMap:
name: wrk-lua-post-json
创建 configMap 和容器
kubectl apply -f pod_wrk.yaml --namespace=test-devops
查看压测结果
kubectl logs wrk --namespace=test-devops
一组容器压测
有时候担心单个进程的并发度有限,无法提供足够的压力。这时就可以部署一组容器来压测:
- Deployment_wrk.yaml
apiVersion: v1
data:
post_json.lua: |
wrk.method = "POST"
wrk.body = "{\"fields\":\"123\",\"field2\":\"456\"}"
wrk.headers["Content-Type"] = "application/json"
kind: ConfigMap
metadata:
name: wrk-lua-post-json
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: deployment-wrk
name: deployment-wrk
spec:
progressDeadlineSeconds: 600
replicas: 5
revisionHistoryLimit: 10
selector:
matchLabels:
app: deployment-wrk
strategy:
rollingUpdate:
maxSurge: 1
maxUnavailable: 0
type: RollingUpdate
template:
metadata:
creationTimestamp: null
labels:
app: deployment-wrk
spec:
affinity: {}
containers:
- name: wrk
image: williamyeh/wrk:4.0.2
imagePullPolicy: IfNotPresent
command: ["/usr/local/bin/wrk"]
args:
- "-t2"
- "-c100"
- "-d120s"
- "--latency"
- "http://10.xxx.0.71:8080/api/v1/GetList"
- "-s"
- "/app/lua/post_json.lua"
resources:
requests:
memory: "512Mi"
cpu: "1"
limits:
memory: "2048Mi"
cpu: "1"
volumeMounts:
- name: config-volume
mountPath: /app/lua/
volumes:
- name: config-volume
configMap:
name: wrk-lua-post-json
- replicas 这里启动 5 个容器来压测
- 创建容器:
kubectl apply -f Deployment_wrk.yaml --namespace=test-devops
- 查看结果,写个稍稍复杂一点的 shell:
while true; do (kubectl logs --selector app=deployment-wrk --namespace=test-devops | grep "Requests/sec";sleep 5); done- 也可以把所有结果过滤出来,便于统计:
kubectl logs --selector app=deployment-wrk --namespace=test-devops | grep "Requests/sec" | awk '{print $2}'
Have fun.
【小实验】使用 wrk 的 docker 容器来压测另一个容器的更多相关文章
- docker搭建图片压测QPS3000+服务器(ftp+nginx)
docker搭建图片压测QPS3000+服务器(ftp+nginx) 在针对图片算法服务进行压力测试时,需要高性能的图片服务器 自己编写的图片应用性能不一定能达到要求 可能因为图片应用自身达不到压测要 ...
- docker学习-lnmp+redis之搭建mysql容器服务
一. 前期准备工作,创建配置文件目录,log文件目录,数据库DATA和WEB站点目录[root@T1 ~]# mkdir -p /lnmp/conf/{mysql,nginx,php} /lnmp/l ...
- 入手Docker容器注意事项:命令结束容器退出
在没有 docker 容器的时候,在终端(terminal)中运行 shell 命令,我们知道当终端退出时(比如关闭终端窗口或退出 ssh 会话),终端中执行的命令也会结束.所以,当我们在终端中执行持 ...
- Http压测工具wrk使用指南
用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...
- Http压测工具wrk使用指南【转】
用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...
- wrk 及扩展支持 tcp 字节流协议压测
wrk 及扩展支持 tcp 字节流协议压测 高性能.方便使用的 HTTP(s) 的流量压测工具,结合了多个开源项目开发而成: redis 的 ae 事件框架 luajit openssl http-p ...
- Docker:使用Ambassador进行跨主机间容器通信
转载请注明出处:点我 由于Docker自身的网络的原因,想要在多主机间的容器之间进行通信是比较麻烦的事情.可以利用Ambassador容器来实现这一功能. 基本原理: 利用Ambassador来实现主 ...
- Docker学习笔记之运行和管理容器
0x00 概述 容器是基于容器技术所建立和运行的轻量级应用运行环境,它是 Docker 封装和管理应用程序或微服务的“集装箱”.在 Docker 中,容器算是最核心的部分了,掌握容器的操作也是 Doc ...
- docker,容器,编排,和基于容器的系统设计模式
目录 从容器说起 背景 docker实现原理 编排之争 基于容器的分布式系统设计之道 单节点协作模式 Sidecar pattern(边车模式) Ambassador pattern(外交官模式) A ...
- Docker 实战(3)- 搭建 Gitlab 容器并上传本地项目代码
如果你还想从头学起 Docker,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1870863.html 搭建 Gitlab 容器 搜索 ...
随机推荐
- 手把手教你如何配置DBeaver对接FusionInsigth MRS Spark2x
摘要:dbeaver是免费和开源为开发人员和数据库管理员通用数据库工具.本文介绍如何配置dbeaver对接FusionInsigth MRS Spark2x. 本文分享自华为云社区<DBeave ...
- 如何配置Apple推送证书 push证书
转载:如何配置Apple推送证书 push证书 想要制作push证书,就需要使用快捷工具appuploader工具制 作证书,然后使用Apple的推送功能配置push证书,就可以得到了.PS:pu ...
- iOS App Store上架流程详解
很多开发者在开发完iOS APP.进行内测后,下一步就面临上架App Store,不过也有很多同学对APP上架App Store的流程不太了解,下面我们来说一下iOS APP上架App Store ...
- 大数据-业务数据采集-FlinkCDC DebeziumSourceFunction via the 'serverTimezone' configuration property
Caused by: org.apache.kafka.connect.errors.ConnectException: Error reading MySQL variables: The serv ...
- Bug定级实例
*1级,**系统崩溃* *定义:*严重阻碍测试和开发工作 *对应**优先级**:**最高* *具体可分为:* 1.功能完全没有实现 2.应用闪退/崩溃无法运行 3*.应用必现安全模式,无法运行* 4. ...
- 在WPF应用中使用FastReport.WPF报表模块
FastReport是一个非常不错的报表组件,在Winform应用中常常使用它进行报表的设计.预览展现.打印或者导出文件(PDF.Excel)等,可以设计打印各种各样的报表,本篇随笔继续介绍当前最新的 ...
- Java ZIP文件解压
Java ZIP文件解压 备忘笔记 代码: private byte[] unZip(byte[] data) { byte[] bArr = null; try { ByteArrayInputSt ...
- JSP | 常见 JSP 简答题
一.简述 JSP 的工作原理 当我们访问一个JSP页面的时候,这个文件首先会被JSP引擎翻译为一个Java源文件,其实就是一个Servlet,并进行编译,然后像其他Servlet一样,由Servlet ...
- <vue 基础知识 4、计算属性computed>
代码结构 一. 计算属性简单使用 1.效果 2.代码 01-计算属性简单用法.html <!DOCTYPE html> <html lang="en"&g ...
- K8s 网关选型血泪史
Sealos 公有云几乎打爆了市面上所有主流的开源网关,本文可以给大家很好的避坑,在网关选型方面做一些参考. Sealos Cloud 的复杂场景 Sealos 公有云上线以来,用户呈爆发式增长,目前 ...
