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

Debian上安装PostgreSQL的故障和排除

命令如下:

apt install postgresql

#可能是apt信息错误,报错

E: Failed to fetch http://deb.debian.org/debian/pool/main/p/postgresql-15/postgresql-client-15_15.12-0%2bdeb12u2_amd64.deb  404  Not Found [IP: 146.75.46.132 80]
E: Failed to fetch http://deb.debian.org/debian/pool/main/p/postgresql-15/postgresql-15_15.12-0%2bdeb12u2_amd64.deb  404  Not Found [IP: 146.75.46.132 80]
E: Unable to fetch some archives, maybe run apt-get update or try with --fix-missing?

我没有运行apt-get update,而是用了apt install postgresql --fix-missing,错误依旧,就自己在网上找安装包,结果没有这个版本,就下载了另一个相近的版本。

wget http://ftp.us.debian.org/debian/pool/main/p/postgresql-15/postgresql-client-15_15.13-0+deb12u1_amd64.deb
wget http://ftp.us.debian.org/debian/pool/main/p/postgresql-15/postgresql-15_15.13-0+deb12u1_amd64.deb

dpkg -i postgresql-client-15_15.13-0+deb12u1_amd64.deb安装的时候,又报错说

dpkg: dependency problems prevent configuration of postgresql-client-15:postgresql-client-15 depends on libpq5 (>= 15.13); however:Version of libpq5:amd64 on system is 15.12-0+deb12u2.

又下载了个同版本的wget http://ftp.de.debian.org/debian/pool/main/p/postgresql-15/libpq5_15.13-0+deb12u1_amd64.deb,安装了这个版本的libpq5后,安装客户端不报错了。
dpkg -i postgresql-15_15.13-0+deb12u1_amd64.deb后启动数据库还是有错

/usr/lib/postgresql/15/bin/pg_ctl start -D  /var/lib/postgresql/15/main
waiting for server to start....postgres: could not access the server configuration file "/var/lib/postgresql/15/main/postgresql.conf": No such file or directorystopped waiting

那个目录下确实没有postgresql.conf文件,但有postgresql.auto.conf 文件,而且它的内容是空白的,网上说建立空白postgresql.conf也行,于是cp postgresql.auto.conf postgresql.conf后再次启动,继续报错,比上次有进步:

waiting for server to start....2025-05-31 07:40:55.082 GMT [16] LOG:  starting PostgreSQL 15.13 (Debian 15.13-0+deb12u1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 12.2.0-14+deb12u1) 12.2.0, 64-bit
2025-05-31 07:40:55.082 GMT [16] LOG:  listening on IPv4 address "127.0.0.1", port 5432
2025-05-31 07:40:55.085 GMT [16] LOG:  listening on Unix socket "/var/run/postgresql/.s.PGSQL.5432"
2025-05-31 07:40:55.087 GMT [16] LOG:  could not open configuration file "/var/lib/postgresql/15/main/pg_hba.conf": No such file or directory
2025-05-31 07:40:55.087 GMT [16] FATAL:  could not load pg_hba.conf

继续照抄网上的内容,自己编辑pg_hba.conf的内容如下:

# TYPE  DATABASE        USER            ADDRESS                 METHOD# "local" 是仅在本地机器上通过UNIX域套接字连接的服务。
# "host" 是仅在本地机器上通过TCP/IP连接的服务。
# IPv4 支持 IPv4 和 IPv6 连接协议。
# IPv6 仅支持 IPv6 连接协议。
local   all             all                                     trust
# "local" connections, 无需身份验证
host    all             all             127.0.0.1/32            trust# "host" connections, 身份验证方法是 md5
host    all             all             0.0.0.0/0               md5# "hostssl" connections, 身份验证方法是 cert
hostssl all             all             0.0.0.0/0               cert

再次启动就不报错了。用psql测试连接成功。

psql -d postgres
psql (15.13 (Debian 15.13-0+deb12u1))
Type "help" for help.postgres=# select version();
#测试连接字符串也成功了
psql postgres://postgres@127.0.0.1/postgres

在duckdb中,

duckdb> load postgres;
duckdb> ATTACH 'dbname=postgres user=postgres host=127.0.0.1' AS db (TYPE postgres);
duckdb> create table db.t(a int);
duckdb> insert into db.t values(1);
duckdb> select * from db.t;

之所以出现这么多问题,估计是没有运行apt-get update造成的,以后要注意。

相关文章:

  • 1Remote远程会话管理以及一键启动虚拟机
  • 攻防 FART 脱壳:特征检测识别 + 对抗绕过全解析
  • 终结电源反接与压降损耗:理想二极管控制器深度解析
  • 前端基础学习html+css+js
  • ​​技术深度解析:《鸿蒙5.0+:全场景能效的产业革命》​
  • 第二章 机器学习基本概念
  • Vue组件定义
  • 爱其实很简单
  • AtCoder Beginner Contest 399题目翻译
  • 看问题的本质背后是什么?
  • 《操作系统真相还原》——进入内核
  • 自编码器Auto-encoder(李宏毅)
  • Git深入解析功能逻辑与核心业务场景流程
  • 【Redis】数据类型补充
  • [GESP202412 五级] 奇妙数字
  • 017搜索之深度优先DFS——算法备赛
  • 任务23:创建天气信息大屏Django项目
  • 【火山引擎 大模型批量推理数据教程---详细讲解一篇过!】
  • 文言文停词库 | 古文停词库 | 624个简体停词 |文言文python分词库-thulac
  • OS10.【Linux】yum命令
  • 网站 建设标准/优化电池充电什么意思
  • 优惠活动制作网站/如何建立一个自己的网站
  • 做网站的服务器带宽一般多少/优化设计答案大全英语
  • 如何组做网站/软文营销文章范文
  • 建设网站需要哪些认证/seo网络营销
  • 网站工信部备案号/伟哥seo博客