Jmeter压测监控体系搭建Docker+Influxdb+Grafana
章节目录:
- 一、背景介绍
- 1.1 概述
- 1.2 拓扑图
- 二、云服务器设置
- 三、Docker
- 3.1 概述
- 3.2 搭建流程
- 3.3 安装验证
- 3.4 配置docker镜像加速
- 3.5 取消sudo运行(可选操作)
- 四、InfluxDB
- 4.1 镜像拉取
- 4.2 运行数据库
- 4.3 创建存储 jmeter 数据的库
- 五、Grafana
- 5.1 镜像拉取
- 5.2 关联 influxdb
- 5.3 进入控制台
- 5.4 数据源配置
- 5.5 控制板配置
- 六、Jmeter
- 七、大屏监控展示
- 八、数据库查看
- 九、结束语
一、背景介绍
我们都知道 Jmeter 提供了原生的结果查看,既然有原生的查看结果,为什么还要多此一举使用其他工具进行查看呢?
1.1 概述
-
除了查看内容丰富外还有最主要的原因:
-
Jmeter 提供的查看结果插件本身是比较消耗性能的,所以在正式压测中应当禁用。
-
结果只能自己看,无法实时共享。
-
报告信息的展示比较简陋单一,不直观。
-
-
提示:此次使用个人的阿里云服务器,搭建了该体系,后面只需要单独配置 Jmeter 的 Backend Listener 元件就可以做到任意项目且随时随地监控,一定程度上提升了复用性。
1.2 拓扑图
二、云服务器设置
- 端口开放:
三、Docker
3.1 概述
简介:Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口,更重要的是容器性能开销极低。
- 三大优点:
- 搭建测试环境,保证测试环境的一致,避免因环境原因造成的互相甩锅。
- 搭建各类基础服务,例如禅道,Jenkins 等,极大降低学习成本!
- 搭建测试执行环境,例如我们运行自动化测试的环境,随用随建,不用即扔。
3.2 搭建流程
# 1.旧版本卸载。
$ sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine# 2.使用存储库安装。
$ sudo yum install -y yum-utils
$ sudo yum-config-manager \--add-repo \https://download.docker.com/linux/centos/docker-ce.repo# 3.安装docker引擎。
$ sudo yum install docker-ce docker-ce-cli containerd.io# 4.启动docker。
$ sudo systemctl start docker# 5.使用开机自启。
$ sudo systemctl enable docker
3.3 安装验证
# 1.查看docker版本号。
$ docker version
3.4 配置docker镜像加速
# 1.创建目录。
$ sudo mkdir -p /etc/docker# 2.配置阿里云镜像。
$ sudo tee /etc/docker/daemon.json <<-'EOF'{"registry-mirrors": ["https://2jakrmvh.mirror.aliyuncs.com"]}EOF# 3.重新加载配置。
$ sudo systemctl daemon-reload# 4.重启docker。
$ sudo systemctl restart docker
3.5 取消sudo运行(可选操作)
# 1.root为当前用户的名字 或 $USER
$ sudo usermod -aG docker root
四、InfluxDB
简介:InfluxDB是一个开源分布式的时序、事件和指标数据库。使用 Go 语言编写,无需外部依赖。其设计目标是实现分布式和水平伸缩扩展。
-
三大特性:
-
Time Series(时间序列):你可以使用与时间有关的相关函数。(如最大,最小,求和等)
-
Metrics(度量):可以实时对大量数据进行计算。
-
Eevents(事件):它支持任意的事件数据。
-
4.1 镜像拉取
$ docker pull influxdb:1.7.10
4.2 运行数据库
- 启动镜像:
# 1.创建 influxdb 镜像。
$ docker run -d --name=influxdb -p 8086:8086 -v ${PWD}:/var/lib/influxdb influxdb:1.7.10# 2.进程查看。
$ docker ps# 3.镜像启动。(未启动进程时,使用该命令)
$ sudo docker start influxdb
docker
run 参数说明:
# 1.docker run 参数格式:docker run [OPTIONS] IMAGE [COMMOND] [ARGS...]# 2. OPTIONS 说明--name="容器新名字": 为容器指定一个名称-d: 后台运行容器,并返回容器ID,也即启动守护式容器-i:以交互模式运行容器,通常与 -t 同时使用-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用-P: 随机端口映射-p: 指定端口映射,有以下四种格式ip:hostPort:containerPortip::containerPorthostPort:containerPortcontainerPort-v, --volume=[] 给容器挂载存储卷,挂载到容器的某个目录--link=[] 指定容器间的关联,使用其他容器的IP、env等信息--rm:容器停止自动删除容器
4.3 创建存储 jmeter 数据的库
- 进入终端操作:
# 1.交互模式进入 influxdb 终端。
$ docker exec -it influxdb bash# 2.进入shell模式。# influx# 3.查看库。> show databases;# 4.创建名为jmeter的数据库。> create database jmeter# 5.使用库,并查看该库的表。> use jmeter> show measurements
五、Grafana
简介:它是一个跨平台的开源的多用途的监控工具,同时通过邮件等方式进行有效的预警通知,丰富的直观的可视化界面,多种数据源配置是其优点所在。
5.1 镜像拉取
$ docker pull grafana/grafana:6.6.2
5.2 关联 influxdb
# 1.关联 influxdb 指定端口及版本号。
$ docker run -d --name=grafana --link=influxdb:influxdb -p 3000:3000 grafana/grafana:6.6.2# 2.进程查看。
$ docker ps# 3.镜像启动。(未启动进程时,使用该命令)
$ sudo docker start grafana
5.3 进入控制台
- 浏览器输入[ip:3000]进行访问
5.4 数据源配置
- 添加数据源
- 配置项
- 保存
5.5 控制板配置
- 选择导入:
- 引入模板ID:
- 模板保存:
六、Jmeter
- Backend Listener监听元件设置
七、大屏监控展示
八、数据库查看
九、结束语
“-------怕什么真理无穷,进一寸有一寸的欢喜。”
微信公众号搜索:饺子泡牛奶。
相关文章:
Jmeter压测监控体系搭建Docker+Influxdb+Grafana
章节目录: 一、背景介绍1.1 概述1.2 拓扑图 二、云服务器设置三、Docker3.1 概述3.2 搭建流程3.3 安装验证3.4 配置docker镜像加速3.5 取消sudo运行(可选操作) 四、InfluxDB4.1 镜像拉取4.2 运行数据库4.3 创建存储 jmeter 数据的库 五、Grafana5.1 镜像拉取5.2 关联…...
TDesign 点击高亮显示=》点击切换class类名
1. wx:for遍历数组 2. 在一行显示 2. 点击高亮...
容器编排学习(二)镜像制作和私有仓库介绍
一 Dockerfile 1 概述 commit的局限 很容易制作简单的镜像,但碰到复杂的情况就十分不方便例如碰到下面的情况需要设置默认的启动命令需要设置环境变量需要指定镜像开放某些特定的端口 Dockerfile就是解决这些问题的方法 Dockerfile是一种更强大的镜像制作方式…...
tcp记录
网络传输:大小端 Qt网络编程实现TCP通信 TCP/IP通讯与socket编程 Qt一步步搭建TcpServer1——封装QTcpServer,QTcpSocket qtcpserver官方文档 Python address already in use 服务器端的端口号和客户端的端口号没有关系 一般服务器是需要BIND指定端口号…...
IDEA中使用Java连接MySQL数据库的配置和使用方法
文章目录 IDE和必要配置数据库连接代码 IDE和必要配置 IDE:IntelliJ IDEA 2023.1 必要配置: 1、安装好JDK,并且配置环境变量 2、导入MYSQL数据库所需的驱动 如果没有导入,可以参考这篇文章IDEA中的MySQL数据库所需驱动包的下载和…...
android——服务JobService
JobService是Android L时候官方新增的组件,适用于需要特定条件才执行后台任务的场景。由系统统一管理和调度,在特定场景下使用JobService更加灵活和省心,相当于是Service的加强或者优化。 JobService是JobScheduler的回调,是安排的…...
一文讲清楚redis的线程池jedis
背景 在shigen实习的时候,遇到了日志系统的性能优化问题,当时的优化点就是:使用redis的线程池,实现并发状态下的性能优化。但是找了很多的技术方案,发现redis的线程池配置起来比较麻烦。正巧,这个周末shig…...
备战面试每日一题
1.如何理解this? this表示的是函数运行时自动生成的一个内部对象,只能在函数内部使用,总是指向调用它的对象。 this是在运行时进行绑定的,并不是在编写的时候绑定,它的上下文取决于函数调用时的各种条件。this的绑定…...
【嵌入式数据库之sqlite3】
目录 一.数据库基本概念(理解) 1.数据 2.数据库 二.常用的数据的数据库(了解) 1.大型数据库 2.中型数据库 3.小型数据库 三.基于嵌入式的数据库(了解) 四.SQLite基础(了解)…...
Android 9.0 pms中关于启动app时获取app的ActivityInfo信息相关源码分析
1.前言 在android9.0的系统rom定制化开发中,在对于app启动时,在进行系统中,通过Launcher调用pms来查询app的相关ActivityInfo的相关信息,然后调用 ams来启动activity,这篇来分析pms中获取app的ActivityInfo的相关信息的相关源码分析 2.pms中关于启动app时获取app的Activ…...
华为数通方向HCIP-DataCom H12-821题库(单选题:321-340)
第321题 BGP的Open报文是用于建立对等体连接的,以下哪一项不属于Open报文中携带的参数信息? A、发送者的Router ID B、AS号 C、BGP版本号 D、TCP端口号 答案:D 解析:以下是BGP的Open报文: 第322题 在建立BGP对等体的过程中,OpenSent状态表明BGP等待的Open报文 并对收…...
《TCP/IP网络编程》阅读笔记--基于TCP的服务器端/客户端
目录 1--TCP/IP协议栈 2--TCP服务器端默认函数调用顺序 3--TCP客户端的默认函数调用顺序 4--Linux实现迭代回声服务器端/客户端 5--Windows实现迭代回声服务器端/客户端 6--TCP原理 7--Windows实现计算器服务器端/客户端 1--TCP/IP协议栈 TCP/IP协议栈共分 4 层…...
【每日一题】43. 字符串相乘
43. 字符串相乘 - 力扣(LeetCode) 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。 注意:不能使用任何内置的 BigInteger 库或直接将输入转换为整数。 示例…...
机器学习——K最近邻算法(KNN)
机器学习——K最近邻算法(KNN) 文章目录 前言一、原理二、距离度量方法2.1. 欧氏距离2.2. 曼哈顿距离2.3. 闵可夫斯基距离2.4. 余弦相似度2.5. 切比雪夫距离2.6. 马哈拉诺比斯距离2.7. 汉明距离 三、在MD编辑器中输入数学公式(额外࿰…...
同步FIFO的verilog实现(1)——计数法
一、FIFO概述 1、FIFO的定义 FIFO是英文First-In-First-Out的缩写,是一种先入先出的数据缓冲器,与一般的存储器的区别在于没有地址线, 使用起来简单,缺点是只能顺序读写数据,其数据地址由内部读写指针自动加1完成&…...
python正则表达式笔记1
最近工作中经常用到正则表达式处理数据,慢慢发现了正则表达式的强大功能,尤其在数据处理工作中,记录下来分享给大家。 一、 正则表达式语法介绍 正则表达式(或 RE)指定了一组与之匹配的字符串;模块内的函…...
YOLO目标检测——口罩规范佩戴数据集+已标注xml和txt格式标签下载分享
实际项目应用:目标检测口罩佩戴检测数据集的应用场景涵盖了公共场所监控、疫情防控管理、安全管理与控制以及人员统计和分析等领域。这些应用场景可以帮助相关部门和机构更好地管理口罩佩戴情况,提高公共卫生和安全水平,保障人们的健康和安全…...
Android 13 - Media框架(9)- NuPlayer::Decoder
这一节我们将了解 NuPlayer::Decoder,学习如何将 MediaCodec wrap 成一个强大的 Decoder。这一节会提前讲到 MediaCodec 相关的内容,如果看不大懂可以先跳过此篇。原先觉得 Decoder 部分简单,越读越发现自己的无知,Android 源码真…...
23.09.5 《CLR via C#》 笔记5
第六章 类型和成员基础 类型可以定义0或多个以下成员:常量、字段、实例构造器、类型构造器、方法、操作符重载、转换操作符、属性、事件、类型类型的可见性分为public和internal(默认)C#中,成员的可访问性分为private、protected、internal、protected …...
laravel部署api项目遇到问题总结
laravel线上部署问题 一、Ubuntu远程Mysql 61“Connection refused”二、Ubuntu更新php8三、线上部署Permission denied3.1、部署完之后访问域名出现报错:3.2、The /bootstrap/cache directory must be present and writable. 四、图片访问404五、git部署线上文件 一…...
lintcode 1646 · 合法组合【字符串DFS, vip 中等 好题】
题目 https://www.lintcode.com/problem/1646 给一个单词s,和一个字符串集合str。这个单词每次去掉一个字母,直到剩下最后一个字母。求验证是否存在一种删除的顺序,这个顺序下所有的单词都在str中。例如单词是’abc’,字符串集合是{‘a’,’…...
【多线程】线程安全 问题
线程安全 问题 一. 线程不安全的典型例子二. 线程安全的概念三. 线程不安全的原因1. 线程调度的抢占式执行2. 修改共享数据3. 原子性4. 内存可见性5. 指令重排序 一. 线程不安全的典型例子 class ThreadDemo {static class Counter {public int count 0;void increase() {cou…...
【用unity实现100个游戏之11】复刻经典消消乐游戏
文章目录 前言开始项目开始一、方块网格生成二、方块交换三、添加交换的动画效果四、水平消除检测五、垂直消除检测六、完善删除功能七、效果优化(移动方块后再进行消除检测)八、方块下落十、方块填充十一、后续 源码参考完结 前言 欢迎来到经典消消乐游…...
若依cloud 修改包名等
一、项目的项目名。 先改pom 然后在重命名文件 1、 修改主pom.xml <artifactId>ruoyi-api</artifactId> 缓存 <artifactId>zxf-api</artifactId> <groupId>com.ruoyi</groupId> <groupId>com.zhixiaofeng</groupId> 2、…...
健康系统练习
健康系统 项目建构: 前后端分离,前端vue3,后端Java,springboot做跨域处理,前端将在vscode中 的tomcat下部署,后端将在ideal中集成的tomcat中部署 创建项目工程在ideal中直接选用springi…创建,…...
网络协议从入门到底层原理学习(一)—— 简介及基本概念
文章目录 网络协议从入门到底层原理学习(一)—— 简介及基本概念一、简介1、网络协议的定义2、网络协议组成要素3、广泛的网络协议类型网络通信协议网络安全协议网络管理协议 4、网络协议模型对比图 二、基本概念1、网络互连模型2、计算机之间的通信基础…...
centos密码过期导致navicat无法通过SSH登录阿里云RDS问题
具体错误提示:2013 - Lost connection to server at "hand hake: reading initial communication packet, system error: 0 解决办法:更新SSH服务器密码...
对于pytorch和对应pytorch网站的探索
一、关于网站上面的那个教程: 适合PyTorch小白的官网教程:Learning PyTorch With Examples - 知乎 (zhihu.com) 这个链接也是一样的, 总的来说,里面讲了这么一件事: 如果没有pytorch的分装好的nn.module用来继承的话,需要设计…...
和AI聊天:动态规划
动态规划 动态规划(Dynamic Programming,简称 DP)是一种常用于优化问题的算法。它解决的问题通常具有重叠子问题和最优子结构性质,可以通过将问题分解成相互依赖的子问题来求解整个问题的最优解。 动态规划算法主要分为以下几个步…...
微信小程序——使用插槽slot快捷开发
微信小程序的插槽(slot)是一种组件化的技术,用于在父组件中插入子组件的内容。通过插槽,可以将父组件中的一部分内容替换为子组件的内容,实现更灵活的组件复用和定制。 插槽的使用步骤如下: 在父组件的wx…...
wordpress项目需求/南京seo排名公司
知己知彼百战不殆 无论你要学习技能,你首先要知道这个技能应该学习哪些内容,把这些内容都学会是否能找到一份工作,这是在开始的时候必须了解的,如果连学习什么内容都不知道,就无从开始。所以首先了解2019年Java技术栈…...
商务咨询网站源码/网站设计的流程
1,第一步安装brew。 https://brew.sh/index_zh-cn.html 2,用brew安装jdk。 brew update brew cask install java 安装完成后就可以执行JAVA相关的操作 3,用brew安装git。 brew update brew install git 4,用brew安装gradle brew u…...
新疆教育集团网站建设/大二网络营销实训报告
很多商家朋友说自己做店铺没有什么头绪,不知道该怎么做也不知道自己哪里不足。这种情况其实对于做店铺来说是很可怕的一件事。做店铺,一定要理清目的,知道我们每个阶段所要去实现的效果,并且要针对运营过程中的核心痛点来操作&…...
网站建设忄金手指专业/优化关键词推广
逻辑回归原理介绍及Matlab实现 原文:逻辑回归原理介绍及Matlab实现版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/laobai1015/article/details/78113214 一、逻辑回归基本概念 1. 什么是逻辑回归 逻辑回归就是这样的一个过…...
请简述网站建设的一般流程图/信息流广告接单平台
独悲需要忍受,快乐需要分享 对Linux协议栈多次perf的结果,我无法忍受conntrack的性能,然而它的功能是如此强大,以至于我无法对其割舍,我想自己实现一个快速流表,但是我不得不抛弃依赖于conntrack的诸多功能…...
江门网站优化经验/东莞网站建设最牛
1、安装 一、安装更新Nuget 打开VS菜单“工具”->"扩展与更新"安装更新nuget 二、修改Nuget镜像 打开VS“工具”->“选项”菜单找到“NuGet包管理器”添加https://nuget.cnblogs.com/v3/index.jsonhttp://api.nuget.org/v3/index.jsonhttps://www.nuget.org/ap…...