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
相关推荐
ss27310 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
l1t10 小时前
DeepSeek总结的数据库外部表
数据库
m0_6742946410 小时前
如何编写SQL存储过程性能对比_记录执行时间评估优化效果
jvm·数据库·python
014-code11 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
运气好好的11 小时前
怎样开启phpMyAdmin的操作审计日志_记录每条执行的SQL
jvm·数据库·python
それども11 小时前
DELETE 和 TRUNCATE TABLE区别
java·数据库·mysql
wenha11 小时前
数据库隔离级别
数据库·mysql·sqlserver·隔离级别
2401_8714928511 小时前
Layui如何修改Layui默认的UI主题颜色(换肤功能实现)
jvm·数据库·python
Edward1111111112 小时前
4.27mysql ,数据库,数据源
数据库·mysql
小徐敲java12 小时前
踩坑实录:MySQL8.0 导入SQL报错 2006 - MySQL server has gone away 完美解决
数据库·sql