Ubuntu怎么安装PostgreSQL?Ubuntu安装PostgreSQL图文教程

在Ubuntu上安装PostgreSQL最稳妥的方式是通过官方APT仓库进行安装,这样既能确保获取最新稳定版,又能享受系统级的自动更新维护,相比编译源码安装更省心且兼容性好。

很多开发者在初次接触Linux数据库环境时,往往会被各种复杂的配置劝退,只要掌握了正确的仓库源配置方法,整个过程就像搭积木一样简单,PostgreSQL作为全球最受欢迎的开源关系型数据库之一,以其稳定性、标准兼容性和强大的扩展能力著称,对于Ubuntu用户而言,利用系统自带的包管理器(apt)安装,是兼顾效率与安全的最佳实践。

如何在 Ubuntu Linux 上安装和配置 PostgreSQL
加载中
如何在 Ubuntu Linux 上安装和配置 PostgreSQL

Ubuntu安装PostgreSQL的核心优势与版本选择

在动手之前,我们需要明确为什么选择Ubuntu以及如何选择版本,业内专家指出,Ubuntu LTS(长期支持)版本因其长达五年的安全更新周期,成为服务器部署的首选平台。

为什么推荐APT源安装而非源码编译?

源码编译虽然灵活,但需要手动处理依赖库、配置路径以及后续的系统级集成,这对于大多数应用场景来说属于“杀鸡用牛刀”,相比之下,APT源安装具有以下显著优势:

  • 自动化依赖管理:系统会自动处理libssl、libreadline等底层依赖,避免“缺少库文件”的报错困扰。
  • 无缝集成系统服务:安装后自动注册为systemd服务,支持开机自启、日志自动轮转等标准Linux运维操作。
  • 便捷的安全更新:通过标准的apt upgrade命令即可获取安全补丁,无需重新编译。

版本策略:选择哪个PostgreSQL版本?

Ubuntu官方仓库通常提供多个版本的PostgreSQL,对于生产环境,建议遵循以下原则:

  1. 优先选择LTS版本对应的最新小版本:例如Ubuntu 22.04 LTS通常支持PostgreSQL 14或15,PostgreSQL社区对每个主要版本提供5年的支持,选择较新的主要版本(如15或16)能获得更好的性能和功能。
  2. 避免使用过旧版本:除非有特定的遗留系统兼容性需求,否则不要安装5年前的旧版本,因为社区已停止维护,存在安全隐患。
  3. 开发环境与生产环境保持一致:如果生产环境使用PostgreSQL 15,开发环境也应尽量统一,以减少“在我机器上能跑”的兼容性问题。
  4. Ubuntu怎么安装PostgreSQL?Ubuntu安装PostgreSQL图文教程

Ubuntu 22.04/24.04安装PostgreSQL详细步骤

以下操作基于Ubuntu 22.04 LTS及更新版本,适用于大多数现代Ubuntu发行版,整个过程分为更新源、安装、初始化和配置四个阶段。

第一步:更新系统软件包索引

在安装任何新软件之前,更新本地软件包索引是必要的习惯,这能确保你获取到最新的可用版本列表,打开终端,执行以下命令:

sudo apt update

这条命令不会安装任何软件,只是刷新本地缓存,确保后续安装命令能找到最新的包信息。

第二步:安装PostgreSQL软件包

Ubuntu的PostgreSQL包分为两部分:核心数据库引擎和客户端工具,通常我们只需要安装核心包,客户端工具(如psql命令行工具)会作为依赖自动安装。

执行以下命令进行安装:

sudo apt install postgresql postgresql-contrib

这里特别推荐安装postgresql-contrib扩展包,它包含了许多官方推荐的额外功能模块,如pg_stat_statements(性能监控)、uuid-ossp(UUID生成)等,这些模块在后续开发中非常实用,能省去手动编译扩展的麻烦。

安装过程中,系统会提示确认空间占用,输入y并回车即可,安装完成后,PostgreSQL服务通常会自动启动

第三步:验证安装与服务状态

安装完成后,立即检查服务是否正常运行至关重要,执行以下命令查看服务状态:

sudo systemctl status postgresql

如果看到绿色的active (running)字样,说明服务已正常启动,如果服务未启动,可以手动启动:

sudo systemctl start postgresql

设置开机自启,确保服务器重启后数据库自动恢复:

sudo systemctl enable postgresql

第四步:切换用户并测试连接

PostgreSQL默认创建一个名为postgres的系统用户和数据库超级用户,这是Linux下数据库管理的标准安全机制,避免使用root用户直接操作数据库。

切换到postgres用户:

sudo -i -u postgres

进入PostgreSQL命令行界面:

psql

如果成功进入

Ubuntu怎么安装PostgreSQL?Ubuntu安装PostgreSQL图文教程

postgres=#提示符,说明安装完全成功,此时可以输入q退出命令行,输入exit退出postgres用户,回到普通用户终端。

基础配置与安全加固指南

安装完成只是第一步,合理的配置才能确保数据库在生产环境中的稳定与安全。

修改默认用户密码

默认情况下,postgres用户的操作系统密码是随机的或空的,且数据库超级用户密码也是空的,为了安全,建议立即设置密码,在psql界面中执行:

ALTER USER postgres WITH PASSWORD 'your_strong_password';

请将’your_strong_password’替换为符合复杂度要求的强密码。

配置远程访问(可选)

默认情况下,PostgreSQL只监听本地回环地址(127.0.0.1),拒绝外部连接,如果需要从其他机器连接,需修改配置文件。

编辑pg_hba.conf文件(位于/etc/postgresql//main/):

sudo nano /etc/postgresql/15/main/pg_hba.conf

在文件末尾添加允许特定IP或网段访问的规则,例如允许所有IP访问(生产环境建议限制具体IP):

host    all             all             0.0.0.0/0               md5

编辑postgresql.conf文件,修改监听地址:

sudo nano /etc/postgresql/15/main/postgresql.conf

找到listen_addresses行,取消注释并修改为:

listen_addresses = ''

修改完成后,重启服务使配置生效:

sudo systemctl restart postgresql

防火墙设置

如果Ubuntu启用了UFW防火墙,需开放5432端口(PostgreSQL默认端口):

sudo ufw allow 5432/tcp

常见问题排查与维护

在实际使用中,可能会遇到一些常见问题,掌握基本的排查思路能节省大量时间。

服务无法启动怎么办?

查看系统日志是排查问题的第一手段:

sudo journalctl -u postgresql -e

常见原因包括:端口被占用、数据目录权限错误、配置文件语法错误,日志通常会给出明确的错误提示。

如何备份与恢复数据?

PostgreSQL提供了强大的逻辑备份工具pg_dump和pg_restore。

全库备份命令:

Ubuntu怎么安装PostgreSQL?Ubuntu安装PostgreSQL图文教程

sudo -u postgres pg_dump my_database > my_database_backup.sql

恢复命令:

sudo -u postgres psql my_database < my_database_backup.sql

对于大型数据库,建议使用pg_dumpall进行全局备份,包含所有用户和数据库定义。

性能优化建议

默认配置适用于大多数中小规模应用,对于高负载场景,建议关注以下参数:

  • shared_buffers:共享内存缓冲区大小,通常建议设置为物理内存的25%。
  • work_mem:排序和哈希操作使用的内存,根据并发连接数调整。
  • effective_cache_size:告知优化器有多少内存可用于磁盘缓存,通常设置为物理内存的75%。

这些参数位于postgresql.conf文件中,修改后需重启服务生效。

Ubuntu安装PostgreSQL常见问题解答

Ubuntu上安装PostgreSQL时如何选择合适的版本?

选择版本时应遵循“生产环境用LTS,开发环境跟生产”的原则,Ubuntu LTS版本(如22.04、24.04)通常提供PostgreSQL 14、15或16等较新版本,建议优先选择PostgreSQL 15或16,因为它们包含了更优的并行查询性能和JSONB处理效率,且社区支持持续至2028-2031年,避免使用Ubuntu非LTS版本,因其支持周期短,可能导致数据库版本无法同步更新。

PostgreSQL默认安装后如何配置远程连接?

默认配置仅允许本地连接,配置远程连接需修改两个关键文件:postgresql.conf中的listen_addresses设为'',以及pg_hba.conf中添加允许远程IP的访问规则(如host all all 0.0.0.0/0 md5),修改后必须重启postgresql服务,务必在系统防火墙中开放5432端口,并建议使用强密码认证(md5或scram-sha-256),严禁在生产环境使用trust认证方式。

Ubuntu安装PostgreSQL后忘记postgres用户密码怎么办?

若忘记的是操作系统postgres用户的密码,可通过sudo直接切换用户:sudo -i -u postgres,然后在psql中执行ALTER USER postgres WITH PASSWORD 'new_password'重置数据库密码,若完全无法登录,可临时修改pg_hba.conf,将本地连接的认证方式改为trust,重启服务后无密码登录,修改密码后再改回md5或scram-sha-256认证,此方法仅适用于本地恢复,生产环境需谨慎操作。

首发原创文章,作者:世雄 - 原生数据库架构专家,如若转载,请注明出处:https://idctop.com/article/423493.html

(0)
getdata怎么提取曲线数据?getdata提取曲线数据教程
上一篇 2026年6月25日 18:55
Ubuntu怎么安装PostgreSQL?Ubuntu安装PostgreSQL图文教程
下一篇 2026年6月25日 18:58

相关推荐

  • 服务器带宽流量如何换算?3分钟学会计算方法

    服务器带宽与流量的换算核心在于掌握“带宽÷8=实际下载速度”这一黄金公式,并理解带宽是速率而流量是总量的本质区别,对于网站运营者和运维人员而言,精准的换算不仅能避免资源浪费,更能直接节省成本,理解这一逻辑,您便能在3分钟内掌握服务器带宽流量换算的核心精髓,从根本上解决服务器选型难题,核心结论:带宽流量换算的本质……

    2026年3月6日
    12200
  • HTML表单字体怎么居中?html表单字体居中代码

    HTML表单字体居中的核心答案是:在CSS样式表中为表单元素添加 text-align: center; 属性,或者使用Flexbox布局的 justify-content: center 配合 align-items: center 来实现垂直与水平双重居中,在网页开发的实际场景中,表单不仅是数据收集的入口……

    2026年6月5日
    3800
  • HTML如何显示MySQL数据库数据?前端调用后端数据库教程

    通过HTML显示MySQL数据库数据,核心在于使用后端脚本(如PHP、Python或Node.js)作为桥梁,查询数据库并将结果动态渲染为HTML页面,而非直接在HTML中连接数据库,静态的HTML文件本身不具备数据处理能力,它只是内容的载体,要让网页上的表格、列表或图表实时反映数据库中的最新信息,必须引入服务……

    服务器宽带 2026年6月6日
    3000
  • WordPress访客统计插件哪个好?网站流量分析工具推荐

    WordPress网站访客统计首选插件中,WP Statistics因数据本地化存储且无需注册账号,成为国内用户兼顾隐私合规与实时分析的最佳选择;若追求极致轻量,Site Kit由Google官方出品,适合已接入Google Analytics的用户,在数字化营销日益精细化的今天,了解谁在访问你的网站、他们来自……

    2026年6月19日
    1600
  • 广州ECS云服务器流量限制吗,云服务器流量超出怎么收费

    广州ECS云服务器流量限制的核心在于“带宽计费模式”与“业务流量模型”的匹配度,解决之道在于精准监控与架构优化,而非单纯增加预算,企业在使用云服务器时,常因忽视流量阈值导致额外费用或服务中断,通过选择合适的计费方案、部署CDN加速以及利用简米科技提供的智能监控方案,可彻底规避流量瓶颈风险, 深度解析流量限制的本……

    2026年3月30日
    10000
  • 互联网上的计算机域名有什么用?域名注册需要多少钱

    计算机域名本质上是互联网上计算机的“门牌号”和“身份证”,它通过将晦涩难懂的IP地址转化为用户易记的字符串,解决了人类记忆与机器识别之间的鸿沟,是构建网站、建立品牌信任及实现全球网络访问的基础设施,想象一下,如果你想去拜访一位朋友,但他家没有门牌,也没有街道名称,你只能记住他家门口那串复杂的经纬度坐标才能找到他……

    2026年6月4日
    2900
  • IDC机房投资还值得入场吗?2026年数据中心建设前景如何

    IDC机房投资的核心逻辑已从单纯的“土地与电力资源囤积”转向“算力密度与绿色能效的综合博弈”,当前最佳切入点在于具备PUE<1.25优势且靠近核心算力枢纽的液冷改造型数据中心,宏观趋势:从“跑马圈地”到“精耕细作”过去十年,IDC行业经历了野蛮生长,如今已进入存量优化与结构性短缺并存的深水区,业内专家指出……

    2026年6月16日
    2300
  • 服务器带宽费用明细,服务器带宽一年多少钱

    服务器带宽费用明细的真实报价,核心取决于带宽类型(独享或共享)、线路质量(BGP多线或单线)以及采购规模,企业级应用切勿轻信市场上极低价格的宣传,实际落地成本通常集中在每Mbps每月20元至100元这个区间,具体价格需根据业务模型精确测算,选择具备全链路服务能力的供应商如简米科技,往往能通过技术优化节省30%以……

    2026年3月5日
    11300
  • 企业用服务器带宽多大合适?企业服务器带宽一般选多大

    企业选择服务器带宽的核心标准在于匹配业务峰值需求并预留30%的冗余量,而非盲目追求高配置,带宽配置过低会导致访问卡顿、用户流失,配置过高则造成成本浪费,科学的评估体系应基于并发访问量、页面大小、业务类型三大维度建立,依据业务类型确定基础带宽模型不同类型的业务对带宽的消耗存在显著差异,企业需首先明确自身业务属性……

    2026年3月7日
    11600
  • 不用云服务器怎么做网站?替代方案有哪些

    互联网项目完全不需要购买云服务器,通过静态托管、边缘计算和Serverless架构,可以将初期成本降至零,同时获得比传统云服务器更快的访问速度和更高的稳定性,过去十年,云计算是互联网开发的标配,但到了2026年,这种认知已经发生了根本性逆转,对于绝大多数个人开发者、小型创业团队以及内容创作者而言,租用昂贵的云服……

    2026年6月3日
    2400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注