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

交易
充值流量我的订单

文档

工具

功能
提交工单页面收录

帮助
轩辕镜像免费版

其他
关于我们网站地图
热门搜索:
dbhub

bytebase/dbhub

bytebase

实现模型上下文协议(MCP)服务器接口的通用数据库网关

下载次数: 0状态:社区镜像维护者:bytebase仓库类型:镜像最近更新:12 天前
让 AI 帮你使用轩辕镜像? · 展开查看说明

如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。

只需在 AI 对话中先发送下面这句话即可:

请先完整阅读并严格遵守以下文档中的全部规则与要求:

https://xuanyuan.cloud/agents.md

在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。

查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。

DockerHub 官方简介
轩辕镜像中文简介
标签列表
镜像标签列表与下载命令
轩辕镜像,快一点,稳很多。
点击查看

通用MCP数据库网关镜像

镜像概述和主要用途

本镜像提供一个实现Model Context Protocol (MCP)服务器接口的通用数据库网关,作为中间层组件,用于连接不同类型的数据库系统与遵循MCP协议的客户端应用,实现跨数据库的数据交互、协议转换与请求路由。其核心价值在于简化多数据库环境下的统一访问与集成,降低应用与底层数据库的耦合度。

核心功能和特性

核心功能

  1. 多数据库适配:支持主流关系型数据库(如MySQL、PostgreSQL、Oracle)及NoSQL数据库(如MongoDB、Redis),通过统一接口实现跨数据库访问。
  2. MCP协议实现:完整实现MCP服务器接口规范,支持MCP协议客户端的连接、认证与数据交互。
  3. 数据路由与转换:根据请求上下文动态路由数据查询至目标数据库,并自动处理不同数据库间的数据类型与格式转换。
  4. 请求代理与负载均衡:支持多后端数据库实例的请求分发,实现负载均衡与故障自动切换。

关键特性

  • 通用性:无需修改客户端代码即可适配不同数据库类型,降低集成成本。
  • 低延迟:内置数据缓存机制与优化的协议解析逻辑,减少请求处理延迟。
  • 可扩展性:支持插件化扩展数据库驱动与协议适配模块。
  • 安全性:集成TLS加密传输、基于JWT的客户端认证及细粒度权限控制。
  • 可观测性:提供Prometheus metrics接口与结构化日志,支持监控与问题排查。

使用场景和适用范围

典型使用场景

  1. 企业多数据库集成:企业内部同时使用MySQL、PostgreSQL等多种数据库时,通过本网关为应用提供统一MCP接口,避免应用直接对接多数据库。
  2. 遗留系统现代化改造:旧系统数据库(如DB2、Sybase)通过网关转换为MCP协议接口,供现代微服务应用访问,无需重构遗留数据库。
  3. 跨平台数据服务:不同技术栈(如Java、Python、Go)的应用通过MCP协议统一访问底层数据库,简化跨平台数据交互。
  4. 微服务数据层解耦:微服务架构中,通过网关隔离数据访问层,实现“应用-网关-数据库”的分层架构,提升系统弹性。

适用范围

  • 企业级多数据库环境
  • 数据集成平台与ETL系统
  • 微服务架构的数据访问层
  • 跨技术栈应用的数据库统一访问
  • 需兼容MCP协议的客户端与数据库交互场景

使用方法和配置说明

环境要求

  • Docker Engine 20.10+ 或 Kubernetes 1.21+
  • 目标数据库网络可达(容器需与后端数据库在同一网络或通过端口映射连通)

Docker快速启动(docker run)

通过以下命令快速启动网关,连接至MySQL数据库并暴露MCP服务端口:

bash
docker run -d \
  --name mcp-db-gateway \
  -p 50051:50051 \  # MCP服务端口映射(宿主机:容器)
  -e MCP_PORT=50051 \  # 容器内MCP服务监听端口
  -e DB_TYPE=mysql \  # 后端数据库类型(支持mysql/postgresql/mongodb/redis等)
  -e DB_HOST=mysql-instance \  # 后端数据库主机名/IP
  -e DB_PORT=3306 \  # 后端数据库端口
  -e DB_USER=admin \  # 数据库访问用户名
  -e DB_PASSWORD=secret \  # 数据库访问密码
  -e LOG_LEVEL=info \  # 日志级别(debug/info/warn/error)
  -e AUTH_ENABLED=true \  # 是否启用MCP客户端认证
  -e TLS_ENABLED=true \  # 是否启用TLS加密传输
  -v /path/to/tls/certs:/etc/mcp/tls \  # 挂载TLS证书(若启用TLS)
  mcp-db-gateway:latest

Docker Compose部署

通过docker-compose.yml配置多数据库后端与网关的集成(以MySQL和PostgreSQL为例):

yaml
version: '3.8'
services:
  mcp-gateway:
    image: mcp-db-gateway:latest
    container_name: mcp-db-gateway
    ports:
      - "50051:50051"  # MCP服务端口
    environment:
      - MCP_PORT=50051
      - LOG_LEVEL=info
      - AUTH_ENABLED=true
      - TLS_ENABLED=true
      # 数据库1:MySQL配置
      - DB_1_TYPE=mysql
      - DB_1_HOST=mysql
      - DB_1_PORT=3306
      - DB_1_USER=mysql_user
      - DB_1_PASSWORD=mysql_pass
      - DB_1_NAME=app_db
      # 数据库2:PostgreSQL配置
      - DB_2_TYPE=postgresql
      - DB_2_HOST=pgsql
      - DB_2_PORT=5432
      - DB_2_USER=pgsql_user
      - DB_2_PASSWORD=pgsql_pass
      - DB_2_NAME=analytics_db
    volumes:
      - ./tls:/etc/mcp/tls  # 挂载TLS证书目录(包含server.crt和server.key)
    depends_on:
      - mysql
      - pgsql
    networks:
      - mcp-network

  # 后端数据库服务(示例)
  mysql:
    image: mysql:8.0
    environment:
      - MYSQL_ROOT_PASSWORD=root_pass
      - MYSQL_DATABASE=app_db
      - MYSQL_USER=mysql_user
      - MYSQL_PASSWORD=mysql_pass
    networks:
      - mcp-network

  pgsql:
    image: postgres:14
    environment:
      - POSTGRES_DB=analytics_db
      - POSTGRES_USER=pgsql_user
      - POSTGRES_PASSWORD=pgsql_pass
    networks:
      - mcp-network

networks:
  mcp-network:
    driver: bridge

配置参数说明

核心环境变量

环境变量名描述默认值示例值
MCP_PORTMCP服务器监听端口5005150052
LOG_LEVEL日志级别(debug/info/warn/error/fatal)infodebug
AUTH_ENABLED是否启用MCP客户端认证(true/false)falsetrue
TLS_ENABLED是否启用TLS加密传输(true/false)falsetrue
CACHE_ENABLED是否启用请求缓存(true/false)truefalse
CACHE_TTL缓存过期时间(秒)300600

数据库连接配置(单数据库场景)

环境变量名描述示例值
DB_TYPE后端数据库类型(mysql/pgsql/mongo/redis)mysql
DB_HOST数据库主机名/IPmysql-host
DB_PORT数据库端口3306
DB_USER数据库访问用户名dbuser
DB_PASSWORD数据库访问密码dbpass
DB_NAME目标数据库名称(如适用)app_db

多数据库路由配置(多数据库场景)

通过DB_<N>_*格式的环境变量配置多数据库后端(<N>为数字,从1开始),例如:

  • DB_1_TYPE=mysql
  • DB_1_HOST=mysql-1
  • DB_2_TYPE=pgsql
  • DB_2_HOST=pgsql-1

网关将根据MCP请求中的context字段路由至对应数据库(需客户端请求中携带db_id: <N>上下文参数)。

高级配置(配置文件挂载)

对于复杂配置(如自定义路由规则、细粒度权限策略),可通过挂载配置文件覆盖默认配置。配置文件为YAML格式,路径为/etc/mcp/config.yaml,示例:

yaml
mcp:
  port: 50051
  tls:
    cert_path: /etc/mcp/tls/server.crt
    key_path: /etc/mcp/tls/server.key
  auth:
    jwt:
      secret: "your-jwt-secret"
      expires_in: 3600

databases:
  - id: 1
    type: mysql
    host: mysql-1
    port: 3306
    user: user1
    password: pass1
    name: db1
    routes: ["order_service.*"]  # 仅路由order_service前缀的请求

  - id: 2
    type: pgsql
    host: pgsql-1
    port: 5432
    user: user2
    password: pass2
    name: db2
    routes: ["analytics_service.*"]

cache:
  enabled: true
  ttl: 300
  backend: redis  # 可选:local/redis
  redis:
    host: redis-cache
    port: 6379

通过Docker命令挂载配置文件:

bash
docker run -d \
  --name mcp-db-gateway \
  -p 50051:50051 \
  -v ./config.yaml:/etc/mcp/config.yaml \  # 挂载自定义配置文件
  -v ./tls:/etc/mcp/tls \
  mcp-db-gateway:latest

更多相关 Docker 镜像与资源

以下是 bytebase/dbhub 相关的常用 Docker 镜像,适用于 不同场景 等不同场景:

  • library/postgres Docker 镜像说明
  • cimg/postgres Docker 镜像说明(CI/CD 优化版本)
  • ubuntu/postgres Docker 镜像说明(基于 Ubuntu,稳定性更好)
  • elestio/postgres Docker 镜像说明(托管 PostgreSQL 服务,开箱即用)
  • supabase/postgres Docker 镜像说明(Supabase PostgreSQL 数据库)

镜像拉取方式

您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。

轩辕镜像加速拉取命令点我查看更多 dbhub 镜像标签

docker pull docker.xuanyuan.run/bytebase/dbhub:<标签>

使用方法:

  • 登录认证方式
  • 免认证方式

DockerHub 原生拉取命令

docker pull bytebase/dbhub:<标签>

轩辕镜像配置手册

按平台快速找到配置文档

Docker

登录仓库拉取

登录认证 · 私有仓库

专属域名拉取

免登录 · 高速拉取

Linux

Docker 镜像配置

Windows / Mac

Docker Desktop 配置

MacOS OrbStack

OrbStack 容器

Docker Compose

Compose 项目配置

NAS

群晖

Synology 配置

飞牛

fnOS 镜像配置

绿联

绿联 NAS

威联通

QNAP 配置

极空间

极空间 NAS

企业仓库

其他仓库

ghcr · Quay · nvcr

Harbor 镜像源

Proxy Repository 对接

Portainer 镜像源

Registries 配置

Nexus 镜像源

Docker Proxy 缓存

开发工具

Dev Containers

VS Code 开发容器

Podman

Podman 配置指南

Singularity / Apptainer

HPC 科学计算容器

Kubernetes

K8s Containerd

Kubernetes · Containerd

K3s

轻量级集群

面板 / 网络

爱快路由

iKuai 镜像加速

宝塔面板

一键配置镜像源

AI

用 AI 使用轩辕镜像

agents.md · AI 对话 · 提示词

一键安装

一键安装 Docker

Linux Docker 一键安装

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

镜像拉取常见问题

功能

免费版与专业版区别

功能对比 · 版本选择

支持的镜像仓库

Docker Hub · GCR · GHCR

新手拉取配置

登录 · 专属域名 · 配置

docker search 限制

专属域名 · Hub 搜索

不支持 push

仅支持 pull · 不支持

拉取速度原因

带宽 · 缓存 · 冷热镜像

错误码

402 与流量用尽

402 · 流量包 · 充值

401 认证失败

401 · docker login

manifest unknown

标签错误 · 镜像不存在

410 Gone 排查

410 · Docker 升级

429 限流

免费版 · 请求频率

其他报错

DNS 超时

DNS 解析 · 网络超时

TLS 证书失败

no matching manifest(架构)

账号

失败是否计费

manifest · blob · 计费

申请开发票(企业 / 个人)

企业 · 个人 · 工单

修改登录密码

网站 · 仓库 · 重置

注销账户

工单 · 数据 · 注销

原理

mirrors 不生效

daemon.json · 重启

去掉域名前缀

docker tag · 重命名

指定架构拉取

ARM64 · AMD64 · 多架构

latest 与「最新」

digest · 版本号 · 标签

查看全部问题→

用户好评

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

用户头像

oldzhang

运维工程师

Linux服务器

5

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

轩辕镜像
镜像详情
...
bytebase/dbhub
教程轩辕镜像功能与使用教程
定价查看流量套餐与价格
热门查看热门 Docker 镜像推荐
博客Docker 镜像公告与技术博客
官方公众号:源码跳动|官方技术交流群:831623681
官方公众号:源码跳动|官方技术交流群:|问题咨询请:提交工单
商务合作:点击复制邮箱
©2024-2026 源码跳动
商务合作:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.

更多 dbhub 镜像推荐

bytebase/bytebase logo

bytebase/bytebase

bytebase
面向开发人员和数据库管理员的基于Web的数据库CI/CD工具,唯一被Cloud Native Landscape收录。
22 次收藏100万+ 次下载
3 天前更新
elestio/bytebase logo

elestio/bytebase

elestio
Elestio验证和打包的Bytebase是一款自托管、无数据库的笔记Web应用,使用Markdown文件的扁平文件夹存储内容。
1 次收藏1万+ 次下载
1 年前更新
bytebase/bytebase-action logo

bytebase/bytebase-action

bytebase
暂无描述
5万+ 次下载
3 天前更新
bytebase/star-history logo

bytebase/star-history

bytebase
暂无描述
1万+ 次下载
2 天前更新

查看更多 dbhub 相关镜像