DOCKER_DATABASE_URL 逐段解析:部署时候的信息解析

DOCKER_DATABASE_URL 逐段解析

复制代码
postgresql://darenku:replace-with-a-strong-password@postgres:5432/darenku
│            │       │                              │       │    │
│            │       │                              │       │    └── 数据库名
│            │       │                              │       └── 端口
│            │       │                              └── 主机名(容器名)
│            │       └── 密码
│            └── 用户名
└── 协议(表示这是 PostgreSQL 数据库)

逐段对应

片段 含义 对应 .env 变量
postgresql:// 协议 用 PostgreSQL 连接 ---
darenku 用户名 登录数据库的账号 POSTGRES_USER
replace-with-a-strong-password 密码 登录数据库的密码 POSTGRES_PASSWORD
postgres 主机名 Docker 容器的服务名 docker-compose 里的服务名
5432 端口 PostgreSQL 默认端口 容器内部端口
darenku 数据库名 要连接哪个库 POSTGRES_DB

为什么主机名是 postgres 而不是 IP?

yaml 复制代码
# docker-compose.yml
services:
  postgres:       # ◄── 这个服务名就是容器间的主机名
    image: postgres:16

  api:
    # api 容器里用 "postgres" 这个名字就能找到数据库容器
    environment:
      - DATABASE_URL=postgresql://darenku:xxx@postgres:5432/darenku
复制代码
┌──────── Docker 内部网络 ────────┐
│                                 │
│   api 容器 ──→ postgres:5432    │
│                    │            │
│              postgres 容器      │
│              (内部监听 5432)     │
│                                 │
└─────────────────────────────────┘

Docker 容器之间通过服务名互相访问,不需要 IP 地址。

对比本地和 Docker 的 URL

bash 复制代码
# 本地开发(从宿主机访问,走映射端口)
DATABASE_URL=postgresql://darenku:darenku@127.0.0.1:35432/darenku
#                                        ^^^^^^^^^ ^^^^^
#                                        宿主机IP   映射端口

# Docker 内部(容器之间访问,走内部网络)
DOCKER_DATABASE_URL=postgresql://darenku:xxx@postgres:5432/darenku
#                                            ^^^^^^^^ ^^^^
#                                            容器服务名 内部端口

简单说:这个 URL 就是告诉 API 容器------"用这个账号密码,去 postgres 容器的 5432 端口,连接 darenku 这个数据库"。

后记

2026年4月23日于上海,在opus 4.6辅助下完成。

相关推荐
weelinking2 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
稳联技术老娜2 小时前
DeviceNet主站怎么连接西门子PLC,Profinet网关配置手册(那智机器人)
服务器·网络·数据库
这个DBA有点耶2 小时前
云上运维新挑战:当数据库不再“看得见摸得着”
数据库·sql·程序人生·云原生·运维开发·学习方法·dba
AskHarries3 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
消失在人海中4 小时前
oracle 数据库多表关联查询
服务器·数据库·oracle
九皇叔叔4 小时前
PostgreSQL/openGauss pg_stats 视图从入门到精通:统计信息、执行计划与慢 SQL 优化实战
数据库·sql·postgresql
gsls2008084 小时前
JVM 堆内存参数 & Docker 容器适配,一次讲清楚
jvm·docker·容器
南极企鹅5 小时前
MySQL间隙锁&临键锁
数据库·sql·mysql
Lumbrologist6 小时前
【零基础部署】Docker 部署 AutoGen 多 Agent 对话框架保姆级教程
运维·docker·容器
TDengine (老段)6 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据