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

源码编译:在现代化环境中部署PostgreSQL 11的实战指南

1. 为什么需要源码编译PostgreSQL 11在当前的数据库运维实践中我们经常会遇到一个尴尬的情况项目需要使用某个特定版本的数据库但官方已经停止提供该版本的二进制安装包。就像我去年遇到的一个金融项目他们的核心系统基于PostgreSQL 11开发由于合规要求不能随意升级版本但服务器需要从CentOS 7迁移到bclinux 8.2这就遇到了安装难题。PostgreSQL官方确实维护了所有历史版本的源码从v1.0到最新版都能找到但二进制包通常只保留最近几个主要版本。以2024年为例官方仓库可能只提供PostgreSQL 12及更高版本的预编译包。这时候源码编译就成了唯一可行的方案。我特别理解这种考古式安装的需求——可能是为了兼容老旧应用可能是为了复现生产环境也可能是为了调试某个只在特定版本出现的问题。无论哪种情况掌握源码编译技能都能让你在关键时刻游刃有余。2. 环境准备与依赖安装2.1 选择合适的Linux发行版在我的多次实践中bclinux 8.2、CentOS 7/8、RHEL等Red Hat系发行版都是很好的选择。这次我们以bclinux 8.2为例因为它兼具稳定性和现代软件支持。先确认系统基本信息cat /etc/os-release uname -r2.2 安装必备编译工具编译PostgreSQL需要一套完整的开发工具链。我建议先更新系统然后安装基础工具sudo yum update -y sudo yum groupinstall Development Tools -y这里有个小技巧如果你在隔离环境中操作可以先在有网络的环境下下载所有rpm包sudo yum install --downloadonly --downloaddir./pg_deps \ gcc make flex bison readline-devel zlib-devel \ openssl-devel pam-devel libxml2-devel libxslt-devel然后通过U盘拷贝到目标机器用rpm -ivh *.rpm安装。2.3 处理依赖关系PostgreSQL 11有几个关键依赖容易出问题readline-devel影响psql命令行体验zlib-devel影响备份压缩功能openssl-devel如果你需要SSL连接我遇到过最头疼的情况是某些依赖的版本冲突。比如某次readline 7.0导致psql无法正常使用退格键最后不得不降级到readline 6.3才解决。建议先用yum list installed检查已安装版本。3. 源码获取与编译配置3.1 下载PostgreSQL 11源码官方源码仓库地址是https://ftp.postgresql.org/pub/source/v11.19/postgresql-11.19.tar.gz我习惯先校验文件完整性wget https://ftp.postgresql.org/pub/source/v11.19/postgresql-11.19.tar.gz wget https://ftp.postgresql.org/pub/source/v11.19/postgresql-11.19.tar.gz.sha256 sha256sum -c postgresql-11.19.tar.gz.sha2563.2 解压与配置解压后进入源码目录tar -xzvf postgresql-11.19.tar.gz cd postgresql-11.19配置阶段有很多选项值得关注。这是我的常用配置模板./configure \ --prefix/opt/pgsql/11 \ --with-openssl \ --with-libxml \ --with-pam \ --with-systemd \ --enable-debug \ --enable-dtrace \ CFLAGS-O2 -g几个关键参数说明--prefix指定安装路径建议放在/opt下--with-openssl启用SSL加密连接CFLAGS-O2优化级别-g保留调试信息如果遇到configure: error仔细看报错信息通常是缺少某个开发包。4. 编译与安装过程详解4.1 编译阶段优化开始编译前建议根据CPU核心数设置并行编译make -j $(nproc)在16核的测试机上完整编译大约需要15-20分钟。如果遇到内存不足可以去掉-j参数单线程编译。我曾经在一台老旧服务器上遇到编译失败最后发现是内存不足导致的。解决方法有两个添加swap空间使用make -j 2限制并行度4.2 安装与目录结构编译成功后执行安装sudo make install安装完成后目录结构应该是这样的/opt/pgsql/11/ ├── bin/ # 客户端和服务器程序 ├── include/ # C语言头文件 ├── lib/ # 库文件 ├── share/ # 文档和配置模板 └── ...建议把bin目录加入PATHecho export PATH/opt/pgsql/11/bin:$PATH ~/.bashrc source ~/.bashrc5. 数据库初始化与配置5.1 创建专用用户安全起见应该使用非root用户运行PostgreSQLsudo groupadd postgres sudo useradd -g postgres postgres sudo passwd postgres5.2 初始化数据目录选择一个足够大的磁盘空间创建数据目录sudo mkdir -p /data/pgsql/11 sudo chown postgres:postgres /data/pgsql/11切换到postgres用户初始化sudo -iu postgres initdb -D /data/pgsql/11 -E UTF8 --localeC--localeC可以避免某些字符集排序问题这在多语言环境中特别重要。5.3 关键配置文件调整postgresql.conf主要修改listen_addresses * # 允许远程连接 max_connections 200 # 根据内存调整 shared_buffers 4GB # 建议内存的25% work_mem 16MB # 每个查询的工作内存 maintenance_work_mem 256MB # 维护操作内存pg_hba.conf配置访问控制# TYPE DATABASE USER ADDRESS METHOD host all all 10.0.0.0/8 md5 local all all peer记得测试配置语法pg_ctl -D /data/pgsql/11 reload6. 服务管理与日常运维6.1 配置systemd服务创建服务文件/etc/systemd/system/postgresql-11.service[Unit] DescriptionPostgreSQL 11 Database Server Afternetwork.target [Service] Typenotify Userpostgres Grouppostgres ExecStart/opt/pgsql/11/bin/postgres -D /data/pgsql/11 ExecReload/bin/kill -HUP $MAINPID KillModeprocess Restarton-failure [Install] WantedBymulti-user.target然后启用服务sudo systemctl daemon-reload sudo systemctl enable postgresql-11 sudo systemctl start postgresql-116.2 基础运维命令检查运行状态pg_ctl -D /data/pgsql/11 status优雅停止pg_ctl -D /data/pgsql/11 stop -m fast查看日志默认在数据目录的log子目录tail -f /data/pgsql/11/log/postgresql-$(date %Y-%m-%d).log7. 安全加固与性能调优7.1 基础安全措施修改默认postgres用户密码psql -U postgres -c ALTER USER postgres WITH PASSWORD 复杂密码;创建业务专用用户createuser -U postgres -P -e 业务用户 createdb -U postgres -O 业务用户 业务数据库7.2 性能监控与调优安装pg_stat_statements扩展CREATE EXTENSION pg_stat_statements;然后在postgresql.conf中添加shared_preload_libraries pg_stat_statements pg_stat_statements.track all查看性能统计SELECT * FROM pg_stat_statements ORDER BY total_time DESC LIMIT 10;8. 常见问题排查问题1启动时报错could not create shared memory segment解决调整内核参数sudo sysctl -w kernel.shmmax17179869184 # 16GB sudo sysctl -w kernel.shmall4194304问题2psql连接时报Ident authentication failed解决修改pg_hba.conf将peer改为md5并reload配置问题3编译时报错fatal error: openssl/ssl.h: No such file or directory解决安装openssl-devel包sudo yum install openssl-devel在实际项目中我还遇到过时区数据缺失的问题。PostgreSQL 11的时区数据需要单独安装sudo yum install postgresql11-tzdata

相关文章:

源码编译:在现代化环境中部署PostgreSQL 11的实战指南

1. 为什么需要源码编译PostgreSQL 11? 在当前的数据库运维实践中,我们经常会遇到一个尴尬的情况:项目需要使用某个特定版本的数据库,但官方已经停止提供该版本的二进制安装包。就像我去年遇到的一个金融项目,他们的核心…...

面试官总问的MESI协议,我用Go写了个模拟器帮你彻底搞懂

用Go模拟MESI协议:从代码运行中理解缓存一致性 记得第一次被问到MESI协议时,我支支吾吾地背出了四个状态名称,却完全不明白它们在实际系统中如何流转。直到后来在调试一个多核并发bug时,亲眼看到缓存不一致导致的数据错误&#xf…...

影刀RPA高级考试实战:用Python绕过反爬,把电影票房数据自动存进MySQL数据库

影刀RPA高级认证实战:Python爬虫与MySQL数据库自动化集成指南 当电影票房数据成为投资决策和市场分析的重要依据时,如何高效获取并结构化存储这些信息就成了技术团队面临的现实挑战。本文将深入探讨如何利用影刀RPA平台结合Python技术栈,构建…...

从零理解UDS故障码:手把手教你解读0x19服务返回的DTC状态位

汽车诊断技术实战:深入解析UDS协议中的DTC状态位机制 1. 汽车电子诊断技术基础 现代汽车已演变为高度复杂的电子系统集合体,平均每辆新车包含超过100个电子控制单元(ECU),这些ECU通过车载网络相互连接。当这些系统出现异常时,统一…...

好写作AI | 学术共同体对AI辅助写作的接纳度与规范共识研究

学术圈怎么看待AI写论文?——有人拥抱,有人警惕,但共识正在形成“我们系现在允许学生用AI查文献、润色语言,但核心论证必须自己写。”“我们导师说,用AI一律按作弊处理。”“我们学校刚出了新规定:使用AI必…...

好写作AI | 导师视角下AI辅助毕业论文写作的指导策略与评判困境

学生用AI写论文,导师怎么办?——管太严怕跟不上时代,管太松怕学术失范“老师,我这篇论文用了AI润色,您看行吗?”“你用的是辅助,还是代写?”“我……我分不太清……”这段对话&#…...

frp - 开源高性能内网穿透神器

背景 在日常开发和运维工作中,我们经常会遇到这样的场景: 在家需要访问公司内网的开发服务器需要将本地开发的小程序或 Web 应用暴露给外部测试远程访问部署在家庭网络的 NAS 或树莓派将内网的 Windows 远程桌面服务暴露给外部访问 这些场景的共同特点…...

好写作AI | AI辅助写作对学位论文原创性评价标准的冲击与应对

原创性不是“没被写过”,是“只有你能写出来”——AI来了,这个标准变了吗?“这篇论文是AI写的,还算原创吗?”“如果我用AI搭框架、自己填内容,原创性怎么算?”“评审老师会不会因为怀疑我用了AI…...

Cal.com:开源日程预约管理平台,Calendly的最佳替代方案

背景 在日常生活和工作中,我们经常需要与他人协调时间: 销售人员需要与潜在客户预约演示时间医生需要为患者安排就诊时间咨询师需要与来访者预约咨询时段导师需要与学生预约会议时间 传统的邮件来回沟通方式效率低下,经常出现时区混淆、时…...

2026最新!降AIGC网站 千笔·降AIGC助手 VS WPS AI,开源免费首选

在AI技术不断渗透学术写作领域的今天,越来越多的学生和研究人员开始依赖AI工具提升写作效率。然而,随着查重系统对AI生成内容的识别能力不断增强,论文中的“AI率超标”问题逐渐成为影响学术成果的关键障碍。无论是知网、维普还是Turnitin&…...

学霸同款 8个降AIGC平台测评:本科生降AI率必看攻略

在当前学术写作中,AI生成内容的普及让论文查重和AIGC率问题变得愈发突出。对于本科生而言,如何在保持原文逻辑与语义的前提下,有效降低AI痕迹和重复率,成为毕业论文撰写过程中的一大挑战。而AI降重工具的出现,为学生提…...

定稿前必看!9个降AIGC工具:论文写作全流程降AI率测评与推荐

在学术论文写作过程中,AI生成内容(AIGC)的痕迹越来越成为高校和科研机构关注的重点。随着查重系统对AI生成内容识别能力的提升,如何有效降低AIGC率、去除AI痕迹,同时保持论文语义通顺、逻辑清晰,已成为每一…...

实测对比后!更贴合论文写作全流程的降AI率网站,千笔·专业降AI率智能体 VS 云笔AI

在AI技术迅速发展的今天,越来越多的学生和研究人员开始借助AI工具辅助论文写作,以提高效率、优化结构甚至生成初稿。然而,随着知网、维普、万方等查重系统不断升级算法,以及Turnitin对AIGC内容的识别愈发严格,AI率超标…...

计算机毕业设计:Python 在线图书销售与协同过滤推荐平台 Django框架 可视化 协同过滤推荐算法 机器学习 大数据 大模型(建议收藏)✅

博主介绍:✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业项目实战6年之久,选择我们就是选择放心、选择安心毕业✌ > 🍅想要获取完整文章或者源码,或者代做,拉到文章底部即可与…...

DVWA靶场实战:手把手教你绕过Medium级别的文件上传限制(附Burp Suite抓包技巧)

DVWA靶场实战:突破Medium级别文件上传限制的技术解析 在Web安全渗透测试的学习过程中,文件上传漏洞始终是一个经典且危险的攻击面。DVWA(Damn Vulnerable Web Application)作为专为安全测试设计的靶场,其Medium级别的文…...

金蝶EAS uploadlogo漏洞实战:如何快速检测你的系统是否受影响

金蝶EAS系统安全检测指南:快速识别uploadlogo漏洞风险 企业级财务管理系统作为核心业务支撑平台,其安全性直接关系到企业财务数据与商业机密的保护。近期曝光的金蝶EAS uploadlogo组件任意文件上传漏洞,可能成为攻击者入侵企业内网的突破口。…...

UEBA实战解析:从异常检测到风险评分的全流程指南

1. UEBA技术入门:为什么需要行为分析? 想象一下你每天上班都会走同一条路,突然某天改道去了完全相反的方向——这就是UEBA(用户和实体行为分析)要捕捉的异常。作为网络安全领域的"行为侦探",UEBA…...

SR-IOV技术解析:如何通过硬件虚拟化提升云主机网络性能

1. 为什么需要SR-IOV技术? 想象一下你租了一间合租房,所有室友共享同一个Wi-Fi路由器。当大家都在刷视频时,网速就会变得卡顿——这就是传统虚拟化网络面临的困境。在云计算环境中,多台虚拟机通过软件模拟的虚拟网卡(如…...

DSGE模型宝典:10分钟掌握宏观经济研究的核心工具箱

DSGE模型宝典:10分钟掌握宏观经济研究的核心工具箱 【免费下载链接】DSGE_mod A collection of Dynare models 项目地址: https://gitcode.com/gh_mirrors/ds/DSGE_mod 想要快速上手DSGE模型研究却苦于无从下手?今天我们来探索一个能让你事半功倍…...

Nginx+ModSecurity实战:5步搭建企业级WAF防护(附规则调优技巧)

NginxModSecurity实战:5步搭建企业级WAF防护(附规则调优技巧) 1. 企业级WAF的核心价值与选型决策 在数字化业务高速发展的今天,Web应用防火墙(WAF)已成为企业安全架构中不可或缺的防线。根据Verizon《2023年数据泄露调查报告》&am…...

cpolar保留TCP地址避坑指南:从后台配置到SSH实战的完整流程

cpolar保留TCP地址深度实战:从配置陷阱到SSH高效访问 在远程访问和网络穿透领域,cpolar作为一款轻量级的内网穿透工具,其保留TCP地址功能为开发者提供了稳定可靠的远程连接方案。本文将深入探讨配置过程中的关键细节,帮助您避开常…...

【科研导航】【计算机视觉与图像处理】从顶刊到潜力股:跨学科(电子/电气/信息)SCI期刊投稿全景图

1. 计算机视觉与图像处理领域的SCI期刊全景图 刚入行的研究生经常问我:"师兄,我这个做图像分割的论文该投哪个期刊?"其实选期刊就像找对象,不仅要门当户对(研究水平匹配期刊层次),还得…...

从HashMap到LinkedHashMap:Java Stream Collectors.toMap自定义Map类型的完整指南

从HashMap到LinkedHashMap:Java Stream Collectors.toMap自定义Map类型的完整指南 在Java 8引入的Stream API中,Collectors.toMap是一个强大但常被低估的工具。它不仅能将流元素转换为Map,还允许开发者精细控制Map的类型和行为。本文将深入探…...

用PlantUML+C4模型轻松绘制软件架构图:实战电商系统设计案例

用PlantUMLC4模型构建电商系统架构图:从理论到实践 在当今快速迭代的软件开发领域,清晰的架构设计文档已成为团队协作的基石。然而,传统绘图工具往往让开发者陷入"美化图表"的泥潭,反而忽视了架构设计的本质思考。本文将…...

香橙派Zero3上1Panel面板的5分钟快速部署指南(附内网穿透配置)

香橙派Zero3极速部署1Panel面板全攻略:从零搭建到远程管理 香橙派Zero3作为一款高性价比的ARM开发板,正在成为个人开发者和轻量级服务器管理的热门选择。而1Panel作为新兴的开源服务器管理面板,以其简洁的界面和强大的Docker管理能力&#xf…...

别再手动改配置了!用Nacos动态管理SkyWalking集群,这5个坑我帮你踩过了

从静态配置到动态治理:SkyWalkingNacos配置中心迁移实战避坑指南 在微服务架构盛行的今天,应用性能监控(APM)系统已成为技术团队不可或缺的运维利器。作为Apache顶级项目,SkyWalking凭借其强大的分布式追踪能力和丰富的指标监控功能&#xf…...

comsol相控阵超声仿真 phased_array_focus 压力声学模块 mph文件

comsol相控阵超声仿真 phased_array_focus 压力声学模块 mph文件相控阵超声在工业检测领域属于高端玩法,这种技术能像魔法师控制声波方向一样精准定位缺陷。不过真要在COMSOL里玩转这个,得先搞明白怎么让一群换能器协同工作——就像指挥交响乐团&#xf…...

单相并网逆变器闭环控制仿真。 单电流环PI控制方式。 电网电压电流同相位锁相。 输入400vdc

单相并网逆变器闭环控制仿真。 单电流环PI控制方式。 电网电压电流同相位锁相。 输入400vdc。最近折腾单相并网逆变器闭环控制仿真有点上头,特别是单电流环PI控制这块,简直就是手把手教电力电子做人的节奏。今天就把自己踩过的坑和代码实操经验扒一扒&am…...

AI率刚好卡在红线上(15%-20%)?精准降到安全区的方法

AI率刚好卡在红线上(15%-20%)?精准降到安全区的方法 学校要求AI率低于15%,你检测出来18%。差3个百分点。就差这么一点。 这种感觉特别难受——论文明明大部分是自己写的,可能就是某几段引用了AI辅助写的内容&#xff0…...

安卓文件管理全攻略:5种方法快速定位下载文件(附三星/谷歌设备专属技巧)

安卓文件管理全攻略:5种方法快速定位下载文件(附三星/谷歌设备专属技巧) 在移动互联网时代,安卓设备已成为我们日常生活的重要组成部分。无论是工作文档、娱乐媒体还是应用安装包,每天都有大量文件被下载到我们的手机或…...