专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

thekevjames/gcloud-pubsub-emulator Docker 镜像 - 轩辕镜像

gcloud-pubsub-emulator
thekevjames/gcloud-pubsub-emulator
thekevjames
messagebird/gcloud-pubsub-emulator镜像提供Google Cloud Pub/Sub模拟器功能,支持基础镜像变更时自动构建,适用于本地开发和测试环境。
2 收藏0 次下载
🙃 代码没问题,结果发布失败在拉镜像
中文简介版本下载
🙃 代码没问题,结果发布失败在拉镜像

gcloud-pubsub-emulator Docker镜像文档

镜像概述和主要用途

gcloud-pubsub-emulator 是一个基于 marcelcorso/gcloud-pubsub-emulator 构建的Docker镜像,提供Google Cloud Pub/Sub服务的本地模拟器。该镜像支持自动构建以追踪 gcloud 工具的最新版本,并集成了更新后的 pubsubc 工具,可在启动时自动初始化主题(topics)和订阅(subscriptions)。主要用于本地开发、集成测试及CI/CD流程中,模拟Pub/Sub服务环境,避免依赖真实云资源。

核心功能和特性

  • 自动构建与版本追踪:基于 gcloud 新版本自动构建,支持按版本号(\d+.\d+.\d+)、提交哈希(commit hash)及 latest 标签区分镜像版本。
  • 主题与订阅自动创建:通过配置文件或环境变量,在启动时自动创建多项目的主题及订阅,支持拉取(pull)和推送(push)订阅类型。
  • 健康检查支持:暴露额外端口(8682)用于健康探针,便于监控容器启动状态。
  • 灵活配置:支持通过配置文件(JSON格式)或环境变量定义项目、主题及订阅,满足复杂场景需求。
  • 超时控制:可自定义模拟器就绪超时时间,适配不同环境下的启动速度。

使用场景和适用范围

  • 本地开发:开发阶段模拟Pub/Sub服务,无需连接Google Cloud,加速开发迭代。
  • 集成测试:在单元测试或集成测试中使用,确保应用对Pub/Sub的交互逻辑正确。
  • CI/CD流程:在持续集成/部署管道中作为依赖服务,验证应用在Pub/Sub集成场景下的稳定性。
  • 多项目隔离:支持同时配置多个项目的主题和订阅,模拟复杂的多服务交互场景。

详细使用方法和配置说明

基本运行
直接运行(Docker Hub)
console
$ docker run --rm -it -p 8681:8681 thekevjames/gcloud-pubsub-emulator:latest
直接运行(quay.io)
console
$ docker run --rm -it -p 8681:8681 quay.io/thekevjames/gcloud-pubsub-emulator:latest
应用连接配置

启动后,通过环境变量 PUBSUB_EMULATOR_HOST 指向模拟器地址:

console
$ export PUBSUB_EMULATOR_HOST=localhost:8681
$ ./your_application  # 应用程序将使用模拟器而非真实Pub/Sub服务
自动主题和订阅创建

支持通过配置文件或环境变量两种方式,在启动时自动创建主题和订阅。

方式一:配置文件(推荐)
  1. 配置文件路径
    默认路径为 /etc/pubsubc/config.json,可通过环境变量 PUBSUBC_CONFIG 自定义路径。

  2. 配置文件格式
    JSON数组格式,每个元素为项目-主题配置,支持嵌套订阅定义。示例:

    json
    [
      {
        "topic": "topic1",  // 主题名称(必填)
        "project": "project1"  // 项目ID(必填)
      },
      {
        "topic": "topic2",
        "project": "project1",
        "subscriptions": [  // 可选,订阅列表
          {
            "name": "subscription1",  // 订阅名称(必填)
            "push_config": {  // 可选,推送订阅配置(无此键则为拉取订阅)
              "push_endpoint": "http://localhost:3001/messages"  // 推送目标地址
            }
          },
          {
            "name": "subscription2"  // 拉取订阅
          }
        ]
      }
    ]
    
  3. 启动命令示例
    挂载自定义配置文件并指定路径:

    console
    $ docker run --rm -it \
        -p 8681:8681 \
        -e PUBSUBC_CONFIG=/custom/config.json \  # 自定义配置文件路径
        -v ./local-config.json:/custom/config.json \  # 挂载本地配置文件
        thekevjames/gcloud-pubsub-emulator:latest
    
方式二:环境变量(不支持推送订阅)

仅在未指定配置文件时生效,通过 PUBSUB_PROJECT<N>(N 从1开始)定义项目及主题/订阅。

  1. 环境变量格式
    格式:PROJECTID,TOPIC1,TOPIC2:SUBSCRIPTION1:SUBSCRIPTION2,TOPIC3:SUBSCRIPTION3

    • 第一个元素为项目ID;
    • 后续元素为主题,格式为 TOPIC_ID[:SUBSCRIPTION1[:SUBSCRIPTION2]...](: 后为订阅名称,可多个)。
  2. 示例
    项目 company-dev 包含:

    • 主题 invoices,订阅 invoice-calculator;
    • 主题 chats,订阅 slack-out、irc-out;
    • 主题 notifications,无订阅。

    环境变量配置:

    console
    $ export PUBSUB_PROJECT1=company-dev,invoices:invoice-calculator,chats:slack-out:irc-out,notifications
    
  3. 启动命令示例

    console
    $ docker run --rm -it \
        -p 8681:8681 \
        -e PUBSUB_PROJECT1=company-dev,invoices:invoice-calculator,chats:slack-out:irc-out,notifications \
        thekevjames/gcloud-pubsub-emulator:latest
    
  4. 多项目配置
    通过 PUBSUB_PROJECT2、PUBSUB_PROJECT3 等添加更多项目,格式同上。

健康检查(Liveness Probes)

当启用自动创建主题/订阅时,需暴露端口 8682 用于健康检查(模拟器就绪后监听此端口)。检查方法示例:

  • 使用 nc:nc -z 127.0.0.1 8682
  • 使用 bash:true &>/dev/null </dev/tcp/127.0.0.1/8682
  • 使用 wget:wget 127.0.0.1:8682
超时配置

若模拟器启动缓慢导致主题/订阅创建超时(默认15秒),可通过 PUBSUB_EMULATOR_WAIT_TIMEOUT 环境变量调整超时时间(单位:秒)。示例:

console
$ docker run --rm -it \
    -p 8681:8681 \
    -e PUBSUB_EMULATOR_WAIT_TIMEOUT=60 \  # 超时设为60秒
    -e PUBSUB_PROJECT1=company-dev,invoices:invoice-calculator \
    thekevjames/gcloud-pubsub-emulator:latest

Docker部署方案示例

示例1:基本运行(仅模拟器服务)
console
$ docker run --rm -it \
    -p 8681:8681 \  # 模拟器服务端口
    thekevjames/gcloud-pubsub-emulator:latest
示例2:带配置文件的自动初始化
console
$ docker run --rm -it \
    -p 8681:8681 \
    -p 8682:8682 \  # 健康检查端口
    -e PUBSUBC_CONFIG=/config/pubsub.json \
    -v ./my-pubsub-config.json:/config/pubsub.json \  # 挂载本地配置文件
    thekevjames/gcloud-pubsub-emulator:latest
示例3:docker-compose配置
yaml
version: '3'
services:
  pubsub-emulator:
    image: thekevjames/gcloud-pubsub-emulator:latest
    ports:
      - "8681:8681"  # 模拟器服务端口
      - "8682:8682"  # 健康检查端口
    environment:
      - PUBSUB_EMULATOR_WAIT_TIMEOUT=60  # 超时配置
      - PUBSUBC_CONFIG=/config/config.json  # 配置文件路径
    volumes:
      - ./local-config.json:/config/config.json  # 挂载配置文件
    restart: unless-stopped

配置参数与环境变量

环境变量作用描述默认值示例
PUBSUBC_CONFIG自动初始化配置文件路径(仅配置文件方式生效)/etc/pubsubc/config.json/custom/pubsub-config.json
PUBSUB_PROJECT<N>项目及主题/订阅配置(仅环境变量方式生效,N从1开始)无company-dev,invoices:calc,chats:slack:irc,notifications(项目1)
PUBSUB_EMULATOR_WAIT_TIMEOUT模拟器就绪超时时间(秒)1560

镜像标签说明

  • latest:主分支最新构建版本。
  • \d+.\d+.\d+:对应 gcloud 工具版本的构建(如 460.0.0)。
  • 提交哈希标签:每个Git提交对应唯一标签(如 a1b2c3d4),用于版本精确追溯。
查看更多 gcloud-pubsub-emulator 相关镜像 →
thekevjames/coveralls logo
thekevjames/coveralls
用于coveralls-python(PyPI上的"coveralls")的最小化Docker镜像,支持将Python项目的代码覆盖率统计结果上传至coveralls.io服务。
1M+ pulls
上次更新:未知
thekevjames/nox logo
thekevjames/nox
为`nox`工具及所有受支持的Python版本提供Docker容器。
3100K+ pulls
上次更新:未知
thekevjames/mysqltuner logo
thekevjames/mysqltuner
提供用于MySQLtuner脚本的Docker容器
510K+ pulls
上次更新:未知
thekevjames/caddy-security logo
thekevjames/caddy-security
一个自动构建和更新的Caddy服务器镜像,内置caddy-security模块,可直接替换标准Caddy:2-alpine镜像使用。
10K+ pulls
上次更新:未知
thekevjames/mosura logo
thekevjames/mosura
Mosura是一个定制化的任务管理前端,旨在提供简化的任务管理体验,支持与Jira集成,具备最小化界面和个性化工作流,确保团队使用无冲突且仅展示必要功能。
10K+ pulls
上次更新:未知
thekevjames/tuning-primer logo
thekevjames/tuning-primer
提供MySQL Tuning Primer脚本的Docker容器。
110K+ pulls
上次更新:未知

轩辕镜像配置手册

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

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

MacOS OrbStack

MacOS OrbStack 容器配置

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

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

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

轩辕镜像支持哪些镜像仓库?

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

流量耗尽错误提示

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

410 错误问题

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

manifest unknown 错误

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

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

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

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
thekevjames/gcloud-pubsub-emulator
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
咨询镜像拉取问题请 提交工单,官方技术交流群:1072982923
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
咨询镜像拉取问题请提交工单,官方技术交流群:
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.