压测引擎数据库设计(上)

压测引擎数据库设计(上)

引言

        在当今快速发展的互联网时代,软件质量保证和性能测试变得尤为重要。自动化测试平台,提供了一套完整的解决方案,以确保软件产品在发布前能够满足性能和稳定性的要求。本文将深入探讨滴云自动化测试平台中的压测引擎数据库设计,分析其结构、功能以及如何支持自动化测试的各个环节。

压测引擎数据库设计概览      

        压测引擎是自动化测试平台中的核心组件之一,它负责管理和执行压力测试用例,收集测试数据,并生成测试报告。数据库设计是压测引擎功能实现的基础,涉及到项目、环境、压测用例模块、测试报告等多个方面的数据存储和管理。

项目(Project)表设计

项目表是整个数据库设计的基础,存储了项目的基本信息。以下是项目表的主要字段:

  • id: 项目的唯一标识符。
  • project_admin: 项目管理员的用户ID。
  • name: 项目名称。
  • description: 项目描述。
  • gmt_create: 项目创建时间。
  • gmt_modified: 项目最后修改时间。

SQL语句如下:

CREATE TABLE `project` (`id` bigint unsigned NOT NULL AUTO_INCREMENT,`project_admin` bigint unsigned DEFAULT NULL COMMENT '项目管理员ID',`name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '项目名称',`description` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '描述',`gmt_create` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

环境(Environment)表设计

环境表用于定义测试所需的不同环境配置,包括协议、域名和端口等信息。以下是环境表的主要字段:

  • id: 环境的唯一标识符。
  • project_id: 所属项目的ID。
  • name: 环境名称。
  • protocol: 协议类型。
  • domain: 环境域名。
  • port: 端口号。
  • description: 环境描述。

SQL语句如下:

CREATE TABLE `environment` (`id` bigint unsigned NOT NULL AUTO_INCREMENT,`project_id` bigint unsigned NOT NULL COMMENT '所属项目ID',`name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '环境名称',`protocol` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '协议',`domain` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '环境域名',`port` int unsigned NOT NULL COMMENT '端口',`description` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '描述',`gmt_create` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

压测用例模块(Stress Case Module)表设计

压测用例模块表存储了压力测试的各个模块信息,每个模块可以包含多个具体的测试用例。以下是压测用例模块表的主要字段:

  • id: 模块的唯一标识符。
  • project_id: 所属项目的ID。
  • name: 接口模块名称。
  • gmt_create: 模块创建时间。
  • gmt_modified: 模块最后修改时间。

SQL语句如下:

CREATE TABLE `stress_case_module` (`id` bigint unsigned NOT NULL AUTO_INCREMENT,`project_id` bigint unsigned DEFAULT NULL COMMENT '所属项目ID',`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '接口模块名称',`gmt_create` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`),UNIQUE KEY `name` (`name`)
) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

压测引擎的工作原理

压测引擎的工作原理可以概括为以下几个步骤:

  1. 项目配置:首先,管理员需要在项目表中配置项目基本信息。
  2. 环境设置:接着,根据测试需求设置不同的测试环境。
  3. 用例设计:设计压力测试用例,并将其归类到不同的模块中。
  4. 测试执行:执行压力测试,收集数据。
  5. 结果分析:分析测试结果,生成测试报告。

E-R图

实体间关系

项目与环境

  • 关系类型:一对多(One-to-Many)
  • 描述:一个项目可以拥有多个环境配置,但每个环境配置只属于一个项目。
  • 关系表示:从Environment实体指向Project实体,Environment中的project_id是外键,引用Projectid

项目与压测用例模块

  • 关系类型:一对多(One-to-Many)
  • 描述:一个项目可以包含多个压测用例模块,但每个压测用例模块只属于一个项目。
  • 关系表示:从StressCaseModule实体指向Project实体,StressCaseModule中的project_id是外键,引用Projectid

压测用例模块与压测用例

  • 关系类型:一对多(One-to-Many)
  • 描述:一个压测用例模块可以包含多个具体的压测用例,但每个压测用例只属于一个模块。
  • 关系表示:从StressCase(假设的压测用例实体)指向StressCaseModule实体,StressCase中的某个字段(例如module_id)是外键,引用StressCaseModuleid

环境与压测用例

  • 关系类型:多对多(Many-to-Many)
  • 描述:一个环境可以执行多个压测用例,一个压测用例也可以在多个环境中执行。
  • 关系表示:通常需要通过一个关联表(例如EnvironmentStressCase)来实现这种关系,该表包含外键environment_idstress_case_id,分别引用EnvironmentStressCaseid

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/43207.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jmeter-beanshell学习6-beanshell生成测试报告

前面写了各种准备工作,内容组合用起来,应该能做自动化了,最后一步,生成一个报告,报告格式还是csv 报告生成的路径和文件,在用户参数写好,防止以后改路径或者名字,要去代码里面改。以…

[AHK V2]AHK能取消正常窗口的双击标题栏最大化事件吗?

问题: AHK能取消正常窗口的双击标题栏最大化事件吗? 解答: AutoHotkey (AHK)是一个强大的脚本语言,可以用来自定义键盘快捷键、鼠标操作等。如果你想阻止双击Windows标题栏进行最大化操作,你可以编写一个脚本来拦截…

Django自动生成Swagger接口文档 —— Python

1. 前言 当接口开发完成,紧接着需要编写接口文档。传统的接口文档通常都是使用Word或者一些接口文档管理平台进行编写,但此类接口文档维护更新比较麻烦,每次接口有变更,需要手动修改接口文档。在实际的工作中,经常会遇…

tomcat的优化和tomcat和nginx实现动静分离:

tomcat的优化 tomcat自身的优化 tomcat的并发处理能力不强。大项目不使用tomcat做为转发动态的中间件(k8s集群,python,rubby),小项目会使用(内部使用),动静分离。 优化tomcat的启动…

Python入门 2024/7/8

目录 数据容器 dict(字典,映射) 语法 定义字典字面量 定义字典变量 定义空字典 从字典中基于key获取value 字典的嵌套 字典的常用操作 新增元素 更新元素 删除元素 清空字典 获取全部的key 遍历字典 统计字典内的元素数量 练习 数据容器的通用操作…

linux环境下echo命令简单测试端口是否连通——筑梦之路

语法格式 echo > /dev/tcp/目标主机地址/端口号 示例 echo > /dev/tcp/example.com/80 当命令执行后,若端口是开放的,命令不会有任何输出并且会立即返回命令提示符;若端口未开放或连接失败,则可能由于网络问题、防火墙限…

在公司的业务杂记1之多选部门且主表没有部门字段(子表查询)

原型 1.新建,上传报告可多选部门 2.查询,可多选部门 数据库(Postgresql) 方式一 新增字段Jsonb: CREATE TABLE public.admin_report (admin_report_uuid uuid DEFAULT gen_random_uuid() NOT NULL,admin_report_tit…

java —— JSP 技术

一、JSP &#xff08;一&#xff09;前言 1、.jsp 与 .html 一样属于前端内容&#xff0c;创建在 WebContent 之下&#xff1b; 2、嵌套的 java 语句放置在<% %>里面&#xff1b; 3、嵌套 java 语句的三种语法&#xff1a; ① 脚本&#xff1a;<% java 代码 %>…

安全防御第三天(笔记持续更新)

1.接口类型以及作用 接口 --- 物理接口 三层口 --- 可以配置IP地址的接口 二层口 普通二层口 接口对 --- “透明网线” --- 可以将一个或者两个接口配置成为接口对&#xff0c;则 数据从一个接口进&#xff0c;将不需要查看MAC地址表&#xff0c;直接从另一个接口出&#xff1b…

机器学习模型运用在机器人上

机器学习模型在机器人技术中的应用非常广泛&#xff0c;涵盖了从简单的运动控制到复杂的认知和交互功能。以下是几种机器学习模型在机器人上的典型应用&#xff1a; 感知与识别&#xff1a; 计算机视觉&#xff1a;使用卷积神经网络&#xff08;CNNs&#xff09;识别和理解视觉…

汇川CodeSysPLC教程 Modbus变量编址

线圈&#xff1a;位变量&#xff0c;只有两种状态0和1。汇川PLC中包含Q区及SM区等变量。 寄存器&#xff1a;16位&#xff08;字&#xff09;变量&#xff0c;本PLC中包含M区及SD区等变量 说明&#xff1a; 汇川HMI的专用协议使用不同功能码&#xff1a;在访问SM时&#xff0c…

Python--并发编程--协程

概念 协程是轻量级的线程&#xff0c;它是程序员管理的并发机制&#xff0c;使得在一个线程中程序可以在多个函数之间交替运行。 Python中主要通过asyncio模块实现协程。 协程函数 用async修饰的函数 import asyncio# func为协程函数 async def func():await asyncio.slee…

Linux开发:进程间通过Unix Domain Socket传递文件描述符

Linux开发:进程间通过Unix Domain Socket传递数据-CSDN博客 介绍了通过UDS传递数据 实际上当需要传递大量的数据时,可以通过UDS直接传递文件描述符,这样接收文件描述符的一方,可以直接从传递过来的文件描述符读取数据 先举例说明: //uds_fd.hpp #pragma once #include &…

时尚品牌GOODBAI好人好事系列纪录片——Jupiter乐队的热血与梦想

时尚品牌GOODBAI推出的好人好事系列纪录片迎来了第二期&#xff0c;本期特别邀请了充满年轻活力的Jupiter乐队。纪录片通过真实的镜头&#xff0c;记录了他们在排练室中充满热血和灵感的创作过程&#xff0c;面对冷清观众席的微妙情绪&#xff0c;以及对未来的深刻思考和殷切期…

2024HW必修高危漏洞集合_v4.0

高危风险漏洞一直是企业网络安全防护的薄弱点&#xff0c;也成为HW攻防演练期间红队的重要突破口;每年 HW期间爆发了大量的高危风险漏洞成为红队突破网络边界防护的一把利器,很多企业因为这些高危漏洞而导致整个防御体系被突破、甚至靶标失守而遗憾出局。 HW 攻防演练在即&…

Vue的仓库是什么

Vue的仓库在广义上可以指存放Vue.js项目相关代码、组件、工具等资源的集合&#xff0c;这些资源可能托管在GitHub、GitLab等代码托管平台上。然而&#xff0c;在更具体的语境下&#xff0c;Vue的仓库可能指的是以下几个方面的内容&#xff1a; 1. Vue官方仓库 Vue.js核心库仓…

如何做一个透明度渐现且向上位移逐行出现的文字效果

前言 在这个夜黑风高的夜晚&#xff0c;你的眼睛已经开始有些疲惫。你的手指在键盘上轻轻地敲击着&#xff0c;仿佛在弹奏一首无声的夜曲。你的思绪在代码的海洋中飘荡&#xff0c;寻找着最后一行需要完成的代码。就在这时&#xff0c;你的老板走了过来&#xff0c;他的脸上带…

MySQL高级----InnoDB引擎

逻辑存储结构 表空间 表空间(ibd文件)&#xff0c;一个mysql实例可以对应多个表空间&#xff0c;用于存储记录、索引等数据。 段 段&#xff0c;分为数据段&#xff08;Leaf node segment)、索引段(Non-leaf node segment)、回滚段(Rollback segment)&#xff0c;InnoDB是…

GNU/Linux - Kconfig Language - 2

Kconfig syntax 配置文件描述了一系列菜单条目&#xff0c;每一行都以一个关键字开头&#xff08;帮助文本除外&#xff09;。以下关键字可结束一个菜单条目&#xff1a; The configuration file describes a series of menu entries, where every line starts with a keyword…

java 如何获取一个空的DATE对象

一&#xff1a;概述 在 Java 中&#xff0c;获取一个空的 Date 对象有多种方法。本文将介绍几种常用方法&#xff0c;并提供实际案例。 二&#xff1a;具体说明 <1>使用构造函数 Java 的 Date 类有多个构造函数&#xff0c;其中有一个无参构造函数&#xff0c;可以用于创…