** 注意:此镜像的描述超出了Hub的25000字符长度限制,因此已被截断。完整描述可在[] 注意:这是postgres镜像的arm32v6构建的“每架构”仓库——更多信息,请参见镜像文档中的“除amd64之外的架构?”[]
-** 维护者:**PostgreSQL Docker社区
-** 获取帮助的地方:**Docker社区Slack、Server Fault、Unix & Linux或Stack Overflow
Dockerfile链接18.0-alpine3.22, 18-alpine3.22, alpine3.22, 18.0-alpine, 18-alpine, alpine
18.0-alpine3.21, 18-alpine3.21, alpine3.21
17.6-alpine3.22, 17-alpine3.22, 17.6-alpine, 17-alpine
17.6-alpine3.21, 17-alpine3.21
16.10-alpine3.22, 16-alpine3.22, 16.10-alpine, 16-alpine
16.10-alpine3.21, 16-alpine3.21
15.14-alpine3.22, 15-alpine3.22, 15.14-alpine, 15-alpine
15.14-alpine3.21, 15-alpine3.21
14.19-alpine3.22, 14-alpine3.22, 14.19-alpine, 14-alpine
14.19-alpine3.21, 14-alpine3.21
13.22-alpine3.22, 13-alpine3.22, 13.22-alpine, 13-alpine
13.22-alpine3.21, 13-alpine3.21
-** 问题反馈地址:[*]
-** 支持的架构:**(更多信息) amd64、arm32v5、arm32v6、arm32v7、arm64v8、i386、mips64le、ppc64le、riscv64、s390x
-** 已发布镜像制品详情:**repo-info仓库的repos/postgres/目录(历史记录)(镜像元数据、传输大小等)
-** 镜像更新:**official-images仓库的library/postgres标签 official-images仓库的library/postgres文件(历史记录)
-** 本描述的来源:**docs仓库的postgres/目录(历史记录)
PostgreSQL,通常简称为“Postgres”,是一个对象关系型数据库管理系统(ORDBMS),强调可扩展性和标准合规性。作为数据库服务器,其主要功能是安全地存储数据并支持最佳实践,随后根据其他软件应用程序的请求检索数据,这些应用程序可以在同一台计算机上运行,也可以在网络(包括互联网)上的另一台计算机上运行。它可以处理从小型单机应用到具有大量并发用户的大型互联网应用的工作负载。最新版本还提供数据库本身的复制功能,以提高安全性和可扩展性。
PostgreSQL实现了SQL:2011标准的大部分内容,是ACID兼容的事务型数据库(包括大多数DDL语句),使用多版本并发控制(MVCC)避免锁定问题,提供对脏读的免疫和完全可串行化;使用许多其他数据库不具备的索引方法处理复杂SQL查询;具有可更新视图和物化视图、触发器、外键;支持函数和存储过程以及其他可扩展性,并有大量第三方编写的扩展。除了可以与主要的专有和开源数据库一起使用外,PostgreSQL通过其广泛的标准SQL支持和可用的迁移工具支持从这些数据库迁移。如果使用了专有扩展,通过其可扩展性,可以通过一些内置和第三方开源兼容性扩展(如Oracle兼容扩展)模拟许多专有扩展。
***.org/wiki/PostgreSQL
!logo
console$ docker run --name some-postgres -e POSTGRES_PASSWORD=mysecretpassword -d arm32v6/postgres
默认的postgres用户和数据库在入口点通过initdb创建。
postgres数据库是一个默认数据库,供用户、实用程序和第三方应用程序使用。
postgresql.org/docs
psqlconsole$ docker run -it --rm --network some-network arm32v6/postgres psql -h some-postgres -U postgres psql (14.3) Type "help" for help. postgres=# SELECT 1; ?column? ---------- 1 (1 row)
docker composepostgres的compose.yaml示例:
yaml# 使用postgres/example用户/密码凭据 services: db: image: postgres restart: always # 使用docker compose时设置共享内存限制 shm_size: 128mb # 或通过swarm stack部署时设置共享内存限制 #volumes: # - type: tmpfs # target: /dev/shm # tmpfs: # size: *** # 128*2^20字节 = 128Mb environment: POSTGRES_PASSWORD: example adminer: image: adminer restart: always ports: - 8080:8080
运行docker compose up,等待其完全初始化,然后访问http://localhost:8080或[***](视情况而定)。
有多种扩展postgres镜像的方法。这里不尝试支持所有可能的用例,仅介绍一些我们发现有用的方法。
PostgreSQL镜像使用几个容易被忽略的环境变量。唯一必需的变量是POSTGRES_PASSWORD,其余为可选。
警告:Docker特定变量仅在您使用空数据目录启动容器时才会生效;容器启动时,任何预先存在的数据库都将保持不变。
POSTGRES_PASSWORD此环境变量是使用PostgreSQL镜像所必需的。它不能为空或未定义。此环境变量设置PostgreSQL的超级用户密码。默认超级用户由POSTGRES_USER环境变量定义。
注意1:PostgreSQL镜像在本地设置trust身份验证,因此您可能会注意到从localhost(在同一容器内)连接时不需要密码。但是,如果从不同的主机/容器连接,则需要密码。
注意2:此变量定义PostgreSQL实例中的超级用户密码,由初始容器启动期间的initdb脚本设置。它对运行时psql客户端可能使用的PGPASSWORD环境变量没有影响,如[***]PGPASSWORD,将作为单独的环境变量指定。
POSTGRES_USER此可选环境变量与POSTGRES_PASSWORD一起使用,用于设置用户及其密码。此变量将创建具有超级用户权限的指定用户和同名数据库。如果未指定,则使用默认用户postgres。
请注意,如果指定了此参数,PostgreSQL在初始化期间仍会显示“The files belonging to this database system will be owned by user "postgres"”。这指的是postgres守护进程运行的Linux系统用户(来自镜像中的/etc/passwd),因此与POSTGRES_USER选项无关。有关更多详细信息,请参见标题为“任意--user注意事项”的部分。
POSTGRES_DB此可选环境变量可用于定义镜像首次启动时创建的默认数据库的不同名称。如果未指定,则使用POSTGRES_USER的值。
POSTGRES_INITDB_ARGS此可选环境变量可用于向postgres initdb发送参数。该值是postgres initdb期望的以空格分隔的参数字符串。这对于添加数据页校验和等功能非常有用:-e POSTGRES_INITDB_ARGS="--data-checksums"。
POSTGRES_INITDB_WALDIR此可选环境变量可用于定义Postgres事务日志的另一个位置。默认情况下,事务日志存储在主Postgres数据文件夹(PGDATA)的子目录中。有时,将事务日志存储在不同的目录中可能更可取,该目录可能由具有不同性能或可靠性特征的存储支持。
注意:在PostgreSQL 9.x上,此变量为POSTGRES_INITDB_XLOGDIR(反映了PostgreSQL 10+中--xlogdir标志重命名为--waldir)。
POSTGRES_HOST_AUTH_METHOD此可选变量可用于控制all数据库、all用户和all地址的host连接的auth-method。如果未指定,则使用scram-sha-256密码身份验证(在14+版本中;旧版本中为md5)。在未初始化的数据库上,这将通过以下大致行填充pg_hba.conf:
consoleecho "host all all all $POSTGRES_HOST_AUTH_METHOD" >> pg_hba.conf
有关可能值及其含义的更多信息,请参见PostgreSQL文档中的pg_hba.conf。
注意1:不建议使用trust,因为它允许任何人无需密码即可连接,即使设置了密码(如通过POSTGRES_PASSWORD)。有关更多信息,请参见PostgreSQL文档中的“信任身份验证”。
注意2:如果将POSTGRES_HOST_AUTH_METHOD设置为trust,则不需要POSTGRES_PASSWORD。
注意3:如果将此设置为其他值(例如scram-sha-256),可能需要额外的POSTGRES_INITDB_ARGS才能使数据库正确初始化(例如POSTGRES_INITDB_ARGS=--auth-host=scram-sha-256)。
PGDATA重要变更:PostgreSQL 18及以上版本中,镜像的
PGDATA环境变量已更改为特定于版本。对于18版本,它是/var/lib/postgresql/18/docker。更高版本将把18替换为其各自的主版本(例如,


来自真实用户的反馈,见证轩辕镜像的优质服务
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像加速服务
在 Docker Desktop 配置镜像加速
Docker Compose 项目配置加速
Kubernetes 集群配置 Containerd
在宝塔面板一键配置镜像加速
Synology 群晖 NAS 配置加速
飞牛 fnOS 系统配置镜像加速
极空间 NAS 系统配置加速服务
爱快 iKuai 路由系统配置加速
绿联 NAS 系统配置镜像加速
QNAP 威联通 NAS 配置加速
Podman 容器引擎配置加速
HPC 科学计算容器配置加速
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名加速
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429