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

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

官方QQ群: 13763429

dvassilenko/mongo-delayed-secondary Docker 镜像 - 轩辕镜像

mongo-delayed-secondary
dvassilenko/mongo-delayed-secondary
包含一个人为延迟从节点的副本集,用于模拟主从数据同步延迟场景,适用于测试数据恢复、故障转移及延迟相关功能验证。
1 收藏0 次下载activedvassilenko镜像
🚀专业版镜像服务,面向生产环境设计
中文简介版本下载
🚀专业版镜像服务,面向生产环境设计

副本集(含延迟从节点)镜像文档

镜像概述

本镜像提供一个预配置的副本集环境,包含1个主节点(Primary)和1个人为延迟的从节点(Secondary with artificial delay)。延迟从节点通过配置同步延迟参数,模拟主从数据同步过程中的滞后场景,可用于开发、测试环境中验证延迟相关功能及故障处理机制。

核心功能与特性

1. 副本集基础架构
  • 包含1个主节点(处理写操作及读请求)和1个从节点(同步主节点数据,仅处理读请求)
  • 支持副本集自动初始化,无需手动配置节点间通信
2. 可配置的同步延迟
  • 从节点数据同步延迟时间可通过环境变量自定义(默认30秒)
  • 延迟机制基于 oplog 同步滞后实现,模拟真实环境中的网络延迟或负载导致的同步延迟
3. 主从故障转移支持
  • 集成副本集自动故障转移功能:主节点故障时,从节点可自动提升为主节点(需满足副本集选举条件)
  • 延迟从节点默认优先级(priority)设为0,避免在主节点故障时被优先选举(可通过配置调整)

使用场景

1. 开发测试环境
  • 模拟生产环境中的主从延迟场景,验证应用在数据不一致状态下的容错能力
  • 开发阶段测试读写分离架构中,从节点延迟对读数据一致性的影响
2. 数据恢复演练
  • 利用延迟从节点保留历史数据版本,测试误操作后的数据恢复流程(如删除数据后从延迟节点恢复)
  • 验证基于时间点的恢复(Point-in-Time Recovery)工具的有效性
3. 延迟相关功能测试
  • 测试依赖数据同步时间的功能(如缓存失效策略、分布式锁超时机制)
  • 验证延迟告警阈值及监控指标的准确性

使用方法与配置说明

环境变量配置
环境变量名描述默认值取值范围
REPLICA_SET_NAME副本集名称rs0字符串
DELAY_SECONDS从节点同步延迟时间(秒)30正整数(≥0)
PRIMARY_PORT主节点对外暴露端口270171024-65535
SECONDARY_PORT从节点对外暴露端口270181024-65535
DATA_VOLUME_PATH数据持久化挂载路径/data/db容器内合法路径
Docker 快速启动命令
bash
docker run -d \
  --name delayed-replica-set \
  -p 27017:27017 \
  -p 27018:27018 \
  -e REPLICA_SET_NAME=test-rs \
  -e DELAY_SECONDS=60 \  # 设置60秒同步延迟
  -v ./replica-data:/data/db \  # 挂载数据卷持久化数据
  [镜像名称]:[标签]
Docker Compose 配置示例
yaml
version: '3.8'
services:
  replica-set:
    image: [镜像名称]:[标签]
    container_name: delayed-replica-set
    ports:
      - "27017:27017"  # 主节点端口映射
      - "27018:27018"  # 延迟从节点端口映射
    environment:
      - REPLICA_SET_NAME=test-rs
      - DELAY_SECONDS=60  # 自定义延迟时间(秒)
      - DATA_VOLUME_PATH=/data/db
    volumes:
      - ./replica-data:/data/db  # 数据持久化卷
    restart: unless-stopped
    networks:
      - replica-network

networks:
  replica-network:
    driver: bridge

验证与使用

1. 连接副本集

通过 MongoDB 客户端连接主节点:

bash
mongo --host localhost --port 27017
2. 查看副本集状态

在 MongoDB 客户端中执行以下命令,验证副本集配置及延迟参数:

javascript
rs.status()  // 查看节点状态及角色
rs.conf()    // 查看副本集配置(确认从节点 delay 字段值)
3. 测试延迟同步效果
  1. 在主节点插入测试数据:
    javascript
    use testdb
    db.demo.insertOne({ "timestamp": new Date() })
    
  2. 立即在从节点查询数据(应无法立即获取最新记录):
    bash
    mongo --host localhost --port 27018  # 连接从节点
    use testdb
    db.demo.find()  # 延迟时间内无结果,延迟后可查询到数据
    

注意事项

  • 环境限制:本镜像仅适用于开发、测试环境,生产环境需根据实际需求调整节点数量、延迟策略及安全配置
  • 数据持久化:必须通过挂载卷(volume)实现数据持久化,避免容器重启后数据丢失
  • 延迟从节点选举:默认配置下延迟从节点优先级为0,不会参与主节点选举;如需调整,可通过 rs.reconfig() 修改节点优先级参数

常见问题

Q: 如何修改从节点的延迟时间?

A: 可通过两种方式修改:

  1. 启动时通过 DELAY_SECONDS 环境变量指定
  2. 运行中通过 MongoDB 客户端执行 rs.reconfig() 命令更新配置:
    javascript
    var config = rs.conf()
    config.members[1].secondaryDelaySecs = 120  // 修改第2个节点(从节点)延迟为120秒
    rs.reconfig(config)
    
Q: 从节点为何无法提升为主节点?

A: 延迟从节点默认优先级(priority)设为0,需将其优先级调整为大于0的值(如1)并重启副本集选举流程。

查看更多 mongo-delayed-secondary 相关镜像 →
mongodb/mongodb-atlas-local logo
mongodb/mongodb-atlas-local
by MongoDB
认证
通过Docker创建、管理和自动化MongoDB Atlas Local资源
101M+ pulls
上次更新:5 天前
mongodb/mongodb-community-server logo
mongodb/mongodb-community-server
by MongoDB
认证
官方MongoDB社区服务器是由MongoDB公司推出的免费开源文档数据库服务,专为开发者与技术社区打造,支持以JSON格式存储灵活的非结构化及半结构化数据,具备高可扩展性、易部署性和丰富的查询功能,广泛应用于Web开发、大数据分析、移动应用后端等场景,为用户提供高效的数据管理解决方案并促进社区协作与技术交流。
17410M+ pulls
上次更新:4 天前
mongodb/mongodb-enterprise-server logo
mongodb/mongodb-enterprise-server
by MongoDB
认证
MongoDB官方企业高级服务器是面向企业级应用的高性能、可扩展文档数据库服务器,支持复杂查询、分布式部署与实时数据分析,提供企业级安全特性(如身份验证、数据加密)、完善的数据备份与恢复机制及专业监控工具,助力企业构建稳定高效的现代应用架构,满足大规模数据存储、处理与业务创新需求。
141M+ pulls
上次更新:4 天前
mongodb/mongodb-atlas-search logo
mongodb/mongodb-atlas-search
by MongoDB
认证
Atlas Search提供无缝、可扩展的体验,用于构建基于相关性的应用功能。
31M+ pulls
上次更新:1 个月前
mongodb/mongodb-atlas-kubernetes-operator logo
mongodb/mongodb-atlas-kubernetes-operator
by MongoDB
认证
MongoDB Atlas Kubernetes Operator - 基于Kubernetes原生管理MongoDB Atlas基础设施
51M+ pulls
上次更新:4 天前
mongodb/mongodb-mcp-server logo
mongodb/mongodb-mcp-server
by MongoDB
认证
官方MongoDB MCP服务器镜像,用于部署和运行MongoDB MCP服务,提供官方支持的可靠运行环境。
1100K+ pulls
上次更新:4 天前

轩辕镜像配置手册

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

登录仓库拉取

通过 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的头像

oldzhang

运维工程师

Linux服务器

5

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

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