轩辕镜像
轩辕镜像专业版
个人中心搜索镜像
交易
充值流量我的订单
工具
工单支持镜像收录Run 助手IP 归属地密码生成Npm 源Pip 源
帮助
常见问题我要吐槽
其他
关于我们网站地图

官方QQ群: 13763429

轩辕镜像
镜像详情
mostafamoradian/xk6-kafka
官方博客使用教程热门镜像工单支持
本站面向开发者与科研用户,提供开源镜像的搜索和下载加速服务。
所有镜像均来源于原始开源仓库,本站不存储、不修改、不传播任何镜像内容。
轩辕镜像 - 国内开发者首选的专业 Docker 镜像下载加速服务平台 - 官方QQ群:13763429 👈点击免费获得技术支持。
本站面向开发者与科研用户,提供开源镜像的搜索和下载加速服务。所有镜像均来源于原始开源仓库,本站不存储、不修改、不传播任何镜像内容。

本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

xk6-kafka Docker 镜像下载 - 轩辕镜像

xk6-kafka 镜像详细信息和使用指南

xk6-kafka 镜像标签列表和版本信息

xk6-kafka 镜像拉取命令和加速下载

xk6-kafka 镜像使用说明和配置指南

Docker 镜像加速服务 - 轩辕镜像平台

国内开发者首选的 Docker 镜像加速平台

极速拉取 Docker 镜像服务

相关 Docker 镜像推荐

热门 Docker 镜像下载

xk6-kafka
mostafamoradian/xk6-kafka

xk6-kafka 镜像详细信息

xk6-kafka 镜像标签列表

xk6-kafka 镜像使用说明

xk6-kafka 镜像拉取命令

Docker 镜像加速服务

轩辕镜像平台优势

镜像下载指南

相关 Docker 镜像推荐

xk6-kafka扩展的官方Docker镜像,用于通过k6对Apache Kafka进行负载测试,支持生产者发送消息、消费者调试,提供多种序列化格式、SASL认证及消息压缩等功能。
2 收藏0 次下载activemostafamoradian镜像
🚀轩辕镜像专业版更稳定💎一键安装 Docker 配置镜像源
中文简介版本下载
🚀轩辕镜像专业版更稳定💎一键安装 Docker 配置镜像源

xk6-kafka 镜像详细说明

xk6-kafka 使用指南

xk6-kafka 配置说明

xk6-kafka 官方文档

xk6-kafka Docker镜像文档

镜像概述和主要用途

xk6-kafka是k6的扩展,允许用户使用生产者(及用于调试的消费者)对Apache Kafka进行负载测试。其核心用途是测试基于Apache Kafka设计的系统,通过自动生成消息并发送到Kafka来验证消费者及整个系统的性能和正确性。本Docker镜像为该扩展提供官方容器化部署方式,简化测试环境配置。

核心功能和特性

  • 多格式支持:生产/消费String、JSON、ByteArray、Avro及JSON Schema格式消息
  • 模式管理:支持用户在脚本中硬编码Avro/JSON Schema键值模式,或从Schema Registry获取
  • 认证机制:支持SASL PLAIN、SCRAM及SSL认证
  • 主题操作:可创建、列出和删除Kafka主题
  • 消息压缩:支持Gzip、Snappy、Lz4及Zstd压缩算法
  • 消费者组:通过group ID从所有分区消费消息
  • 指标监控:导出丰富的Kafka指标(如消息数、字节数、错误数等),支持k6阈值设置
  • 调试工具:内置消费者用于验证消息发送正确性

使用场景和适用范围

适用于对Kafka生产者、消费者及依赖Kafka的系统进行负载测试的场景,尤其适合:

  • 验证系统在高并发消息处理下的吞吐量和延迟
  • 测试消息格式、序列化/反序列化逻辑正确性
  • 验证认证机制(如SASL)和权限配置有效性
  • 开发环境中快速验证Kafka主题配置和消息流

使用方法和配置说明

获取镜像

从Docker Hub拉取官方镜像:

docker pull mostafamoradian/xk6-kafka:latest

基本使用示例

通过挂载本地脚本或标准输入传递测试脚本运行负载测试。

1. 通过标准输入传递脚本

docker run --rm -i mostafamoradian/xk6-kafka:latest run - <本地脚本路径/test_json.js

2. 挂载本地目录运行脚本

将本地脚本目录挂载到容器中,直接运行指定脚本:

docker run --rm -v $(pwd)/scripts:/scripts mostafamoradian/xk6-kafka:latest run /scripts/test_json.js

测试脚本结构

测试脚本遵循k6测试生命周期,包含以下核心阶段:

1. 导入模块

// 导入完整模块
import * as kafka from "k6/x/kafka";

// 或导入特定类和常量
import { Writer, Reader, Connection, SchemaRegistry, SCHEMA_TYPE_STRING } from "k6/x/kafka";

2. 初始化上下文(init阶段)

创建Kafka连接、生产者、消费者实例,并初始化主题:

// 创建生产者
const writer = new Writer({
  brokers: ["localhost:9092"],  // Kafka broker地址列表
  topic: "my-test-topic",       // 目标主题
  compression: "snappy"         // 消息压缩方式(可选)
});

// 创建消费者
const reader = new Reader({
  brokers: ["localhost:9092"],
  topic: "my-test-topic",
  groupID: "test-group"         // 消费者组ID(可选)
});

// 创建连接(用于主题管理)
const connection = new Connection({ address: "localhost:9092" });

// 初始化时创建主题(仅首次运行)
if (__VU == 0) {
  connection.createTopic({
    topic: "my-test-topic",
    numPartitions: 3,            // 分区数(可选)
    replicationFactor: 1         // 副本因子(可选)
  });
}

3. VU测试逻辑(default函数)

发送消息、消费消息并验证:

export default function () {
  // 生产消息
  writer.produce({
    messages: [
      {
        key: schemaRegistry.serialize({ data: "key-1", schemaType: SCHEMA_TYPE_STRING }),
        value: schemaRegistry.serialize({ data: { id: 1, value: "test" }, schemaType: SCHEMA_TYPE_JSON })
      }
    ]
  });

  // 消费消息并验证
  const messages = reader.consume({ limit: 10 });  // 最多消费10条消息
  if (messages.length > 0) {
    console.log(`消费消息: ${JSON.stringify(messages[0].value)}`);
    // 可添加k6 checks验证消息内容、格式等
  }
}

4. 清理资源(teardown阶段)

关闭连接并清理测试主题:

export function teardown() {
  // 删除测试主题(可选)
  connection.deleteTopic("my-test-topic");
  
  // 关闭所有连接
  writer.close();
  reader.close();
  connection.close();
}

环境配置示例

SASL认证配置

const writer = new Writer({
  brokers: ["kafka-broker:9092"],
  topic: "sasl-test-topic",
  sasl: {
    mechanism: "SCRAM-SHA-256",  // 认证机制
    username: "test-user",
    password: "test-pass"
  },
  tls: {
    enable: true  // 启用TLS
  }
});

Avro格式消息(带Schema Registry)

const schemaRegistry = new SchemaRegistry({ url: "[***]" });

writer.produce({
  messages: [
    {
      key: schemaRegistry.serialize({
        data: "user-1",
        schemaType: "avro",
        schema: { type: "string" }  // 或从Schema Registry获取
      }),
      value: schemaRegistry.serialize({
        data: { id: 1, name: "test" },
        schemaType: "avro",
        schema: { type: "record", name: "User", fields: [{ name: "id", type: "int" }, { name: "name", type: "string" }] }
      })
    }
  ]
});

支持的指标

xk6-kafka导出以下核心指标用于监控测试过程:

指标名称类型描述
kafka_reader_message_countCounter消费消息总数
kafka_writer_message_countCounter生产消息总数
kafka_reader_error_countCounter消费错误总数
kafka_writer_error_countCounter生产错误总数
kafka_reader_lagGauge消费滞后量(最后消息偏移与当前偏移差)
kafka_writer_write_secondsTrend消息写入耗时(趋势)
kafka_reader_read_secondsTrend消息读取耗时(趋势)
kafka_reader_fetch_bytesCounter读取字节总数
kafka_writer_batch_sizeCounter批处理消息总数

示例脚本

官方仓库scripts目录提供多种功能示例,关键脚本包括:

  • test_json.js:JSON格式消息生产/消费测试
  • test_avro_with_schema_registry.js:使用Schema Registry的Avro消息测试
  • test_sasl_auth.js:SASL认证测试
  • test_consumer_group.js:消费者组多分区消费测试
  • test_topics.js:主题创建/删除/列出操作测试
查看更多 xk6-kafka 相关镜像 →

常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像免费版与专业版有分别支持哪些镜像?

免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

轩辕镜像下载加速使用手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

🔐

登录方式进行 Docker 镜像下载加速教程

通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤

🐧

Linux Docker 镜像下载加速教程

在 Linux 系统上配置轩辕镜像源,支持主流发行版

🖥️

Windows/Mac Docker 镜像下载加速教程

在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统

📦

Docker Compose 镜像下载加速教程

在 Docker Compose 中使用轩辕镜像加速,支持容器编排

📋

K8s containerd 镜像下载加速教程

在 k8s 中配置 containerd 使用轩辕镜像加速

🔧

宝塔面板 Docker 镜像下载加速教程

在宝塔面板中配置轩辕镜像加速,提升服务器管理效率

💾

群晖 NAS Docker 镜像下载加速教程

在 Synology 群晖NAS系统中配置轩辕镜像加速

🐂

飞牛fnOS Docker 镜像下载加速教程

在飞牛fnOS系统中配置轩辕镜像加速

📱

极空间 NAS Docker 镜像下载加速教程

在极空间NAS中配置轩辕镜像加速

⚡

爱快路由 ikuai Docker 镜像下载加速教程

在爱快ikuai系统中配置轩辕镜像加速

🔗

绿联 NAS Docker 镜像下载加速教程

在绿联NAS系统中配置轩辕镜像加速

🌐

威联通 NAS Docker 镜像下载加速教程

在威联通NAS系统中配置轩辕镜像加速

📦

Podman Docker 镜像下载加速教程

在 Podman 中配置轩辕镜像加速,支持多系统

📚

ghcr、Quay、nvcr、k8s、gcr 等仓库下载镜像加速教程

配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤

🚀

专属域名方式进行 Docker 镜像下载加速教程

无需登录即可使用轩辕镜像加速服务,更加便捷高效

需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429

商务:17300950906
|©2024-2025 源码跳动
商务合作电话:17300950906|Copyright © 2024-2025 杭州源码跳动科技有限公司. All rights reserved.