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

openEuler23.09源码编译PostgreSQL16.3实战指南

1. 环境准备与系统配置在openEuler23.09上编译PostgreSQL16.3之前我们需要先做好基础环境配置。我建议使用全新安装的openEuler23.09系统这样可以避免各种依赖冲突问题。通过执行cat /etc/os-release可以确认系统版本输出应该包含VERSION_ID23.09。系统安全策略需要特别注意。我遇到过很多次因为SELinux和防火墙导致的安装失败所以建议先临时关闭它们systemctl stop firewalld systemctl disable firewalld setenforce 0 sed -i s/SELINUXenforcing/SELINUXdisabled/g /etc/selinux/config接下来是依赖包的安装。openEuler的yum源配置比较特殊如果发现某些包找不到可以尝试先挂载安装镜像mount /dev/cdrom /mnt yum install -y cmake make gcc zlib-devel perl readline-devel \ openssl-devel pam-devel libicu-devel python3 tcl-devel2. 源码获取与用户配置PostgreSQL官方源码下载推荐使用国内镜像站加速。我实测清华镜像站速度最快wget https://mirrors.tuna.tsinghua.edu.cn/postgresql/source/v16.3/postgresql-16.3.tar.gz数据库运行需要专用用户这是生产环境的基本安全要求。我习惯使用61600作为UID/GIDgroupadd -g 61600 pgsql useradd -u 61600 -g pgsql -m -d /home/pgsql -s /bin/bash pgsql目录结构设计直接影响后期运维效率。我的标准目录方案是mkdir -p /postgresql/{pgdata,backup,pgsql16,soft} chown -R pgsql:pgsql /postgresql chmod -R 750 /postgresql3. 编译安装过程详解解压源码后进入目录开始编译。这里有个小技巧先清理旧编译结果再开始su - pgsql tar zxvf postgresql-16.3.tar.gz -C /postgresql/soft cd /postgresql/soft/postgresql-16.3 make distclean编译配置参数直接影响数据库性能。我推荐的优化配置是./configure --prefix/postgresql/pgsql16 \ --with-icu \ --with-openssl \ --with-pam \ --with-perl \ --with-python \ --with-tcl \ --with-libxml \ --with-libxslt编译过程可能会遇到各种问题。如果报错缺少icu库需要先安装yum install -y libicu-devel编译完成后安装到指定目录make -j$(nproc) make install4. 数据库初始化与配置环境变量配置很关键建议直接写入.bashrcecho export PGHOME/postgresql/pgsql16 export PGDATA/postgresql/pgdata export PATH$PGHOME/bin:$PATH export LD_LIBRARY_PATH$PGHOME/lib:$LD_LIBRARY_PATH ~/.bashrc source ~/.bashrc初始化数据库集群时字符集选择很重要。对于中文环境推荐initdb -D $PGDATA -E UTF8 --localezh_CN.utf8 -U postgres关键配置文件调整包括postgresql.conf主要参数listen_addresses * max_connections 300 shared_buffers 2GB work_mem 16MB maintenance_work_mem 256MBpg_hba.conf访问控制host all all 192.168.1.0/24 md5启动服务后建议设置开机自启pg_ctl start -D $PGDATA echo pg_ctl start -D $PGDATA -l /postgresql/pgdata/logfile /etc/rc.local chmod x /etc/rc.d/rc.local5. 数据库管理实践首次登录后立即修改超级用户密码ALTER USER postgres WITH PASSWORD YourStrongPassword123!;创建应用数据库的标准流程CREATE USER appuser WITH PASSWORD AppUserPass123; CREATE DATABASE appdb WITH OWNER appuser; GRANT ALL PRIVILEGES ON DATABASE appdb TO appuser;性能监控常用SQL-- 查看活跃连接 SELECT * FROM pg_stat_activity WHERE state active; -- 检查锁等待 SELECT blocked_locks.pid AS blocked_pid, blocking_locks.pid AS blocking_pid FROM pg_catalog.pg_locks blocked_locks JOIN pg_catalog.pg_locks blocking_locks ON blocking_locks.locktype blocked_locks.locktype AND blocking_locks.DATABASE IS NOT DISTINCT FROM blocked_locks.DATABASE AND blocking_locks.relation IS NOT DISTINCT FROM blocked_locks.relation AND blocking_locks.page IS NOT DISTINCT FROM blocked_locks.page AND blocking_locks.tuple IS NOT DISTINCT FROM blocked_locks.tuple AND blocking_locks.virtualxid IS NOT DISTINCT FROM blocked_locks.virtualxid AND blocking_locks.transactionid IS NOT DISTINCT FROM blocked_locks.transactionid AND blocking_locks.classid IS NOT DISTINCT FROM blocked_locks.classid AND blocking_locks.objid IS NOT DISTINCT FROM blocked_locks.objid AND blocking_locks.objsubid IS NOT DISTINCT FROM blocked_locks.objsubid AND blocking_locks.pid ! blocked_locks.pid;6. 常见问题排查编译时报错readline library not found的解决方法yum install -y readline-devel启动时报错could not create shared memory segment的处理sysctl -w kernel.shmmax17179869184 sysctl -w kernel.shmall4194304客户端连接超时问题排查步骤检查postgresql.conf中的listen_addresses确认pg_hba.conf中的访问规则排查防火墙规则测试telnet到5432端口7. 性能优化建议根据服务器配置调整的关键参数# 4核8G服务器示例配置 shared_buffers 2GB effective_cache_size 6GB maintenance_work_mem 512MB checkpoint_completion_target 0.9 random_page_cost 1.1 effective_io_concurrency 200定期维护任务设置# 每周日凌晨3点执行vacuum 0 3 * * 0 pgsql /postgresql/pgsql16/bin/vacuumdb -a -z -v扩展插件安装方法-- 安装常用扩展 CREATE EXTENSION pg_stat_statements; CREATE EXTENSION hstore; CREATE EXTENSION pg_trgm;8. 备份恢复策略物理备份完整流程# 基础备份 pg_basebackup -D /postgresql/backup/basebackup -Ft -z -P -U postgres # 归档配置 echo archive_mode on archive_command cp %p /postgresql/backup/wal/%f $PGDATA/postgresql.conf逻辑备份最佳实践# 全库备份 pg_dumpall -U postgres -f /postgresql/backup/full_backup.sql # 单库备份 pg_dump -U appuser -Fc appdb /postgresql/backup/appdb.dump时间点恢复测试方法# 准备恢复配置 echo restore_command cp /postgresql/backup/wal/%f %p recovery_target_time 2024-03-01 12:00:00 $PGDATA/recovery.conf

相关文章:

openEuler23.09源码编译PostgreSQL16.3实战指南

1. 环境准备与系统配置 在openEuler23.09上编译PostgreSQL16.3之前,我们需要先做好基础环境配置。我建议使用全新安装的openEuler23.09系统,这样可以避免各种依赖冲突问题。通过执行cat /etc/os-release可以确认系统版本,输出应该包含VERSION…...

ADS DC仿真实战:从零构建电源完整性分析

1. 电源完整性分析为何如此重要? 最近在做一个FPGA板卡项目时,我遇到了一个棘手的问题:板卡在低温环境下频繁出现异常重启。经过排查发现,问题出在核心电源轨的压降上。当环境温度降低时,电源网络的阻抗变化导致供电电…...

强力解锁B站字幕:跨平台字幕下载与转换完整方案

强力解锁B站字幕:跨平台字幕下载与转换完整方案 【免费下载链接】BiliBiliCCSubtitle 一个用于下载B站(哔哩哔哩)CC字幕及转换的工具; 项目地址: https://gitcode.com/gh_mirrors/bi/BiliBiliCCSubtitle 你是否曾为B站视频的字幕无法下载而烦恼?想…...

Neat Bookmarks:浏览器书签管理的树状结构解决方案

Neat Bookmarks:浏览器书签管理的树状结构解决方案 【免费下载链接】neat-bookmarks A neat bookmarks tree popup extension for Chrome [DISCONTINUED] 项目地址: https://gitcode.com/gh_mirrors/ne/neat-bookmarks 你是否曾经在数百个杂乱的书签中迷失方…...

Go语言命名规则实战:从变量到包名的完整避坑指南

Go语言命名规则实战:从变量到包名的完整避坑指南 当你第一次接触Go语言时,可能会被它简洁的语法所吸引,但很快就会发现这门语言对命名有着近乎苛刻的要求。我至今还记得刚学Go时,因为一个包名的大小写问题调试了整个下午的经历。本…...

告别驱动烦恼:Universal ADB Driver 让 Windows 连接 Android 设备变得简单

告别驱动烦恼:Universal ADB Driver 让 Windows 连接 Android 设备变得简单 【免费下载链接】UniversalAdbDriver One size fits all Windows Drivers for Android Debug Bridge. 项目地址: https://gitcode.com/gh_mirrors/un/UniversalAdbDriver 还在为连接…...

别再只用Chat模式了!Cursor的Rule和Docs功能,才是提升Java开发效率的隐藏王牌

解锁Cursor的Rule与Docs功能:Java开发者的效率革命 在Java开发领域,我们常常陷入重复性工作的泥潭——手动检查代码规范、翻阅过时的API文档、反复调试基础配置。Cursor编辑器远不止是一个智能补全工具,它的Rule和Docs功能正在悄然改变Java开…...

微信小程序里canvas不跟手滚动?别再用scroll-view了,试试这个官方推荐的替代方案

微信小程序Canvas滚动难题:官方方案与工程实践解析 第一次在小程序里实现类似淘宝详情页的锚点跳转功能时,我信心满满地用scroll-view包住了所有内容区域。直到测试阶段才发现,页面里的UCharts图表就像被钉死在屏幕上一样,完全无…...

WebP图片处理全攻略:如何让Java的Thumbnails支持最新图片格式(含SPI机制解析)

WebP图片处理全攻略:Java生态下的高效解决方案与SPI机制深度解析 WebP作为Google推出的新一代图片格式,凭借其卓越的压缩效率和动画支持能力,正在逐步改变互联网图像存储与传输的格局。根据最新行业统计,采用WebP格式的网站平均可…...

如何快速开始使用BeRoot:权限提升检测的10个核心技巧

如何快速开始使用BeRoot:权限提升检测的10个核心技巧 【免费下载链接】BeRoot Privilege Escalation Project - Windows / Linux / Mac 项目地址: https://gitcode.com/gh_mirrors/be/BeRoot BeRoot Project是一款强大的权限提升检测工具,专为Win…...

从Hello World到生产部署:Agent开发完整教程

从Hello World到生产部署:Agent开发完整教程引言:为什么现在是学习Agent开发的黄金时代? 痛点引入:从“脚本化工具人”到“自主智能助手”的瓶颈 各位读者朋友们,我是老周,一个在互联网摸爬滚打了12年、从传…...

让 ABAP 编码更顺手:全面掌握 ADT 中的预测式代码补全

在现代 ABAP 开发里,代码补全早已不只是 Ctrl + Space 之后弹出一个候选列表那么简单。随着 SAP 在 ADT,也就是 ABAP development tools for Eclipse 中持续引入 AI 辅助能力,Predictive Code Completion 已经从传统补全的补充工具,逐步变成很多开发者日常写代码时的隐形助…...

OpenClaw飞书机器人配置:Qwen3.5-9B多轮对话实战

OpenClaw飞书机器人配置:Qwen3.5-9B多轮对话实战 1. 为什么选择OpenClaw飞书Qwen3.5-9B组合 去年我接手了一个小团队的内部效率优化项目,需要在不增加人力的情况下提升日常事务处理速度。经过几轮技术选型,最终选择了OpenClaw作为自动化核心…...

这份数据挖掘方法实战选择指南,将带你掌握实战中如何选对方法,用好数据挖掘,助力你在实战中斩获佳绩。

好的,针对“机器学习中数据挖掘方法与选择,结合实战使用与实例选择详解”这一问题,我们首先进行解构与推演。 核心问题在于如何在实战中为不同数据集和目标选择合适的预处理与挖掘方法。 答案将聚焦于一个从目标出发、数据驱动、迭代验证的…...

告别手动翻页!用幻影联动+DLL调用,5分钟搞定通达信分时指标自动选股

通达信分时指标自动化选股实战:幻影联动DLL调用的高效解决方案 在瞬息万变的股票市场中,分时级别的交易信号往往转瞬即逝。传统的手动翻页监控方式不仅效率低下,还容易错过最佳买卖时机。本文将详细介绍如何通过幻影联动软件结合DLL调用技术&…...

3步颠覆传统:Hyper-V DDA图形工具让设备直通效率提升10倍

3步颠覆传统:Hyper-V DDA图形工具让设备直通效率提升10倍 【免费下载链接】DDA 实现Hyper-V离散设备分配功能的图形界面工具。A GUI Tool For Hyper-Vs Discrete Device Assignment(DDA). 项目地址: https://gitcode.com/gh_mirrors/dd/DDA 问题发现&#x…...

Claude道歉!爆火研究漏引华人团队成果

点击下方卡片,关注“CVer”公众号AI/CV重磅干货,第一时间送达点击进入—>【顶会/顶刊】投稿交流群添加微信号:CVer2233,小助手拉你进群!扫描下方二维码,加入CVer学术星球!可以获得最新顶会/顶…...

DeepSeek专家模式是什么?从企业架构视角解析AI Agent自动化执行的落地全路径与避坑指南

【摘要】 站在2026年4月的时间节点回看,DeepSeek专家模式的正式上线标志着大模型从“对话工具”向“推理引擎”的质变。然而,作为一名深耕行业15年的企业架构师,我发现许多企业在引入DeepSeek专家模式后,依然面临“能思考、难执行…...

告别手动排版:Illustrator智能填充工具提升设计效率指南

告别手动排版:Illustrator智能填充工具提升设计效率指南 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 问题:设计师为何困在重复劳动中? 为什么…...

Starry Night Art Gallery保姆级教程:BF16精度启用与FP32回退机制

Starry Night Art Gallery保姆级教程:BF16精度启用与FP32回退机制 1. 引言:当艺术创作遇上显存焦虑 想象一下,你正坐在一个数字化的艺术馆里,手握“画笔”,准备创作一幅史诗级的画作。灵感如泉涌,你输入了…...

Filament Shield 高级技巧:如何为第三方插件生成权限和策略

Filament Shield 高级技巧:如何为第三方插件生成权限和策略 【免费下载链接】filament-shield The easiest and most intuitive way to add access management to your Filament Panel; Resources, Pages & Widgets through spatie/laravel-permission 项目地…...

简单实用:Yi-Coder-1.5B代码生成工具快速入门

简单实用:Yi-Coder-1.5B代码生成工具快速入门 1. 为什么选择Yi-Coder-1.5B 如果你正在寻找一个轻量级但功能强大的代码助手,Yi-Coder-1.5B值得考虑。这个仅有15亿参数的模型在编程任务上的表现令人惊喜,特别适合日常开发使用。 Yi-Coder-1…...

AgentCPM研报助手效果展示:看AI如何流式生成一份逻辑严密的深度分析报告

AgentCPM研报助手效果展示:看AI如何流式生成一份逻辑严密的深度分析报告 1. 专业研报生成的新范式 在金融分析、市场研究和技术咨询领域,撰写一份高质量的深度研究报告往往需要耗费分析师数天甚至数周时间。传统AI写作工具虽然能快速生成内容&#xff…...

C++的std--span:非拥有式的连续内存视图

C的std::span:非拥有式的连续内存视图 在现代C编程中,高效且安全地处理连续内存数据是一项常见需求。传统方法通常依赖原始指针或迭代器,但这些方式容易引发越界访问或内存管理问题。C20引入的std::span为此提供了优雅的解决方案——它是一种…...

为什么Webi-installers是开发者的必备神器?10个理由告诉你答案

为什么Webi-installers是开发者的必备神器?10个理由告诉你答案 【免费下载链接】webi-installers Primary and community-submitted packages for webinstall.dev 项目地址: https://gitcode.com/gh_mirrors/we/webi-installers Webi-installers是一个革命性…...

FOC无刷电机驱动笔记:从三相电流到旋转坐标的数学之旅

1. 从三相电流到旋转坐标:FOC控制的核心数学工具 第一次接触FOC(Field Oriented Control)无刷电机控制时,最让我头疼的就是那些复杂的坐标变换。三相电流、克拉克变换、帕克变换...这些名词听起来就像天书。直到我用STM32F407VET6…...

人脸特征精准控制:ComfyUI InstantID技术探索与实践指南

人脸特征精准控制:ComfyUI InstantID技术探索与实践指南 【免费下载链接】ComfyUI_InstantID 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI_InstantID 在AI绘画领域,创作者常面临"人脸失控"的困境——明明输入了清晰的参考照…...

如何构建企业级AI系统:Awesome-Context-Engineering实战教程

如何构建企业级AI系统:Awesome-Context-Engineering实战教程 【免费下载链接】Awesome-Context-Engineering 🔥 Comprehensive survey on Context Engineering: from prompt engineering to production-grade AI systems. hundreds of papers, framewor…...

Arduino-Pico终极安装教程:从Arduino IDE到PlatformIO的完整配置

Arduino-Pico终极安装教程:从Arduino IDE到PlatformIO的完整配置 【免费下载链接】arduino-pico Raspberry Pi Pico Arduino core, for all RP2040 and RP2350 boards 项目地址: https://gitcode.com/gh_mirrors/ar/arduino-pico Arduino-Pico是一款针对Rasp…...

2025届最火的六大降重复率助手实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 专门用于降低文本里人工智能生成内容可检测概率的工具是降AIGC工具,此类工具借助…...