当前位置: 首页 > article >正文

PostgreSQL Docker Error – 5432: 地址已被占用

PostgreSQL Docker Error – 5432: 地址已被占用

今天在学习【Spring Boot + React】价值79.9美元,全栈开发,搭建个人网站、做毕业设计、试试这套课程第17~21节视频的时候,发现运行docker run --name demo-postgres -e POSTGRES_PASSWORD=password -p 5432:5432 -d postgres命令创建docker postgres数据库的容器报错,提示:docker: Error response from daemon: driver failed programming external connectivity on endpoint demo-postgres (e82e78bfe7108768b58298a8f90f50c9605bcadc4c2fca4aed21617a33b721a5): Bind for 0.0.0.0:5432 failed: port is already allocated.
PostgreSQL Docker Error – 5432: 地址已被占用
说明5432端口被占用了,因为我本地Windows11系统之前安装过了Postgres数据库,占用了默认的5432端口

在本文中,我们将介绍在使用 PostgreSQL Docker 时可能遇到的错误:5432:地址已被占用。我们将探讨这个错误的原因以及如何解决它。首先,让我们了解一下 PostgreSQL 和 Docker 的基本概念。
:PostgreSQL 教程

PostgreSQL 简介

PostgreSQL 是一个强大的开源关系型数据库管理系统,具有可靠性、高性能和可扩展性。它支持大量的数据类型和功能,如 ACID 事务、多版本并发控制和完善的数据完整性检查。PostgreSQL 使用 SQL 语言进行数据管理和查询。它是业界认可的一个成熟数据库解决方案,并且在各种应用场景中得到广泛应用。

Docker 简介

Docker 是一个开源的容器化平台,它可以将应用程序及其依赖项打包为一个独立的容器。容器是一个完全自包含的运行环境,其中包含了应用程序运行所需的所有组件,包括操作系统、库文件和环境变量。使用 Docker,我们可以快速部署和管理应用程序,并保证应用程序在不同环境下的一致性。

PostgreSQL Docker Error – 5432: 地址已被占用

在使用 PostgreSQL Docker 容器时,有时候会遇到一个常见的错误:5432:地址已被占用。这个错误通常是由于其他进程或容器已经占用了应用程序默认的 PostgreSQL 端口(5432)所导致的。当我们尝试启动 PostgreSQL 容器时,Docker 引擎会尝试监听端口 5432,但如果端口已经被占用,就会导致这个错误的发生。
如下图所示:
C:\Users\ccf19>docker run --name demo-postgres -e POSTGRES_PASSWORD=password -p 5432:5432 -d postgres

postgres的默认5432端口被占用
由于我本地安装了PostgresSql数据库,默认的5432端口被占用了,导致我执行docker run --name demo-postgres -e POSTGRES_PASSWORD=password -p 5432:5432 -d postgres创建docker容器时,使用5432端口创建容器,报错。

解决 PostgreSQL Docker 错误 – 5432: 地址已被占用,有以下几种方式:

1. 检查已占用的端口
首先,我们可以使用 lsof 命令或 netstat 命令来检查哪个进程或容器占用了端口 5432。在终端中运行以下命令:

lsof -i :5432

netstat -tuln | grep 5432

如果是Windows下,可以输入如下命令:

netstat -ano |findstr :5432

Windows下查找被5432端口占用的进程
这将显示占用端口 5432 的进程或容器的详细信息。根据该信息,您可以决定是停止该进程或容器,还是将 PostgreSQL Docker 容器绑定到另一个可用端口。

2. 修改 Docker 容器端口映射
如果您正在使用 docker run 命令启动 PostgreSQL Docker 容器,可以通过修改端口映射来解决该错误。在命令中添加 -p 参数并指定另一个可用端口,如下所示:

docker run -p <host-port>:5432 postgres

其中 <host-port> 是一个可用的主机端口,用于将主机上的请求转发到 PostgreSQL Docker 容器的端口 5432。通过修改端口映射,您可以避免端口冲突导致的错误。
我在看【Spring Boot + React】价值79.9美元,全栈开发,搭建个人网站、做毕业设计、试试这套课程的P18~P21章节的时候,使用Docker容器来部署配置Postgres数据库容器,但是创建容器的时候发现5432端口被我本地的Postgres数据库占用的,于是可以通过docker run --name demo-postgres -e POSTGRES_PASSWORD=password -p 5437:5432 -d postgres命令创建容器,将主机上的5437端口的请求转发到 PostgreSQL Docker 容器的端口 5432

3. 使用 Docker Compose
如果您使用 Docker Compose 来管理多个容器,并且 PostgreSQL 是其中之一,您可以在 docker-compose.yml 文件中修改 PostgreSQL 服务的端口映射。例如:

services:
  postgres:
    ports:
      - <host-port>:5432

在 YAML 文件中,将 替换为一个可用的主机端口。当使用 docker-compose up 命令启动容器时,Docker Compose 将根据该配置进行端口映射,解决了可能的端口冲突问题。

总结

在本文中,我们介绍了在使用 PostgreSQL Docker 时可能遇到的错误:5432:地址已被占用。我们了解了 PostgreSQL 和 Docker 的基本概念,并探讨了解决这个错误的几种方法。希望本文能帮助您解决 PostgreSQL Docker 错误 – 5432: 地址已被占用,并顺利地使用 PostgreSQL Docker 容器进行开发和部署。

参考资料

  • PostgreSQL Docker Error – 5432: 地址已被占用
  • 【Spring Boot + React】价值79.9美元,全栈开发,搭建个人网站、做毕业设计、试试这套课程-2022 P18 Docker and Postgres
  • 【Spring Boot & React】Spring Boot和React教程 价值79美元 付费完整版-2023
  • PostgreSQL
  • Docker

http://www.kler.cn/news/334010.html

相关文章:

  • 【nlp自然语言】知识图谱,全文检索,自然语言nlp,数据资产标签,集成管理平台
  • 如何使用ssm实现政务大厅管理系统+vue
  • 基于Word2Vec和LSTM实现微博评论情感分析
  • 运行tensorflow报错InternalError: libdevice not found at ./libdevice.10.bc解决方法
  • 墙绘艺术市场:SpringBoot技术驱动的变革
  • 【GEE数据库】WRF常用数据集总结
  • Notepad++ 之 AndroidLogger插件
  • 数据结构-4.2.串的定义和基本操作
  • Python : 类变量、静态方法、类方法
  • 【Verilog学习日常】—牛客网刷题—Verilog企业真题—VL65
  • android compose ScrollableTabRow indicator 指示器设置宽度
  • 如何突破科技服务领域的客户管理困境?
  • [NeurIPS 2022] STaR: Bootstrapping Reasoning With Reasoning
  • 逻辑回归(下): Sigmoid 函数的发展历史
  • 【C++】多态练习题(面试常考)
  • 网络基础 【HTTPS】
  • 【RocketMQ】从 文件/数据结构 视角理解RocketMQ原理
  • 数据库(MySQL):使用命令从零开始在Navicat创建一个数据库及其数据表(一).创建基础表
  • (14)MATLAB莱斯(Rician)衰落信道仿真4
  • Django上下文处理器