docker swarm里搭建Selenium Grid分布式测试集群,测试节点随时在线,无需反复启停,效率增倍

分布式测试集群搭建

Selenium Grid 是 Selenium 生态系统中的关键组件,专为分布式测试设计,支持在多环境、多设备上并行执行测试用例,显著提升测试效率

核心组成:

  • Hub(中心节点):作为控制中枢,负责接收测试请求并将任务分发至符合条件的节点。通常运行在单一机器上。

  • Node(执行节点):实际执行测试的机器,可注册到 Hub。每个节点可配置不同的浏览器、版本及操作系统(如 Chrome on Windows、Firefox on macOS)。

docker Swarm里执行

先启动hub中心

复制代码
docker service create \
  --name selenium-hub\
  --with-registry-auth\
  --network product_overlay_network \
  --replicas 1 \
  --constraint 'node.labels.jeecgcenter== true' \
   docker.m.daocloud.io/selenium/hub:latest

再启动node节点

复制代码
docker service create \
  --name selenium-node-chromium \
  --network product_overlay_network \
  --replicas 1 \
  --constraint 'node.labels.jeecgcenter==true' \
  -e SE_EVENT_BUS_HOST=selenium-hub \
  --mount type=tmpfs,destination=/dev/shm,tmpfs-size=2g \
  -e SE_EVENT_BUS_PUBLISH_PORT=4442 \
  -e SE_EVENT_BUS_SUBSCRIBE_PORT=4443 \
  docker.m.daocloud.io/selenium/node-chromium:latest

注意:swarm集群和 network网络请自行创建。

  • 子节点可以后面调整节点个数,默认为1个

效果展示:

启动8个节点的效果如下:

使用场景

  • 1.不同类型浏览器进行测试用例测试
  • 2.数据抓取的时候,使用该集群可以减少浏览器安装以及驱动配置支持selenium,playwright框架。

优势

可以指定任意数量的节点运行,
节点实时运行,不需要每次都启动停止浏览器,用完只需断开连接,后面继续使用连接上来就行,效率很高

相关推荐
難釋懷30 分钟前
分布式锁的原子性问题
分布式
ai_xiaogui2 小时前
【开源前瞻】从“咸鱼”到“超级个体”:谈谈 Panelai 分布式子服务器管理系统的设计架构与 UI 演进
服务器·分布式·架构·分布式架构·panelai·开源面板·ai工具开发
凯子坚持 c2 小时前
如何基于 CANN 原生能力,构建一个支持 QoS 感知的 LLM 推理调度器
分布式
飞升不如收破烂~2 小时前
Redis 分布式锁+接口幂等性使用+当下流行的限流方案「落地实操」+用户连续点击两下按钮的解决方案自用总结
数据库·redis·分布式
无心水2 小时前
分布式定时任务与SELECT FOR UPDATE:从致命陷阱到优雅解决方案(实战案例+架构演进)
服务器·人工智能·分布式·后端·spring·架构·wpf
0思必得02 小时前
[Web自动化] Selenium获取元素的子元素
前端·爬虫·selenium·自动化·web自动化
70asunflower2 小时前
用Docker创建不同的容器类型
运维·docker·容器
Lansonli3 小时前
大数据Spark(八十):Action行动算子fold和aggregate使用案例
大数据·分布式·spark
小Pawn爷3 小时前
3.Dockerfile
docker