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框架。

优势

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

相关推荐
R-G-B20 小时前
【P1】win10安装 Docker教程
运维·docker·容器
Java小学生丶21 小时前
非常简单的基于 Docker 自建 RustDesk 远程桌面教程
docker·远程桌面·异地组网
大数据CLUB1 天前
酒店预订数据分析及预测可视化
大数据·hadoop·分布式·数据挖掘·数据分析·spark·mapreduce
驾驭人生1 天前
Docker中安装 redis、rabbitmq、MySQL、es、 mongodb设置用户名密码
redis·docker·rabbitmq
灰勒塔德1 天前
ubuntu 部署 gitlab docker服务
docker·容器·gitlab
深蓝电商API1 天前
云原生爬虫:使用Docker和Kubernetes部署与管理分布式爬虫集群
docker·kubernetes
啟明起鸣1 天前
【Go 与云原生】让一个 Go 项目脱离原生的操作系统——我们开始使用 Docker 制造云容器进行时
docker·云原生·golang
不见长安在1 天前
分布式ID
java·分布式·分布式id
qq_316837751 天前
jmeter 分布式压测
分布式·jmeter
西岭千秋雪_1 天前
Zookeeper实现分布式锁
java·分布式·后端·zookeeper·wpf