当前位置: 首页 > article >正文

基于Docker的Chromedriver与Google-Chrome跨平台部署方案

1. 为什么需要Docker化Chromedriver与Chrome最近在做一个自动化测试项目时遇到了一个典型问题团队里有小伙伴用Mac我用Ubuntu还有同事用Windows。每次跑测试脚本总有人因为Chrome版本不匹配或者Chromedriver版本不对而报错。更糟的是当我们需要在服务器集群上部署时每台机器都要手动安装和配置环境费时费力还容易出错。这时候Docker就派上用场了。把Chromedriver和Chrome打包成镜像后不管在什么系统上只要有Docker环境就能一键拉起完全相同的运行环境。这就像把整个厨房都装进了一个魔法盒子到哪里都能做出味道完全一样的菜。提示Docker化浏览器环境特别适合需要跨平台协作的团队或者需要在不同服务器上部署相同环境的场景。实际项目中我们遇到过几个典型痛点开发环境与生产环境的Chrome版本不一致导致测试结果不同团队协作时因系统差异导致的在我机器上是好的问题服务器集群部署时需要重复安装配置浏览器环境Kubernetes环境中Pod调度到不同节点时的环境一致性问题2. 环境准备与资源获取2.1 获取正确的软件版本Chromedriver和Chrome版本必须严格匹配否则会出现各种莫名其妙的错误。我推荐使用Chrome for Testing项目提供的版本这是Google专门为自动化测试维护的版本。# Chrome for Testing官方仓库 https://googlechromelabs.github.io/chrome-for-testing/这里可以找到各个平台的稳定版Chrome和对应的Chromedriver。我建议选择Stable渠道的版本因为这是经过充分测试的。对于Linux系统可以直接下载.rpm或.deb包。Windows用户可以直接下载安装程序但建议在Docker中还是使用Linux版本因为最终运行环境通常都是Linux服务器。2.2 准备Dockerfile基础我习惯使用CentOS 7作为基础镜像因为它比较稳定兼容性好。当然你也可以选择Ubuntu或Alpine等更轻量的基础镜像。FROM centos:centos7如果对镜像大小敏感可以考虑使用Alpine Linux但要注意可能需要额外安装一些依赖库。3. 构建Docker镜像的完整过程3.1 编写Dockerfile下面是一个经过实战检验的Dockerfile示例包含了一些优化措施FROM centos:centos7 # 安装基础依赖 RUN yum -y install wget unzip libX11 GConf2 fontconfig \ yum clean all # 添加Chrome RPM包 ADD google-chrome-stable-117.0.5938.92-1.x86_64.rpm /tmp/ # 安装Chrome RUN yum -y localinstall /tmp/google-chrome-stable-117.0.5938.92-1.x86_64.rpm \ rm -f /tmp/google-chrome-stable-117.0.5938.92-1.x86_64.rpm # 添加Chromedriver ADD chromedriver /usr/local/bin/chromedriver # 设置权限和字体 RUN chmod x /usr/local/bin/chromedriver \ yum -y install dejavu-sans-fonts \ yum clean all # 设置环境变量 ENV CHROME_DRIVER /usr/local/bin/chromedriver这个配置做了几项优化清理了yum缓存减小镜像体积将临时文件放在/tmp目录并在安装后删除安装了基本字体支持设置了环境变量方便后续使用3.2 构建和测试镜像构建命令很简单docker build -t chrome-driver:latest .构建完成后可以运行一个测试容器验证是否正常工作docker run -it --rm chrome-driver:latest google-chrome --version docker run -it --rm chrome-driver:latest chromedriver --version这两个命令应该输出匹配的版本号。如果版本不一致就需要检查下载的软件包是否正确。4. 高级配置与优化技巧4.1 解决常见问题在实际使用中我遇到过几个典型问题中文乱码问题 如果页面中有中文显示为方框需要安装中文字体RUN yum -y install wqy-microhei-fonts \ yum clean all无头模式下的字体渲染 在无头模式下运行时可能需要额外的字体配置RUN yum -y install xorg-x11-fonts-100dpi xorg-x11-fonts-75dpi \ xorg-x11-utils xorg-x11-fonts-cyrillic xorg-x11-fonts-Type1 \ xorg-x11-fonts-misc \ yum clean all内存泄漏问题 长时间运行的Chrome实例可能会内存泄漏建议定期重启容器。4.2 镜像优化策略原始镜像构建后可能比较大我们可以通过多阶段构建来优化# 第一阶段构建环境 FROM centos:centos7 as builder RUN yum -y install wget unzip ADD google-chrome-stable-117.0.5938.92-1.x86_64.rpm /tmp/ RUN yum -y localinstall /tmp/google-chrome-stable-117.0.5938.92-1.x86_64.rpm # 第二阶段运行时环境 FROM centos:centos7 COPY --frombuilder /opt/google/chrome /opt/google/chrome COPY --frombuilder /usr/bin/google-chrome /usr/bin/google-chrome COPY --frombuilder /usr/lib64/libnss3.so /usr/lib64/libnss3.so # 复制其他必要的库文件... ADD chromedriver /usr/local/bin/chromedriver RUN chmod x /usr/local/bin/chromedriver这样可以将最终镜像体积减小30%-50%。5. 在Kubernetes中的实际应用5.1 作为Sidecar容器部署在K8s中我通常将浏览器环境作为Sidecar容器运行apiVersion: apps/v1 kind: Deployment metadata: name: web-automation spec: replicas: 1 selector: matchLabels: app: web-automation template: metadata: labels: app: web-automation spec: containers: - name: main-app image: your-application-image ports: - containerPort: 8080 - name: chrome image: your-chrome-driver-image ports: - containerPort: 95155.2 资源限制与调度浏览器比较吃资源记得设置合理的资源限制resources: limits: cpu: 1 memory: 1Gi requests: cpu: 500m memory: 512Mi对于内存密集型任务可以适当增加内存限制。我在一个爬虫项目中发现每个Chrome实例至少需要1GB内存才能稳定运行。6. 版本管理与持续集成6.1 自动化构建流程我建议将镜像构建纳入CI/CD流程这样每次Chrome或Chromedriver更新时都能自动生成新镜像。下面是一个GitLab CI的示例build_chrome_image: stage: build script: - docker build -t $CI_REGISTRY_IMAGE/chrome-driver:latest . - docker push $CI_REGISTRY_IMAGE/chrome-driver:latest only: changes: - Dockerfile - chromedriver - google-chrome-stable-*.rpm6.2 版本标签策略为了便于回滚我使用以下标签策略latest最新稳定版{chrome版本}-{chromedriver版本}具体版本标签日期标签如20240501这样在Dockerfile更新时可以保持版本清晰ARG CHROME_VERSION117.0.5938.92 ARG CHROME_DRIVER_VERSION117.0.5938.92 ADD google-chrome-stable-${CHROME_VERSION}-1.x86_64.rpm /tmp/ ADD chromedriver-${CHROME_DRIVER_VERSION} /usr/local/bin/chromedriver在实际项目中这套方案帮我们节省了大量环境调试时间。特别是在Kubernetes集群中部署时再也不用担心节点间的环境差异问题。记得定期更新Chrome和Chromedriver版本保持与最新稳定版同步。

相关文章:

基于Docker的Chromedriver与Google-Chrome跨平台部署方案

1. 为什么需要Docker化Chromedriver与Chrome 最近在做一个自动化测试项目时,遇到了一个典型问题:团队里有小伙伴用Mac,我用Ubuntu,还有同事用Windows。每次跑测试脚本,总有人因为Chrome版本不匹配或者Chromedriver版本…...

Faster-Whisper-GUI:一站式智能语音转写解决方案,高效将音频视频转换为精准字幕

Faster-Whisper-GUI:一站式智能语音转写解决方案,高效将音频视频转换为精准字幕 【免费下载链接】faster-whisper-GUI faster_whisper GUI with PySide6 项目地址: https://gitcode.com/gh_mirrors/fa/faster-whisper-GUI 面对海量音频视频内容需…...

AI时代的“特洛伊木马”:被忽视的网关层正在窃取一切

在AI快速渗透企业核心业务的过程中,一个被忽视但正在快速放大的安全问题正在显现:模型网关正在成为AI系统中最脆弱、最容易被利用的攻击入口之一。最新一项研究显示,在大量的第三方模型网关中,已经出现真实的恶意行为与数据窃取事…...

Mathtype高效统一硕士论文公式格式:从混乱到规范

1. 论文公式格式混乱的三大痛点 写硕士论文最让人头疼的环节之一,就是处理全文几十个甚至上百个数学公式的格式问题。我指导过上百位研究生的论文排版,发现90%的人都会遇到这三个典型问题: 第一是格式不统一。你可能从不同文献里复制了公式&a…...

辅助医生能力成长与患者个体化治疗方案生成系统(下)

第六章 反馈学习与模型迭代 6.1 医生修正数据记录 # ==================== 反馈收集模块 ==================== class FeedbackCollector:"""收集医生对AI方案的修正行为,形成训练样本"""def __init__(self, storage_path: str = feedback.db…...

别再纠结Java私有方法怎么测了!用JUnit+反射搞定单元测试覆盖率(附完整代码)

突破Java私有方法测试困境:反射与JUnit实战指南 在代码质量审查中,单元测试覆盖率常常成为硬性指标。当Sonar报告显示由于私有方法未被覆盖导致整体覆盖率不达标时,开发者往往陷入两难——是破坏封装性修改访问权限,还是放弃这部分…...

ArcGIS小白必看:3个隐藏技巧让你的天地图区位图秒变专业级

ArcGIS小白必看:3个隐藏技巧让你的天地图区位图秒变专业级 第一次打开ArcGIS时,那种面对空白画布的茫然感我还记忆犹新。特别是当需要制作研究区位图时,明明用了官方底图,却总觉得哪里不够"专业"。直到后来才发现&#…...

初学C语言,写给自己的第一个实用程序 |文末赠书

在 C 语言编程的学习之路上,同学们在了解基本概念、掌握基础语法之后,一定跃跃欲试想开发一款有意义的实用程序。 编程实现计算器是一个不错的选择。因为它难度适中,需要用到的知识又恰好涵盖了 C 语言的基本关键点,还具有一定的…...

Innovus实战:Guide/Fence/Region三种约束类型到底怎么选?附避坑指南

Innovus布局约束实战指南:Guide/Fence/Region深度解析与选型策略 在数字芯片设计的物理实现阶段,合理使用布局约束是优化时序、功耗和面积的关键手段。作为Cadence Innovus工具的核心功能之一,Guide、Fence和Region三种约束类型各有其独特的应…...

如何免费获取专业级中文宋体:Source Han Serif CN完整使用指南

如何免费获取专业级中文宋体:Source Han Serif CN完整使用指南 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为商业字体授权费用而烦恼吗?Source Han Ser…...

从消费电子到机器人,步步精科技如何切入连接器高端赛道

在人工智能与具身智能快速发展的背景下,机器人产业正迎来前所未有的增长机遇。从工业机器人到人形机器人,再到服务机器人与智能终端,行业正加速迈向规模化应用阶段。在这一趋势下,作为核心基础部件之一的连接器,正成为…...

毕设:基于融合注意力机制的单目深度估计算法(纯小白钻研历程记录)-Day1 介绍基本情况

一.基本概念融合注意力:注意力机制是让模型在处理信息时自动分配权重,对关键内容赋予更高关注度、忽略无关信息,通过计算查询(Q)、键(K)的相似度得到注意力权重,再对值(V…...

AI产品经理转型:从技术思维到商业决策

在人工智能浪潮席卷千行百业的当下,一个连接技术潜能与商业价值的核心角色正日益凸显——AI产品经理。对于身处软件测试领域的专业人士而言,这一转型不仅是职业赛道的跨越,更是一次将既有技术严谨性与系统思维,升维至产品定义与商…...

如何配置Data Guard的重做路由Redo Routing_级联备库Cascaded Standby架构

Redo Routing 是 Data Guard 在级联备库(Cascaded Standby)场景下自动启用的重做转发机制,即备库B将主库A发来的重做日志原样转发给下游备库C;它依赖B处于MANAGED STANDBY RECOVER模式、网络连通、密码文件一致等前提,…...

构建未来护城河:2026年全栈测试工程师必备技能体系深度解析

站在2026年的技术浪潮之巅,软件测试领域正经历一场由AI、云原生与数字化转型驱动的深刻重塑。传统的“测试执行者”角色正加速消解,取而代之的是具备全局视野、技术深度与业务洞察力的“全栈质量架构师”。对于每一位软件测试从业者而言,理解…...

MySQL数据备份策略如何制定_利用mysqldump实现全量与增量备份

全量备份对InnoDB表几乎总需加--single-transaction,否则锁表阻塞写入;增量备份只能依赖binlog;mysqldump易漏--routines、--events、--set-gtid-purgedOFF;压缩备份须校验完整性。全量备份必须加 --single-transaction 吗&#x…...

Hermes Agent 是什么:一篇讲清楚 AI Agent 能力边界的入门文章

如果你最近经常看到 AI Agent、自动化执行、任务编排这些词,很容易产生一种错觉: 只要接入一个大模型,系统就会自动理解目标、分解步骤、调用工具,最后把事情办完。 现实没有这么简单,但也没有那么遥远。像 Hermes agent 这类系统…...

第 17 课:任务选择与批量操作

第 17 课:任务选择与批量操作 这一课,我们继续把任务页做得更像真实后台系统。 上一课我们已经完成了: 单条任务删除危险操作确认框局部更新和局部删除 这一课继续升级,加入两个在真实项目里非常常见的能力: 勾选多条任…...

2026届必备的降AI率工具实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 伴随人工智能辅助写作越发普遍的情形下,切实减少文本的机器生成迹象变成内容创作…...

深入RK3588 ISP调试:用RKISP_Tuner在线抓Raw图与RTSP推流的实战技巧

深入RK3588 ISP调试:用RKISP_Tuner在线抓Raw图与RTSP推流的实战技巧 在嵌入式视觉系统的开发中,图像信号处理(ISP)调试是决定最终成像质量的关键环节。RK3588作为瑞芯微旗舰级芯片,其强大的ISP性能为开发者提供了广阔的…...

springboot私家车位共享系统小程序(文档+源码)_kaic

第5章 系统实现 5.1管理员功能模块 管理员登录,管理员通过输入用户名,密码,验证码等信息进入私家车位共享系统,如图5-1所示。 图5-1管理员登录界面图 管理员登录进入私家车位共享系统可以查看首页、轮播图、公告、资源管理&#…...

毕业答辩PPT制作:10款工具对比,助你轻松通过答辩

毕业答辩PPT制作是每位毕业生必须面对的挑战。你是否担心PPT设计不够专业、内容结构不清晰,或者时间紧迫无法高效完成?本文将围绕“毕业答辩PPT制作”这一核心关键词,为你推荐10款实用工具,包括第一款AIPPT,并提供免费…...

SPL06-001 气压计:从寄存器配置到数据校准的嵌入式实践

1. SPL06-001气压计基础与嵌入式应用场景 SPL06-001是Infineon推出的一款高精度数字气压传感器,采用MEMS技术实现压力测量。在嵌入式系统中,它常被用于无人机高度控制、气象站数据采集、室内导航等场景。我第一次接触这个传感器是在开发一个户外气象监测…...

KITTI数据集改造实战:用rosbag_filter_gui和merge_bags.py打造你的专属100Hz IMU融合数据集

KITTI数据集深度定制:构建100Hz IMU融合数据集的完整实战指南 在自动驾驶和机器人定位领域,KITTI数据集一直是算法验证的黄金标准。但当我们试图评估基于滤波的多传感器融合算法时,标准数据集中的10Hz IMU数据往往成为性能瓶颈。本文将带你从…...

热点文章_具身智能量产元年开启5亿订单人形机器人商业化飞轮启动开发者如何抓住红利_20260415_003

具身智能量产元年开启:5亿订单引爆人形机器人商业化飞轮,开发者如何抓住这波红利摘要:2026年被业界公认为"具身智能量产元年"。随着宇树科技冲刺科创板、智平方斩获5亿元全球最大单一订单、人形机器人进入规模化部署阶段&#xff0…...

从MATLAB到Tecplot:ASCII格式PLT文件的结构化数据转换实战

1. Tecplot ASCII格式PLT文件基础解析 第一次接触Tecplot的PLT文件格式时,我被它灵活的ASCII结构深深吸引。与二进制格式相比,ASCII格式虽然读取速度稍慢,但它的可读性和可调试性为工程师和科研人员提供了极大的便利。记得我刚开始处理CFD数据…...

OpenMV硬件魔改指南:如何给H743开发板添加自定义串口和SD卡检测

OpenMV H743硬件魔改实战:自定义串口与SD卡检测的深度优化 当标准OpenMV开发板的功能无法满足你的项目需求时,硬件层面的定制化改造就成为必经之路。本文将带你深入H743开发板的硬件适配层,通过修改底层配置文件实现串口扩展和SD卡检测优化&a…...

从手机导航到厘米级RTK:一文搞懂GNSS三大观测量(伪距、载波相位、多普勒)到底怎么用

从手机导航到厘米级RTK:GNSS三大观测量的技术跃迁与应用革命 当我们打开手机地图导航时,很少会思考那个蓝色定位点背后的技术奥秘。事实上,从日常导航到精准农业,从无人机测绘到自动驾驶,全球导航卫星系统(GNSS)技术的…...

大语言模型架构演进:从BERT到GPT再到Mamba的正确打开方式

先说结论大模型架构的演进史,本质上是一部"如何更高效承载智能"的优化史。从BERT的双向理解,到GPT的单向生成,再到Mamba的线性复杂度——每一代架构都在解决上一代的瓶颈。这个东西是什么想象一下,你要处理一段文字。BE…...

【AI Agent 从入门到精通】第六章:多智能体(Multi-Agent)系统架构详解:从双 Agent 协作到大型多 Agent 系统

📌 前置说明:本系列共 8 章,建议按顺序阅读。 📖 系列导航: 第一章:AI Agent 是什么?一文讲清楚核心概念与架构 第二章:AI Agent 的技术原理:LLM + 规划 + 记忆 + 工具 第三章:主流 AI Agent 框架对比:LangChain、AutoGPT、AutoGen、LlamaIndex 第四章:动手实现你…...