作为测试怎么设计ES与数据库的相关测试用例

首先要明确ES是分布式全文检索与分析引擎,主打高效查询、全文搜索、数据分析

数据库为了结构化数据存储,对于一些复杂的关联查询等

所在在实际的业务中经常是使用:**数据库存储核心数据,ES做高效检索同步,**所以在测试过程中核心就是要保证ES数据与数据库中的数据保持一致性

1.功能测试,测试数据的一致准确性

|--------|-----------------------------------------------------------------|-----------------------------------------------------------------------|
| 测试点 | 测试步骤 | 预期结果 |
| 全量数据同步 | 1.清空ES的索引 2.做全量同步的脚本 3.抽取mysql中的数据与ES中进行对比 | 1.ES中的索引与数据库中的保持一致 2.ES中数据的条数与mysql中的条数保持一致 3.字段保持一致 |
| 增量数据同步 | 1.先完成全量同步 2.对数据库中进行增删改 3.等待同步完成比对ES中的数据 | 1.增删改,es中的数据保持一致 2.同步延时的时间符合预期 |
| 异常同步容错 | 1.同步过程中中断ES 2.恢复ES后重新触发同步 3.比对数据一致性,有无数据丢失 | 1.未同步的数据不会丢失 2.同步的数据没有重复,没有缺失 3.同步失败的数据有对应的日志记录 |
| 字段映射正常 | 验证 MySQL 字段类型与 ES 字段类型的映射关系(如 int→integer,varchar→text/keyword) | 1. 映射关系符合设计要求;2. 需检索的字段设为 text 类型(支持分词),需精确匹配的字段设为 keyword 类型(如商品 ID) |

2.异常测试场景

|------------|--------------------------|----------------------|
| 测试点 | 测试步骤 | 预期结果 |
| 测试超大字段是否正常 | 如 MySQL 中存储的商品详情(5000 字) | ,同步到 ES 后是否完整,检索是否正常 |
| 测试特殊字符 | 如商品名含/、#、@等特殊字符 | ES是否能正常同步可以正常检索 |
| 测试超过数据量边界 | 如同步 100 万条数据 | ES是否可以正常同步检索是否正常 |

3.ES的独立功能

4.性能测试

分别设置按照ES和数据库的形式进行压测看有无性能瓶颈,之前仓储的一个商品6合一接口上线出现大面积的超时当时按照ES和数据库进行压测找出来性能瓶颈并正常修复上线对应的压测过程如下

生产环境: queryPlaceSkusCriteria

相关推荐
Elasticsearch19 小时前
在 ES|QL 中的混合搜索和多阶段检索
elasticsearch
AC赳赳老秦20 小时前
量化交易脚本开发:DeepSeek生成技术指标计算与信号触发代码
数据库·elasticsearch·信息可视化·流程图·数据库架构·memcached·deepseek
Elastic 中国社区官方博客20 小时前
使用 Elastic Agent Builder 和 MCP 实现 Agentic 参考架构
大数据·人工智能·elasticsearch·搜索引擎·ai·架构·全文检索
予枫的编程笔记21 小时前
Elasticsearch深度搜索与查询DSL实战:精准定位数据的核心技法
java·大数据·人工智能·elasticsearch·搜索引擎·全文检索
予枫的编程笔记1 天前
Elasticsearch聚合分析与大规模数据处理:解锁超越搜索的进阶能力
java·大数据·人工智能·分布式·后端·elasticsearch·全文检索
我是海飞1 天前
Git 本地仓库推送到远程空仓库指南
大数据·git·elasticsearch
better_liang1 天前
每日Java面试场景题知识点之-ELK技术栈实战应用
java·elk·elasticsearch·kibana·logstash·日志分析·企业级应用
予枫的编程笔记1 天前
Elasticsearch核心架构与基础原理:解密其极速性能的底层逻辑
java·大数据·人工智能·elasticsearch·搜索引擎·架构·全文检索
长路 ㅤ   1 天前
ES索引切分方案4:索引+别名 应用层自己维护:时间序列索引
elasticsearch·索引模板·时间序列索引·别名系统·大数据优化
小龙1 天前
【Git 报错解决】本地分支与远程分支名称/提交历史不匹配
大数据·git·elasticsearch·github