
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
SPQR(Stateless Postgres Query Router)是一个生产就绪的PostgreSQL水平扩展系统,通过分片实现查询路由。它作为透明的查询路由器,可将查询分发到多个PostgreSQL实例(分片),同时保持完整的PostgreSQL协议兼容性,使应用无需修改即可使用分片集群。
使用SPQR Router需要先准备PostgreSQL分片实例,建议使用PostgreSQL 15及以上版本。
docker run启动SPQR Router实例bash# 创建网络 docker network create spqr-net # 启动PostgreSQL分片 docker run -d --name shard1 --network spqr-net \ -e POSTGRES_PASSWORD=password -e POSTGRES_USER=user1 -e POSTGRES_DB=db1 \ postgres:15 docker run -d --name shard2 --network spqr-net \ -e POSTGRES_PASSWORD=password -e POSTGRES_USER=user1 -e POSTGRES_DB=db1 \ postgres:15 # 启动SPQR Router docker run -d --name spqr-router --network spqr-net \ -p 6432:6432 -p 7432:7432 \ -v $(pwd)/router.yaml:/etc/spqr/router.yaml:ro \ pgsharding/spqr-router:latest
上述命令创建了一个SPQR路由器,监听6432端口(数据查询)和7432端口(管理命令)。
docker compose启动创建docker-compose.yml文件:
yamlversion: '3.8' services: shard1: image: postgres:15 environment: POSTGRES_USER: user1 POSTGRES_PASSWORD: password POSTGRES_DB: db1 shard2: image: postgres:15 environment: POSTGRES_USER: user1 POSTGRES_PASSWORD: password POSTGRES_DB: db1 spqr-router: image: pgsharding/spqr-router:latest ports: - "6432:6432" # 路由端口 - "7432:7432" # 管理控制台 volumes: - ./router.yaml:/etc/spqr/router.yaml:ro depends_on: - shard1 - shard2
启动服务:
bashdocker compose up -d
SPQR通过YAML文件进行配置。创建router.yaml:
yamlhost: '0.0.0.0' router_port: '6432' admin_console_port: '7432' router_mode: PROXY log_level: info frontend_rules: - usr: user1 db: db1 pool_mode: TRANSACTION auth_rule: auth_method: ok shards: shard1: db: db1 usr: user1 pwd: password type: DATA tls: sslmode: disable hosts: - 'shard1:5432' shard2: db: db1 usr: user1 pwd: password type: DATA tls: sslmode: disable hosts: - 'shard2:5432' backend_rules: - usr: user1 db: db1 connection_limit: 100
配置项说明:
host: 路由器监听地址router_port: 数据查询端口admin_console_port: 管理控制台端口router_mode: 路由模式(PROXY)log_level: 日志级别(debug/info/warn/error)frontend_rules: 前端连接规则,定义用户和数据库的匹配关系shards: 分片配置,包含各分片的连接信息backend_rules: 后端连接规则,定义连接限制等启动SPQR后,连接管理控制台配置分片规则:
bashpsql "host=localhost port=7432 user=user1 dbname=db1 sslmode=disable"
创建分布和定义键范围:
sql-- 创建基于整数的分布 CREATE DISTRIBUTION ds1 COLUMN TYPES integer; -- 将表附加到分布 ALTER DISTRIBUTION ds1 ATTACH RELATION orders DISTRIBUTION KEY id; -- 定义键范围(1-999 → shard1,1000+ → shard2) CREATE KEY RANGE kr1 FROM 1 ROUTE TO shard1 FOR DISTRIBUTION ds1; CREATE KEY RANGE kr2 FROM 1000 ROUTE TO shard2 FOR DISTRIBUTION ds1;
连接路由端口,像使用普通PostgreSQL数据库一样操作:
bashpsql "host=localhost port=6432 user=user1 dbname=db1 sslmode=disable"
执行SQL操作:
sqlCREATE TABLE orders (id INTEGER PRIMARY KEY, customer TEXT, total DECIMAL); INSERT INTO orders VALUES (100, 'Alice', 150.00); -- 路由到shard1 INSERT INTO orders VALUES (1500, 'Bob', 200.00); -- 路由到shard2 SELECT * FROM orders WHERE id = 100; -- 查询shard1 SELECT * FROM orders; -- 查询所有分片
| 环境变量 | 说明 | 默认值 |
|---|---|---|
SPQR_ROUTER_PORT | 覆盖路由端口 | 配置文件中的值 |
SPQR_ADMIN_PORT | 覆盖管理控制台端口 | 配置文件中的值 |
SPQR_LOG_LEVEL | 设置日志级别 | info |
6432: 路由端口(PostgreSQL协议)- 应用程序连接此端口7432: 管理控制台(PostgreSQL协议)- 配置分片规则7000: gRPC API - 程序化管理和监控pgsharding/spqr-router:<version>生产环境推荐使用此镜像,包含SPQR路由器二进制文件和最小运行时依赖(约50MB)。
支持的标签
latest, stable: 最新稳定版本v1.2.3, v1.2, v1: 特定版本标签nightly: 从master分支构建(最新功能,用于测试)nightly-<git-hash>: 特定夜间构建prerelease: 最新预发布版本(alpha、beta、rc)如遇到镜像相关问题,请在https://github.com/pg-sharding/spqr/issues%E6%8F%90%E4%BA%A4issue%E3%80%82
如需一般使用问题和讨论,可加入我们的***聊天。
SPQR是开源项目,欢迎贡献!详情请查看https://github.com/pg-sharding/spqr%E3%80%82
SPQR源代码采用PostgreSQL全球开发组许可证分发。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。

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