Ubuntu22 安装PostgreSQL

Ubuntu 22.04 安装 PostgreSQL 全流程(含踩坑 + 优化 + 远程连接)

适用于:个人开发 / 小型服务 / 云服务器部署

环境:Ubuntu 22.04 + PostgreSQL


📌 一、为什么选择 PostgreSQL?

PostgreSQL 是一个企业级开源关系型数据库,相比 MySQL:

  • 更强的 SQL 标准支持
  • 更适合复杂查询 / 分析
  • JSON / GIS / 扩展能力强
  • 数据一致性更严谨

👉 适合场景:

  • Web 后端(Django / Node / Go)
  • 数据分析系统
  • 日志 / 监控存储
  • 小型 SaaS 项目

🛠️ 二、安装 PostgreSQL

1. 更新系统

复制代码
sudo apt update && sudo apt upgrade -y

2. 安装 PostgreSQL

复制代码
sudo apt install postgresql postgresql-contrib -y

✅ 三、验证安装

复制代码
sudo systemctl status postgresql

👉 正常状态:

复制代码
active (running)

⚠️ 四、重要认知(新手必踩坑)

❗ sudo 要的不是数据库密码!

执行:

复制代码
sudo systemctl restart postgresql

提示输入密码时:

👉 输入的是 Linux 系统用户密码

❌ 不是 PostgreSQL 的密码


❗ postgres 默认没有密码

默认登录方式是:

复制代码
sudo -u postgres psql

原因:

👉 使用的是 peer 认证(系统用户信任)


🧑‍💻 五、进入数据库

复制代码
sudo -i -u postgres
psql

退出:

复制代码
\q

🏗️ 六、创建数据库 & 用户(推荐)

复制代码
-- 创建用户
CREATE USER myuser WITH PASSWORD 'mypassword';

-- 创建数据库
CREATE DATABASE mydb OWNER myuser;

-- 授权
GRANT ALL PRIVILEGES ON DATABASE mydb TO myuser;

🔐 七、修改认证方式(关键)

默认是 peer(本地免密),需要改成密码登录。

编辑配置:

复制代码
sudo nano /etc/postgresql/14/main/pg_hba.conf

找到:

复制代码
local   all   all   peer

改为:

复制代码
local   all   all   md5

🌐 八、开启远程访问(服务器必做)

1. 修改监听地址

复制代码
sudo nano /etc/postgresql/14/main/postgresql.conf

修改:

复制代码
listen_addresses = '*'

2. 配置访问规则

复制代码
sudo nano /etc/postgresql/14/main/pg_hba.conf

新增:

复制代码
host    all    all    0.0.0.0/0    md5

3. 重启服务

复制代码
sudo systemctl restart postgresql

4. 开放端口

复制代码
sudo ufw allow 5432/tcp

🧪 九、连接测试

本地:

复制代码
psql -U myuser -d mydb -h localhost

远程:

复制代码
psql -U myuser -d mydb -h 服务器IP

💡 十、1核1G服务器优化(实战重点)

👉 小内存机器必须优化,否则容易卡死

推荐配置

编辑:

复制代码
sudo nano /etc/postgresql/14/main/postgresql.conf

修改:

复制代码
max_connections = 20
shared_buffers = 128MB
work_mem = 2MB
maintenance_work_mem = 32MB
effective_cache_size = 512MB

开启 swap(强烈建议)

复制代码
sudo fallocate -l 1G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile

持久化:

复制代码
echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab

🚨 十一、常见问题(踩坑合集)

❌ 1. 连接失败(Connection refused)

排查:

复制代码
ss -lntp | grep 5432

检查:

  • listen_addresses
  • 防火墙
  • 服务是否启动

❌ 2. 密码不生效

👉 90% 原因:

  • pg_hba.conf 还是 peer
  • 忘记重启服务

❌ 3. sudo 要密码但不知道

👉 解决:

复制代码
whoami

确认当前用户,然后使用该用户密码。


❌ 4. 服务器卡死 / OOM

👉 原因:

  • 连接数太多
  • 内存配置过大
  • 没有 swap
相关推荐
想唱rap2 小时前
线程之条件变量和生产消费模型
java·服务器·开发语言·数据库·mysql·ubuntu
RInk7oBjo2 小时前
MySQL的编译安装
数据库·mysql·adb
java资料站2 小时前
MySQL 增量同步脚本
android·数据库·mysql
ningmengjing_2 小时前
从零推导出 Redis
数据库·redis
IvorySQL2 小时前
PostgreSQL & IvorySQL 技术交流 Meetup・郑州站| 4.18 线下开讲,只聊硬核技术
数据库·postgresql·开源
iOS妖狐小北2 小时前
mysql中主键索引和联合索引的原理解析
数据库·mysql
大嘴皮猴儿2 小时前
AI图片翻译技术解析:以跨马翻译为例看电商图片翻译的实际效果
大数据·数据库·人工智能·自动翻译·教育电商
FlDmr4i283 小时前
.NET 开发 MCP 服务器完全指南:打造智能数据库查询助手
服务器·数据库·.net
AC赳赳老秦3 小时前
OpenClaw实战案例:用1个主控+3个Agent,实现SEO文章日更3篇
服务器·数据库·python·mysql·.net·deepseek·openclaw