在现代软件开发中,性能和用户体验是至关重要的,而负载测试和自动化测试可以帮助我们实现这一目标。在本文中,我们将讨论如何在 Kubernetes 环境中运行 Locust 和 Selenium,并详细介绍如何安装 Chrome 和 ChromeDriver。

1. Dockerfile 配置

首先,我们需要创建一个 Dockerfile,以构建一个包含 Locust 和 Selenium 的 Docker 镜像。以下是 Dockerfile 的内容:

FROM locustio/locust:2.31.3

# 设置 Chrome 的版本
ENV CHROME_VERSION 130.0.6723.69 USER root
RUN apt-get update -qq -y && \
apt-get install -y wget unzip && \
apt-get install -y \
libasound2 \
libatk-bridge2.0-0 \
libgtk-4-1 \
libnss3 \
xdg-utils && \
wget -q -O chrome-linux64.zip https://storage.googleapis.com/chrome-for-testing-public/$CHROME_VERSION/linux64/chrome-linux64.zip && \
unzip chrome-linux64.zip && \
rm chrome-linux64.zip && \
mv chrome-linux64 /opt/chrome/ && \
ln -s /opt/chrome/chrome /usr/local/bin/ && \
wget -q -O chromedriver-linux64.zip https://storage.googleapis.com/chrome-for-testing-public/$CHROME_VERSION/linux64/chromedriver-linux64.zip && \
unzip -j chromedriver-linux64.zip chromedriver-linux64/chromedriver && \
rm chromedriver-linux64.zip && \
mv chromedriver /usr/local/bin/ # 设置 Chrome 的配置和缓存目录
ENV XDG_CONFIG_HOME=/tmp/.chromium
ENV XDG_CACHE_HOME=/tmp/.chromium COPY . .
RUN pip install -r requirements.txt

解释

  1. 基础镜像:使用 locustio/locust 作为基础镜像。
  2. 安装依赖:更新包管理器并安装必要的库,以确保 Chrome 和 ChromeDriver 正常运行。
  3. 下载和安装 Chrome 和 ChromeDriver:从 Google 的存储库下载 Chrome 和 ChromeDriver。
  4. 配置目录:通过环境变量设置 Chrome 的配置和缓存目录,这一步非常重要。若未设置正确,可能会在 Kubernetes 中出现权限问题,具体参考 puppeteer-sharp

requirements.txt 示例

locust=2.31.3
selenium==4.21.0

2. Chrome 选项配置

在使用 Selenium 时,我们需要为 Chrome 配置一些选项,以确保它能够在无头模式下正常工作。以下是获取 Chrome 选项的代码示例:

import platform
from selenium import webdriver def is_running_in_linux():
return platform.system() == 'Linux' def get_chrome_options():
is_in_linux = is_running_in_linux()
options_custom = webdriver.ChromeOptions() # Linux 下的 Chrome 选项
if is_in_linux:
options_custom.add_argument("--headless") # 无头模式
options_custom.add_argument('--disable-gpu') # 禁用 GPU 加速
options_custom.add_argument("--no-sandbox") # 禁用沙箱模式
else:
options_custom.add_argument("--start-maximized") # 启动时最大化窗口 # 其他通用选项
options_custom.add_argument("--disable-dev-shm-usage") # 解决资源限制问题
options_custom.add_argument("--ignore-ssl-errors=yes") # 忽略 SSL 错误
options_custom.add_argument("--disable-cache") # 禁用缓存 return options_custom

解释

  • 操作系统检测:根据当前操作系统选择适当的 Chrome 选项。
  • 无头模式:在 Linux 环境中使用无头模式,以便在没有图形界面的情况下运行 Chrome。
  • 禁用沙箱:在 Kubernetes 环境中,禁用沙箱模式可以避免潜在的权限问题。

3. Locust 用户定义

下面是一个简单的 Locust 用户示例,使用 Selenium 控制 Chrome 访问特定页面:

from locust import User, task

class GetUrl(User):
customdriver = None def on_start(self):
self.customdriver = webdriver.Chrome(options=get_chrome_options()) @task
def load_page(self):
self.customdriver.get("http://example.com") # 根据需要替换为实际 URL

解释

  • 用户定义:创建一个继承自 User 的类,使用 Selenium 控制 Chrome。
  • 启动时操作:在用户启动时初始化 customdriver
  • 任务定义:在 load_page 方法中执行实际的页面加载操作。

4. Kubernetes 部署

完成 Dockerfile 和代码后,可以将其构建为 Docker 镜像,并在 Kubernetes 中部署。以下是一个基本的 Kubernetes YAML 配置示例:

apiVersion: apps/v1
kind: Deployment
metadata:
name: locust
spec:
replicas: 1
selector:
matchLabels:
app: locust
template:
metadata:
labels:
app: locust
spec:
containers:
- name: locust
image: your-docker-image:latest
ports:
- containerPort: 8089
env:
- name: XDG_CONFIG_HOME
value: /tmp/.chromium # 设置 Chrome 的配置目录
- name: XDG_CACHE_HOME
value: /tmp/.chromium # 设置 Chrome 的缓存目录
---
apiVersion: v1
kind: Service
metadata:
name: locust-service
spec:
type: NodePort
ports:
- port: 8089
targetPort: 8089
selector:
app: locust

解释

  • Deployment:定义 Locust 的 Deployment,指定容器镜像和服务端口。
  • Service:创建一个 Service,使外部能够访问 Locust Web 界面。

结论

通过以上步骤,我们成功在 Kubernetes 中运行了 Locust 和 Selenium,并安装了 Chrome 和 ChromeDriver。确保配置正确的环境变量和 Chrome 选项,可以大大提高在 Kubernetes 环境中的稳定性。如果您有更多需求,可以根据项目的具体情况进行扩展和调整。

在 Kubernetes 中运行 Locust 与 Selenium:安装 Chrome 和 ChromeDriver的更多相关文章

  1. python+ubuntu+selenium安装chrome和chromedriver

    请确保selenium已经安装成功,没安装的可以pip install selenium 安装chrome 在终端输入 下载安装包 wget https://dl.google.com/linux/d ...

  2. 【Linux】【Selenium】安装Chrome和ChromeDriver的配置

    转自:https://www.cnblogs.com/longronglang/p/8078898.html 1.安装chrome sudo apt-get install libxss1 libap ...

  3. centos 无界面 服务器 安装chrome部署chromedriver

    转:https://blog.csdn.net/u013849486/article/details/79466359 基本 做完了,要弄进docker里面去了的时候,才搜到 docker-chrom ...

  4. ubuntu 安装chrome 和chromedriver

    1. chromedriver 下载地址:  https://npm.taobao.org/mirrors/chromedriver 在这里找到对应的驱动 2. 安装谷歌浏览器 2.1 安装依赖 ap ...

  5. linux安装chrome及chromedriver(转)

    1.chrome: curl https://intoli.com/install-google-chrome.sh | bash 1.1.centos安装chrome: 從 Google 下載最新版 ...

  6. 在kubernetes中运行单节点有状态MySQL应用

    Deploy MySQL https://kubernetes.io/docs/tasks/run-application/run-single-instance-stateful-applicati ...

  7. 如何解决selenium打开chrome提示chromedriver.exe已停止工作

    场景:启动Chrome,打开URL,提示“disconnected: unable to connect to renderer” 解决方法:chromedriver与chrome的对应关系表, 需要 ...

  8. Nodejs的安装配置及如何在sublimetext2中运行js

    Nodejs的安装配置及如何在sublimetext2中运行js听语音 | 浏览:4554 | 更新:2015-06-16 11:29 Nodejs的安装配置及如何在sublimetext2中运行js ...

  9. Kubernetes 中的核心组件与基本对象概述

    Kubernetes 是 Google 基于 Borg 开源的容器编排调度,用于管理容器集群自动化部署.扩容以及运维的开源平台.作为云原生计算基金会 CNCF(Cloud Native Computi ...

  10. 在 Kubernetes 上运行高可用的 Kafka 集群

    转载自:https://www.qikqiak.com/post/deploy-kafka-ha-on-k8s/ Apache Kafka 是目前最流行的分布式消息发布订阅系统,虽然 Kafka 非常 ...

随机推荐

  1. 微服务架构SpringCloud的理解

    微服务架构是什么? 微服务是一种架构思想,实际上以分布式系统方式开发.架构是为了解耦.该架构解决的是分布式中的四个问题: 一.客户端如何访问众多服务: 应用划分为众多服务以后,客户端需要如何访问? 通 ...

  2. 秒懂全文:盘点13个各具特色的AI智能阅读助手工具

    在当今信息爆炸的时代,AI阅读工具正在革新我们的阅读方式,成为了提高效率.优化阅读体验的关键. 这类AI阅读辅助工具,只需要上传文件或者输入链接,便可以直接以聊天对话的形式进行一键总结和智能问答,满足 ...

  3. 神经网络之卷积篇:详解卷积步长(Strided convolutions)

    详解卷积步长 卷积中的步幅是另一个构建卷积神经网络的基本操作,让向展示一个例子. 如果想用3×3的过滤器卷积这个7×7的图像,和之前不同的是,把步幅设置成了2.还和之前一样取左上方的3×3区域的元素的 ...

  4. css居中的多种方式

    1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...

  5. rk3568 | 瑞芯微平台GPIO引脚驱动编写

    最近在玩瑞芯微平台的产品,移植了几个设备的驱动,遇到了一些问题,总结后发现大部分问题都出在了GPIO配置的问题上,写下本篇文章,用来分享一下调试的心得. 有喜欢瑞芯微的朋友,可以加我好友,拉你进群,一 ...

  6. [HCTF 2018]admin 1

    [HCTF 2018]admin 1 < 文章中有有关flask session 文章 需要认真读一下> 1.信息搜集 由题意,注册admin 用户,回显 The username has ...

  7. CSS学习(四)值和单位

    一.关键字.字符串和其它文本值 关键字:与其它编程语言一样,是代表特定含义的一个单词( 接收关键字的属性,所取的关键字必须在那个属性允许使用的关键字范围之内 ) 字符串:前后引号要保持一致( 可以是单 ...

  8. Apache HTTP Server 使用

    安装 macOS: brew install apache2 Ubuntu: sudo apt install apache2 使用 配置文件路径: macOS: /opt/homebrew/etc/ ...

  9. Spring Cloud集成Seata分布式事务-TCC模式

    参考文章 分布式事务实战方案汇总 https://www.cnblogs.com/yizhiamumu/p/16625677.html 分布式事务原理及解决方案案例https://www.cnblog ...

  10. 论文阅读翻译之Deep reinforcement learning from human preferences

    论文阅读翻译之Deep reinforcement learning from human preferences 关于 首次发表日期:2024-09-11 论文原文链接:https://arxiv. ...