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

告别sudo!手把手教你无root权限在Linux服务器上源码编译安装PostgreSQL 14

告别sudo手把手教你无root权限在Linux服务器上源码编译安装PostgreSQL 14在共享开发环境或受限权限的服务器上数据库部署常常面临权限壁垒。想象这样一个场景你刚拿到实验室服务器的普通账号急需搭建PostgreSQL进行数据分析却发现自己既不能sudo安装软件包也无法写入系统目录。这种困境在高校实验室、企业测试环境和云平台共享实例中屡见不鲜。本文将彻底解决这个痛点——通过源码编译方式在用户主目录下构建完整的PostgreSQL运行环境。与常见的yum/apt安装不同这种方法完全绕过系统包管理器所有文件都存放在~/pgsql这样的自定义路径中。更关键的是整个过程不需要任何root权限操作却能获得与系统级安装完全一致的功能体验。1. 环境准备与源码获取1.1 系统依赖检查在开始编译前需要确认基础构建工具链的可用性。打开终端执行以下检查# 检查GCC编译器 gcc --version | head -n1 # 检查GNU make版本必须≥3.80 make --version | head -n1 # 检查必备开发库 ls /usr/include/{zlib.h,readline.h} 2/dev/null如果缺少关键组件可以尝试在用户空间安装# 在用户目录安装GCC示例 mkdir ~/gcc-build cd ~/gcc-build wget https://ftp.gnu.org/gnu/gcc/gcc-11.2.0/gcc-11.2.0.tar.gz tar xzf gcc-11.2.0.tar.gz cd gcc-11.2.0 ./configure --prefix$HOME/.local --disable-multilib make -j$(nproc) make install1.2 源码下载与验证从PostgreSQL官方镜像站获取源码时建议选择离你地理位置最近的镜像# 创建构建目录 mkdir -p ~/build/pgsql cd ~/build/pgsql # 下载源码包和校验文件 wget https://ftp.postgresql.org/pub/source/v14.5/postgresql-14.5.tar.gz{,.sha256} # 验证文件完整性 sha256sum -c postgresql-14.5.tar.gz.sha256解压时使用-C参数指定目标目录tar xzf postgresql-14.5.tar.gz -C ~/build/pgsql --strip-components12. 定制化编译配置2.1 configure参数解析进入解压后的目录运行./configure --help可以看到上百个配置选项。对于无root安装这几个核心参数尤为重要参数作用典型值--prefix安装根目录$HOME/pgsql--with-opensslSSL加密支持openssl--with-uuidUUID生成支持ossp--with-libxmlXML处理支持yes--with-libxsltXSLT转换支持yes实际执行配置命令示例./configure \ --prefix$HOME/pgsql \ --with-openssl \ --with-uuidossp \ --with-libxml \ --with-libxslt \ --enable-debug2.2 依赖库路径处理当系统库不在标准路径时需要通过环境变量指定export CPPFLAGS-I$HOME/.local/include export LDFLAGS-L$HOME/.local/lib -Wl,-rpath$HOME/.local/lib常见依赖问题的解决方案readline缺失使用--without-readline禁用zlib问题添加--with-zlib/custom/pathSSL错误指定--with-openssl/usr/local/ssl3. 构建与安装流程3.1 并行编译优化利用多核CPU加速编译make -j$(nproc) world build.log 21 tail -f build.log # 实时监控编译进度关键阶段说明Bootstrap阶段生成解析器代码约3分钟核心编译构建服务端二进制约15分钟扩展编译contrib模块构建约5分钟3.2 用户级安装安装到预设目录make install-world # 包含文档和所有扩展目录结构说明~/pgsql/ ├── bin/ # 客户端工具 ├── include/ # 开发头文件 ├── lib/ # 共享库 ├── share/ # 文档和配置模板 └── data/ # 数据库集群后续初始化4. 数据库初始化与管理4.1 定制化初始化创建专属数据库集群initdb \ -D $HOME/pgsql/data \ -E UTF8 \ --localeen_US.UTF-8 \ --data-checksums关键参数解析-D数据目录位置-E默认编码推荐UTF8--data-checksums启用页校验影响性能但更安全4.2 服务启动脚本创建管理脚本~/bin/pgctl#!/bin/bash PGDATA$HOME/pgsql/data PGLOG$HOME/pgsql/logfile case $1 in start) pg_ctl start -D $PGDATA -l $PGLOG ;; stop) pg_ctl stop -D $PGDATA -m fast ;; status) pg_ctl status -D $PGDATA ;; *) echo Usage: $0 {start|stop|status} exit 1 esac赋予执行权限chmod x ~/bin/pgctl4.3 环境变量配置在~/.bashrc末尾添加export PGHOME$HOME/pgsql export PATH$PGHOME/bin:$PATH export LD_LIBRARY_PATH$PGHOME/lib:$LD_LIBRARY_PATH export PGDATA$PGHOME/data立即生效source ~/.bashrc5. 高级配置技巧5.1 远程访问设置修改$PGDATA/postgresql.conflisten_addresses 0.0.0.0 port 5432 max_connections 100配置客户端认证$PGDATA/pg_hba.conf# TYPE DATABASE USER ADDRESS METHOD host all all 192.168.1.0/24 md55.2 性能调优参数针对开发环境的推荐配置shared_buffers 128MB work_mem 8MB maintenance_work_mem 64MB effective_cache_size 512MB random_page_cost 1.15.3 自动启动方案通过crontab实现开机启动(crontab -l 2/dev/null; echo reboot $HOME/bin/pgctl start) | crontab -6. 日常维护与问题排查6.1 备份策略创建简易备份脚本~/bin/pgbackup#!/bin/bash BACKUP_DIR$HOME/pgsql/backups/$(date %Y%m%d) mkdir -p $BACKUP_DIR pg_dumpall -U postgres | gzip $BACKUP_DIR/full.sql.gz6.2 常见错误处理问题1libpq.so.5: cannot open shared object file解决方案export LD_LIBRARY_PATH$HOME/pgsql/lib:$LD_LIBRARY_PATH问题2could not connect to server: No such file or directory检查服务状态pg_ctl status -D $PGDATA6.3 版本升级路径源码升级的标准流程停止旧版本服务安装新版本到不同目录如~/pgsql14使用pg_upgrade迁移数据验证后切换环境变量在项目迁移到Kubernetes环境时这种用户级安装的PostgreSQL可以直接打包进容器镜像比传统系统级安装更具灵活性。某金融公司的开发团队就通过这种方式在严格管控的中央服务器上为每个项目组建立了独立的数据库实例。

相关文章:

告别sudo!手把手教你无root权限在Linux服务器上源码编译安装PostgreSQL 14

告别sudo!手把手教你无root权限在Linux服务器上源码编译安装PostgreSQL 14 在共享开发环境或受限权限的服务器上,数据库部署常常面临权限壁垒。想象这样一个场景:你刚拿到实验室服务器的普通账号,急需搭建PostgreSQL进行数据分析&…...

卷积与傅里叶变换的视觉化解析及DSP应用

1. 卷积与离散傅里叶变换的视觉化解析数字信号处理(DSP)的核心数学工具中,卷积和傅里叶变换无疑是最重要的两个概念。当我第一次接触这些理论时,复杂的公式推导让我望而生畏。直到有一天,我尝试用图形化的方式来理解这…...

【电赛封神榜】ADC采样总是漏数据?STM32“双缓冲DMA+Cache一致性+DSP加速”终极架构解析

前言:在全国大学生电子设计竞赛(仪器仪表类、信号处理类)中,**“高频信号采集与处理”**是永远的考点。无论是做示波器、频谱分析仪,还是电网参数测量,第一步都是用 ADC 把模拟信号抓进内存。很多同学在 F1…...

高性能工控机在高精度机器人中的应用

大家好,我是阿强,从事工业控制技术工作 17 年。在半导体制造、精 密装配、医用设备、航 空 航 天等领域,对机器人的精度和速度有着很高的要求。这些高精度机器人需要处理大量的复杂数据,运行复杂的运动控制算法和视觉检测算法&…...

低功耗工控机在电池供电机器人中的应用

大家好,我是阿强,在工控行业深耕了 17 年。如今,移动机器人已经广泛应用于物流、仓储、巡检、配送等各个领域,而续航能力一直是制约移动机器人发展的关键因素。电池供电的机器人对控制单元的功耗有着非常严格的要求,低…...

从产品抽检到网站点击率:二项分布近似在实际业务中的5个应用场景与Python实现

二项分布近似在业务决策中的实战指南:5个场景与Python实现 当产品经理需要评估新功能上线后的用户转化率,或是数据分析师要预测广告点击量的波动范围时,二项分布及其近似方法往往能成为决策工具箱里的秘密武器。不同于教科书中的理论推导&…...

3分钟搞定Windows安卓驱动:最新ADB/Fastboot一键安装全攻略

3分钟搞定Windows安卓驱动:最新ADB/Fastboot一键安装全攻略 【免费下载链接】Latest-adb-fastboot-installer-for-windows A Simple Android Driver installer tool for windows (Always installs the latest version) 项目地址: https://gitcode.com/gh_mirrors/…...

保姆级教程:手把手教你用ROS驱动Ouster OS1激光雷达(含编译避坑指南)

ROS实战:Ouster OS1激光雷达从驱动配置到高级应用全解析 激光雷达作为机器人感知环境的核心传感器,其性能与集成效率直接影响着SLAM、导航等关键系统的表现。Ouster OS1系列凭借出色的性价比和稳定的性能,已成为众多机器人开发团队的首选。本…...

实测对比:Windows远程桌面、ToDesk、向日葵,谁才是看视频不卡的远程神器?

远程桌面工具横评:谁才是流畅观影的最佳选择? 在居家办公和远程协作日益普及的今天,远程桌面工具已经成为许多人日常工作娱乐的必备软件。特别是对于需要在不同设备间观看视频的用户来说,流畅度和画质表现直接决定了使用体验。面对…...

别急着改java.security!排查JDBC连SQL Server报TLS错误的3个更优思路

别急着改java.security!排查JDBC连SQL Server报TLS错误的3个更优思路 当你在使用JDBC连接SQL Server时遇到"The server selected protocol version TLS10 is not accepted by client preferences"的错误,大多数技术文章会直接建议你修改java.s…...

当你的无人机被厂商“绑架“:如何用DankDroneDownloader夺回控制权

当你的无人机被厂商"绑架":如何用DankDroneDownloader夺回控制权 【免费下载链接】DankDroneDownloader A Custom Firmware Download Tool for DJI Drones Written in C# 项目地址: https://gitcode.com/gh_mirrors/da/DankDroneDownloader 你是否…...

Spring Security的会话管理

Spring Security的会话管理在保障应用程序安全方面起着至关重要的作用,它负责管理用户会话的创建、维护和销毁等操作。以下详细介绍Spring Security会话管理的相关内容: 1. 会话管理的作用 用户状态跟踪:通过会话,Spring Security可以跟踪用户的登录状态,从而确定用户是否…...

KEA128与S32K144的LIN主从机实战:从硬件对接到波形调试全记录

KEA128与S32K144的LIN总线异构通信实战:从硬件设计到波形分析的完整指南 在汽车电子系统中,LIN总线作为CAN网络的补充,广泛应用于车门、座椅、空调等低复杂度控制场景。本文将基于NXP KEA128和S32K144两款不同架构的MCU,构建一个完…...

彻底告别Grub引导错误:用Boot-Repair图形化工具一键修复Ubuntu启动项(附Live USB制作指南)

彻底告别Grub引导错误:用Boot-Repair图形化工具一键修复Ubuntu启动项(附Live USB制作指南) 每次开机看到那个冷冰冰的Grub命令行界面,是不是感觉像被扔进了技术深渊?特别是当屏幕上出现"Minimal BASH-like line …...

拒绝标题党!真正可用的AI试衣系统源码,带Web界面

温馨提示:文末有资源获取方式最近有不少人在问有没有靠谱的AI试衣方案,网上搜了一圈,发现要么是夸大其词的标题党,要么根本跑不起来。今天就分享一套真正可用的源码,带完整Web界面,实测有效。这套系统能做什…...

Bioicons:如何在10分钟内为科研论文找到完美的免费矢量图标?

Bioicons:如何在10分钟内为科研论文找到完美的免费矢量图标? 【免费下载链接】bioicons A library of free open source icons for science illustrations in biology and chemistry 项目地址: https://gitcode.com/gh_mirrors/bi/bioicons Bioic…...

从验证小白到SVA高手:我是如何通过《SystemVerilog Assertions and Functional Coverage》这本书搞定芯片验证的

从验证小白到SVA高手:我的SystemVerilog断言进阶之路 第一次接触SystemVerilog断言(SVA)时,那种既熟悉又陌生的感觉至今记忆犹新。作为Verilog的延伸,语法看起来似曾相识,但那些神秘的"assert"、…...

Qwen3-ForcedAligner-0.6B与WhisperX对比评测:时间戳精度提升77%

Qwen3-ForcedAligner-0.6B与WhisperX对比评测:时间戳精度提升77% 语音时间戳对齐技术正在重塑音频内容处理的标准,而精度提升77%意味着什么?这不仅仅是数字的变化,更是整个行业处理效率的质的飞跃。 1. 评测背景与方法 在语音处理…...

从代码到财富:程序员的量化投资跃迁之路

《A股因子投资实战:从理论到策略实现》 推荐序言 当你计划阅读本专栏时,你可能正站在一个重要的十字路口——一边是熟悉的代码世界,另一边是充满挑战但也机遇无限的金融市场。作为程序员,你已经掌握了这个时代最重要的技能之一&am…...

别再乱用disable fork了!手把手教你用guard_fork精准控制SystemVerilog线程

精准掌控SystemVerilog线程:guard_fork防御性编程实践 在验证环境开发中,多线程控制是每个工程师必须面对的挑战。想象一下这样的场景:你的monitor正在后台持续采集数据,而某个测试用例触发了超时机制,直接使用disable…...

为什么HPC环境更推荐Singularity而非Docker?CentOS7.9实战安装教程

为什么HPC环境更推荐Singularity而非Docker?CentOS7.9实战安装教程 高性能计算(HPC)环境中,容器化技术已成为科研工作流的重要组成部分。不同于企业级应用场景,HPC集群对安全性、多用户隔离和资源调度有着更严格的要求…...

nli-MiniLM2-L6-H768实际效果:多模态场景下文本前提与图像假设的跨模态NLI探索

nli-MiniLM2-L6-H768实际效果:多模态场景下文本前提与图像假设的跨模态NLI探索 1. 模型介绍与核心能力 nli-MiniLM2-L6-H768是一个基于自然语言推理(NLI)的轻量级模型,专门用于判断两个句子之间的逻辑关系。这个630MB的精简模型在保持高性能的同时&…...

Python字典视图对象的5个隐藏用法:从数据比对到多线程监控

Python字典视图对象的5个隐藏用法:从数据比对到多线程监控 在Python开发中,字典是最常用的数据结构之一。大多数开发者对字典的基本操作如添加、删除、修改键值对都很熟悉,但很少有人深入了解字典视图对象(dict_keys, dict_values, dict_item…...

空洞骑士模组管理革命:Lumafly一键安装300+模组的终极解决方案

空洞骑士模组管理革命:Lumafly一键安装300模组的终极解决方案 【免费下载链接】Lumafly A cross platform mod manager for Hollow Knight written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/lu/Lumafly Lumafly是一款专为《空洞骑士》玩家设…...

告别Xamarin!用.NET MAUI从零构建你的第一个跨平台App(Windows桌面+安卓双端运行实录)

从Xamarin到.NET MAUI:跨平台开发的现代化迁移指南 如果你是一位熟悉Xamarin.Forms的开发者,可能已经注意到微软正在将跨平台移动开发的重心转向.NET MAUI(Multi-platform App UI)。这个新一代框架不仅继承了Xamarin.Forms的优势…...

Pixel Aurora EngineGPU利用率提升教程:diffusers流水线并行优化

Pixel Aurora Engine GPU利用率提升教程:diffusers流水线并行优化 1. 认识Pixel Aurora Engine Pixel Aurora Engine是一款基于AI扩散模型的高端绘图工作站,采用独特的8-bit像素风格界面设计。这款"虚拟游戏机"能将文字描述转化为极具视觉冲…...

Navicat Mac版无限试用终极指南:3种方法突破14天限制

Navicat Mac版无限试用终极指南:3种方法突破14天限制 【免费下载链接】navicat_reset_mac navicat mac版无限重置试用期脚本 Navicat Mac Version Unlimited Trial Reset Script 项目地址: https://gitcode.com/gh_mirrors/na/navicat_reset_mac 还在为Navic…...

告别单调界面:用ESP32和LVGL 8.1的Style背景API打造炫酷UI(附渐变/图片实战代码)

告别单调界面:用ESP32和LVGL 8.1的Style背景API打造炫酷UI(附渐变/图片实战代码) 你是否厌倦了嵌入式设备上那些千篇一律的灰色矩形和生硬的按钮?在智能家居面板或工业仪表盘项目中,一个精心设计的UI往往能让产品从竞品…...

别下716GB了!用这个18GB的Light-HaGRID手势数据集,快速上手YOLOv5训练

18GB轻量级手势数据集实战:5步搞定YOLOv5模型训练 当你想验证一个手势识别模型的效果时,面对动辄数百GB的原始数据集往往会望而却步。硬盘空间吃紧、下载速度缓慢、数据处理繁琐——这些现实问题让很多研究者和开发者还没开始就打了退堂鼓。今天介绍的Li…...

统信UOS远程连接工具:从内网到公网的全场景实战指南

1. 统信UOS远程连接工具初探 第一次接触统信UOS自带的远程连接工具时,我完全被它的便捷性惊艳到了。作为国产操作系统的代表,统信UOS不仅界面美观,内置的远程协助功能更是解决了跨设备协作的大问题。这个工具最大的特点就是无需安装第三方软件…...