【PostgreSQL】技术传承:使用Docker快速部署PostgreSQL数据库

前言

PostgreSQL的重要贡献者Simon Riggs因一起坠机事故不幸离世。Simon Riggs是英国著名的软件与服务领导者,也是PostgreSQL的主要开发者和贡献者。事故发生在英国当地时间3月26日13:41分,当时他驾驶的私人通用航空Cirrus SR22飞机在英国达克斯福德机场坠毁。

对于这个悲痛事件确实让人深感哀悼,同时也提醒我们珍惜并继续发展那些由伟大的贡献者们留下的宝贵遗产。PostgreSQL作为一个强大的开源对象关系数据库系统,正是Simon Riggs等人的贡献,使其成为了业界广泛使用和尊重的技术之一。

尝试学习和使用PostgreSQL无疑是对Simon Riggs工作最好的致敬。而使用Docker来运行和管理PostgreSQL容器,可以让这个过程变得更加简单和高效。

操作步骤指南

  1. 创建一个docker-compose.yml文件
yaml 复制代码
version: "3.8"
services:
  postgres:
    image: postgres:latest
    restart: always
    ports:
      - "5432:5432"
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: mypgdbpass
      POSTGRES_DB: mydatabase
    volumes:
      - postgres_data:/var/lib/postgresql/data

volumes:
  postgres_data:
  1. 启动服务
bash 复制代码
docker compose up -d

镜像将开始下载,整个过程可能需要1-2分钟,具体取决于您的互联网连接速度。最后,您应该看到一个与下图类似的屏幕,告知容器已成功创建并启动。

  1. 检查状态
bash 复制代码
docker compose ps

检查PostgreSQL的版本,目前latest标签的版本是PostgreSQL 16.2

如果不使用docker compose来启动容器,也可以使用以下方式启动

  • 创建数据卷
bash 复制代码
docker volume create postgres_data
  • 运行PostgreSQL容器并挂载数据卷:
bash 复制代码
docker run --name my_postgres -e POSTGRES_PASSWORD=mypgdbpass -e POSTGRES_USER=postgres -e POSTGRES_DB=mydatabase -p 5432:5432 -v postgres_data:/var/lib/postgresql/data -d postgres:latest
  1. 使用Navicat到PostgreSQL数据库

结尾

通过这种方式,您可以轻松地尝试和学习PostgreSQL,同时也是对Simon Riggs等开源贡献者工作的尊重和传承。继续探索和使用这些工具,您将能够更深入地理解开源技术,并可能为社区做出自己的贡献。

相关推荐
Databend2 小时前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
Suroy8 小时前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭9 小时前
运行你的第一个Docker容器
后端·docker·容器
ClouGence1 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
宋均浩1 天前
# Docker 镜像瘦身实战:从 1.2G 到 80MB 的五个优化步骤
ci/cd·docker
飞将1 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库
程序员老赵2 天前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
Nturmoils2 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
WangMingHua1112 天前
LM Studio Docker 部署——本地大模型一键启动
docker
渣波2 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端