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

Linux离线环境实战:PostgreSQL与PostGIS一站式部署指南

1. 离线环境部署前的准备工作在开始部署之前我们需要先了解几个关键点。离线环境意味着服务器无法连接互联网所有依赖包都需要提前下载并传输到目标机器。这就像要去一个没有超市的荒岛露营必须把所有的食物和工具都准备好带过去。首先检查系统版本这个很重要因为不同Linux发行版的包管理器和依赖项可能不同。执行以下命令查看系统信息cat /etc/os-release uname -a我建议创建一个专门的目录来存放所有安装包比如/opt/offline_packages。这样便于管理也不会弄乱系统目录。把所有需要的安装包按类别分好子目录postgresql存放数据库主程序包postgis存放地理信息扩展包dependencies存放所有依赖包tools存放编译工具链特别注意在传输文件到离线服务器时建议使用md5sum或sha256sum校验文件完整性。我曾经遇到过因为文件传输损坏导致安装失败的情况排查了很久才发现是文件传输过程中出了问题。2. 编译工具链与基础依赖安装没有编译器就像没有螺丝刀想组装家具一样困难。在离线环境中我们需要先搭建完整的编译环境。2.1 安装GCC工具链GCC是编译PostgreSQL的必备工具。离线安装GCC需要准备以下RPM包以CentOS为例gccgcc-cmakeglibc-develglibc-headerskernel-headerslibgomplibmpcmpfrcpp把这些包都放在/opt/offline_packages/tools/gcc目录下然后执行cd /opt/offline_packages/tools/gcc rpm -Uvh *.rpm --nodeps --force常见问题如果遇到依赖错误可以尝试先安装低版本的包。我在一台CentOS 7.5的机器上就遇到过这个问题后来发现是某些包的版本过高导致的。2.2 其他必要依赖PostgreSQL还需要这些基础库# 安装readline开发包 rpm -ivh readline-devel-*.rpm # 安装zlib压缩库 rpm -ivh zlib-devel-*.rpm # 安装XML处理库 rpm -ivh libxml2-devel-*.rpm安装完成后验证编译器是否可用gcc --version g --version make --version3. PostgreSQL数据库安装与配置3.1 源码编译安装我推荐使用源码安装而不是直接使用RPM包因为这样可以在离线环境下更好地控制安装选项和路径。首先解压PostgreSQL源码包tar -zxvf postgresql-12.6.tar.gz -C /opt cd /opt/postgresql-12.6配置编译选项时建议加上--with-libxml支持XML功能./configure --prefix/usr/local/postgresql \ --with-libxml \ --with-openssl \ --with-perl \ --with-python然后开始编译和安装make -j4 # 使用4个线程加速编译 make install性能提示编译时可以通过-j参数指定并行编译的线程数通常设置为CPU核心数的1.5-2倍能获得最佳编译速度。3.2 创建专用用户为PostgreSQL创建专用系统用户是个好习惯groupadd postgres useradd -g postgres postgres passwd postgres # 设置密码3.3 初始化数据库集群切换到postgres用户并初始化数据库su - postgres /usr/local/postgresql/bin/initdb -D /usr/local/postgresql/data初始化完成后可以启动数据库服务/usr/local/postgresql/bin/pg_ctl -D /usr/local/postgresql/data -l logfile start3.4 配置远程访问修改配置文件允许远程连接vi /usr/local/postgresql/data/postgresql.conf找到listen_addresses参数修改为listen_addresses *然后修改客户端认证配置vi /usr/local/postgresql/data/pg_hba.conf添加以下行允许所有IP通过密码连接host all all 0.0.0.0/0 md5重启服务使配置生效/usr/local/postgresql/bin/pg_ctl -D /usr/local/postgresql/data restart4. PostGIS地理信息扩展安装PostGIS是PostgreSQL的空间数据库扩展安装它需要先解决一系列依赖。4.1 安装GEOS几何引擎GEOS是PostGIS的核心依赖之一tar -jxvf geos-3.9.0.tar.bz2 -C /opt cd /opt/geos-3.9.0 ./configure --prefix/usr/local/geos-3.9.0 make make install4.2 安装PROJ坐标转换库PROJ处理地图投影和坐标转换tar -zxvf proj-7.2.1.tar.gz -C /opt cd /opt/proj-7.2.1 ./configure --prefix/usr/local/proj-7.2.1 make make install4.3 安装GDAL地理数据抽象库GDAL提供了丰富的地理数据格式支持tar -zxvf gdal-3.3.0.tar.gz -C /opt cd /opt/gdal-3.3.0 ./configure --prefix/usr/local/gdal-3.3.0 \ --with-geos/usr/local/geos-3.9.0/bin/geos-config \ --with-proj/usr/local/proj-7.2.1 make make install4.4 编译安装PostGIS现在可以安装PostGIS本身了tar -zxvf postgis-3.1.2.tar.gz -C /opt cd /opt/postgis-3.1.2 ./configure --prefix/usr/local/postgis \ --with-pgconfig/usr/local/postgresql/bin/pg_config \ --with-geosconfig/usr/local/geos-3.9.0/bin/geos-config \ --with-projdir/usr/local/proj-7.2.1 \ --with-gdalconfig/usr/local/gdal-3.3.0/bin/gdal-config make make install5. 配置与验证5.1 配置动态链接库路径PostGIS安装后需要确保PostgreSQL能找到所有的共享库vi /etc/ld.so.conf.d/postgis.conf添加以下内容/usr/local/postgresql/lib /usr/local/geos-3.9.0/lib /usr/local/proj-7.2.1/lib /usr/local/gdal-3.3.0/lib然后更新动态链接库缓存ldconfig5.2 创建PostGIS扩展连接到PostgreSQL并创建PostGIS扩展psql -U postgres CREATE DATABASE gisdb; \c gisdb CREATE EXTENSION postgis; CREATE EXTENSION postgis_topology;5.3 功能验证执行以下SQL验证PostGIS是否工作正常SELECT PostGIS_version(); SELECT ST_AsText(ST_Buffer(ST_GeomFromText(POINT(0 0), 4326), 1));如果能看到版本信息和缓冲后的几何图形说明安装成功。6. 常见问题排查6.1 缺少共享库错误如果遇到类似libgeos_c.so.1: cannot open shared object file的错误说明动态链接库路径有问题。解决方法确认库文件确实存在于/usr/local/xxx/lib目录检查/etc/ld.so.conf是否包含正确路径执行ldconfig更新缓存6.2 编译失败处理编译过程中如果失败可以尝试查看config.log文件获取详细错误信息确保所有依赖库都已正确安装清理编译目录后重新configure和make6.3 性能优化建议对于生产环境建议调整以下PostgreSQL参数vi /usr/local/postgresql/data/postgresql.conf调整以下参数shared_buffers 4GB # 25% of total RAM effective_cache_size 12GB # 75% of total RAM maintenance_work_mem 1GB work_mem 64MB random_page_cost 1.1 # For SSD storage7. 自动化部署脚本为了简化重复部署过程可以创建一个安装脚本#!/bin/bash # 定义安装目录和版本 PG_HOME/usr/local/postgresql PG_VERSION12.6 POSTGIS_VERSION3.1.2 # 安装PostgreSQL tar -zxvf postgresql-${PG_VERSION}.tar.gz -C /opt cd /opt/postgresql-${PG_VERSION} ./configure --prefix${PG_HOME} --with-libxml make -j4 make install # 创建用户和数据库目录 groupadd postgres useradd -g postgres postgres mkdir -p ${PG_HOME}/data chown -R postgres:postgres ${PG_HOME} # 初始化数据库 su - postgres -c ${PG_HOME}/bin/initdb -D ${PG_HOME}/data su - postgres -c ${PG_HOME}/bin/pg_ctl -D ${PG_HOME}/data -l logfile start # 安装PostGIS依赖 install_geos() { tar -jxvf geos-3.9.0.tar.bz2 -C /opt cd /opt/geos-3.9.0 ./configure --prefix/usr/local/geos-3.9.0 make make install } # 类似地添加其他依赖安装函数... # 最后安装PostGIS tar -zxvf postgis-${POSTGIS_VERSION}.tar.gz -C /opt cd /opt/postgis-${POSTGIS_VERSION} ./configure --with-pgconfig${PG_HOME}/bin/pg_config # 其他配置参数... make make install记得给脚本添加执行权限chmod x install_postgresql_postgis.sh在实际项目中我发现把整个安装过程脚本化可以节省大量时间特别是在需要部署多台服务器时。不过要注意脚本需要根据实际环境调整路径和版本号。

相关文章:

Linux离线环境实战:PostgreSQL与PostGIS一站式部署指南

1. 离线环境部署前的准备工作 在开始部署之前,我们需要先了解几个关键点。离线环境意味着服务器无法连接互联网,所有依赖包都需要提前下载并传输到目标机器。这就像要去一个没有超市的荒岛露营,必须把所有的食物和工具都准备好带过去。 首先检…...

缠论可视化分析插件:通达信技术分析终极指南

缠论可视化分析插件:通达信技术分析终极指南 【免费下载链接】Indicator 通达信缠论可视化分析插件 项目地址: https://gitcode.com/gh_mirrors/ind/Indicator 缠论作为技术分析领域的重要理论体系,其复杂性和抽象性常常让交易者望而却步。缠论可…...

别再乱用casex了!从Formality等价性检查失败,谈Verilog X态编码风格避坑

从Formality等价性检查失败看Verilog X态编码的深层隐患 在数字IC设计领域,Verilog代码中的X态处理一直是工程师们容易忽视的雷区。最近遇到一个典型案例:某芯片设计在RTL仿真阶段一切正常,Formality等价性检查也顺利通过,但门级仿…...

Visual C++运行库一键安装终极指南:彻底解决DLL缺失问题

Visual C运行库一键安装终极指南:彻底解决DLL缺失问题 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否经常遇到"无法启动程序&#xff0c…...

从CPU到GPU:PyTorch DataLoader的num_workers与batch_size内存调优实战

1. 从内存溢出报错说起:DataLoader的死亡信号 那天我正在训练一个图像分类模型,突然终端弹出红色警告:"DataLoader worker (pid 12345) is killed by signal: Killed"。这个报错就像深度学习工程师的"蓝屏界面"&#xff…...

Realistic Vision V5.1 虚拟摄影棚部署运维指南:Linux常用命令与监控

Realistic Vision V5.1 虚拟摄影棚部署运维指南:Linux常用命令与监控 部署好Realistic Vision V5.1,看着它生成第一张惊艳的写实人像,这只是第一步。想让这个“虚拟摄影棚”在服务器上7x24小时稳定工作,随时响应你的创作需求&…...

30分钟快速上手:使用Testsigma开源平台实现AI驱动自动化测试

30分钟快速上手:使用Testsigma开源平台实现AI驱动自动化测试 【免费下载链接】testsigma Testsigma is an agentic test automation platform powered by AI-coworkers that work alongside QA teams to simplify testing, accelerate releases and improve quality…...

3步实现Windows风扇智能控制:FanControl全面实用指南

3步实现Windows风扇智能控制:FanControl全面实用指南 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/…...

终极游戏乱码修复方案:Locale Remulator完全指南

终极游戏乱码修复方案:Locale Remulator完全指南 【免费下载链接】Locale_Remulator System Region and Language Simulator. 项目地址: https://gitcode.com/gh_mirrors/lo/Locale_Remulator 还在为日韩游戏乱码而烦恼吗?Locale Remulator是一款…...

一文讲清,LPA分层审核怎么分层?LPA分层审核的层级划分与实施要点

审核做了一轮又一轮,但现场问题依旧反复出现;整改措施写了一大堆,但落实效果总是不理想。这就是典型的审核与执行两张皮。而LPA分层审核(Layered Process Audit)正是为了解决这一难题而生的管理工具。那么LPA分层审核怎…...

d2s-editor:告别十六进制编辑器,暗黑2存档编辑的魔法工具箱

d2s-editor:告别十六进制编辑器,暗黑2存档编辑的魔法工具箱 【免费下载链接】d2s-editor 项目地址: https://gitcode.com/gh_mirrors/d2/d2s-editor 你是否曾为《暗黑破坏神2》的角色属性不够理想而苦恼?是否因为复杂的十六进制编辑器…...

5分钟掌握RVC:AI语音转换的终极入门指南

5分钟掌握RVC&#xff1a;AI语音转换的终极入门指南 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI Easily train a good VC model with voice data < 10 mins! 项目地址: https://gitcode.com/GitHub_Trending/re/Retrieval-based-Voice-Conversion-WebUI …...

避坑指南:Android 12开机logo修改那些事儿(从bmp格式到内核logo的完整流程)

Android 12开机logo定制全流程&#xff1a;从格式规范到内核级调试实战 在Android系统定制开发中&#xff0c;开机logo的修改看似简单&#xff0c;实则暗藏玄机。作为设备启动时最先呈现的视觉元素&#xff0c;它不仅关乎品牌形象&#xff0c;更直接影响用户对设备品质的第一印…...

告别环境配置噩梦:手把手教你用Ubuntu 20.04搞定Camera ITS测试环境(含Python3依赖解决方案)

从零搭建Camera ITS测试环境&#xff1a;Ubuntu 20.04全流程避坑指南 当Android相机模块需要验证成像质量时&#xff0c;ITS&#xff08;Image Test Suite&#xff09;测试框架是开发者绕不开的标准化工具。但许多工程师在Ubuntu 20.04环境下搭建测试环境时&#xff0c;往往会…...

如何用Pixel-Composer快速制作专业级像素艺术特效?终极节点式VFX编辑器指南

如何用Pixel-Composer快速制作专业级像素艺术特效&#xff1f;终极节点式VFX编辑器指南 【免费下载链接】Pixel-Composer Node base VFX editor for pixel art. 项目地址: https://gitcode.com/gh_mirrors/pi/Pixel-Composer Pixel-Composer是一款基于节点的像素艺术视觉…...

调优系统性能知识点问答

1.系统管理员可以使用哪个命令来更改tuned守护进程的设置&#xff1f; 管理员使用tuned-adm命令来更改tuned守护进程的设置&#xff0c;tuned-adm active可以查看当前活动配置&#xff0c;tuned-adm list可以列出所有可用配置&#xff0c;tuned-adm profile 配置名可以切换到指…...

Node.js 中间层我维护了两年,这周终于摊牌了——成本账单算完我人傻了

背景先交代一下&#xff0c;我在一个 20 人的创业团队做全栈&#xff0c;两年前入职第一件事就是搭 Node.js 中间层。当时的理由很充分&#xff1a;scss前端&#xff1a;React SPA中间层&#xff1a;Node.js (Express) ← 我搭的后端&#xff1a;Java 微服务 6老板说前端不能直…...

SDC设计约束进阶:工作条件与功耗约束的实战解析

1. 工作条件约束的实战应用 在芯片设计中&#xff0c;工作条件约束就像是给运动员设定比赛环境。想象一下&#xff0c;同一个运动员在高原和平原的跑步表现会完全不同。set_operating_conditions命令就是用来定义芯片工作的"气候环境"&#xff0c;它会直接影响时序分…...

超越官方文档:用Jetson Nano和CSI摄像头打造你的第一个AI视觉项目

超越官方文档&#xff1a;用Jetson Nano和CSI摄像头打造你的第一个AI视觉项目 当你第一次点亮Jetson Nano上的CSI摄像头时&#xff0c;那种兴奋感可能很快会被一个现实问题取代&#xff1a;"接下来我能用它做什么&#xff1f;"本文将带你跨越基础测试阶段&#xff0c…...

NLopt实战指南:从算法原理到工程应用

1. NLopt入门&#xff1a;非线性优化的瑞士军刀 第一次接触NLopt是在三年前的一个机器人路径规划项目里&#xff0c;当时需要解决一个带约束的多目标优化问题。试过几个开源库后&#xff0c;NLopt以其简洁的API设计和丰富的算法支持让我眼前一亮。这个由MIT开发的非线性优化库&…...

Phi-3 Mini 128K效果展示:长小说理解与代码库分析真实案例

Phi-3 Mini 128K效果展示&#xff1a;长小说理解与代码库分析真实案例 1. 引言&#xff1a;当轻量级模型遇上超长文本 在AI模型领域&#xff0c;参数规模往往与性能成正比&#xff0c;但微软的Phi-3 Mini 128K打破了这一常规。这款仅有3.8B参数的轻量级模型&#xff0c;凭借1…...

告别Designer!在VS2019里用Qt Creator高效编辑.ui文件的正确姿势

告别Designer&#xff01;在VS2019里用Qt Creator高效编辑.ui文件的正确姿势 每次在Visual Studio 2019中双击.ui文件时&#xff0c;那个熟悉的Qt Designer界面弹出&#xff0c;随之而来的可能是卡顿、崩溃&#xff0c;或是编译后界面显示异常的问题。作为一个长期使用Qt进行跨…...

nginx proxy_redirect指令实战:精准修复代理重定向后的404与域名复用跳转难题

1. 为什么你的Nginx代理总跳404&#xff1f;从Location头说起 最近在帮朋友排查一个诡异的Nginx问题&#xff1a;他的电商网站通过Nginx反向代理多个微服务&#xff0c;用户登录时总随机出现404页面。我打开Chrome开发者工具&#xff0c;发现点击登录按钮后出现302跳转&#xf…...

Navicat16/17 Mac版试用期终极重置指南:3种方法实现无限免费使用

Navicat16/17 Mac版试用期终极重置指南&#xff1a;3种方法实现无限免费使用 【免费下载链接】navicat_reset_mac navicat mac版无限重置试用期脚本 Navicat Mac Version Unlimited Trial Reset Script 项目地址: https://gitcode.com/gh_mirrors/na/navicat_reset_mac …...

为什么M9A智能助手能成为《重返未来:1999》玩家的首选自动化方案

为什么M9A智能助手能成为《重返未来&#xff1a;1999》玩家的首选自动化方案 【免费下载链接】M9A 重返未来&#xff1a;1999 小助手 | Assistant For Reverse: 1999 项目地址: https://gitcode.com/gh_mirrors/m9/M9A 还在为《重返未来&#xff1a;1999》中每日重复的资…...

极域电子教室破解终极指南:如何重获课堂电脑控制权

极域电子教室破解终极指南&#xff1a;如何重获课堂电脑控制权 【免费下载链接】JiYuTrainer 极域电子教室防控制软件, StudenMain.exe 破解 项目地址: https://gitcode.com/gh_mirrors/ji/JiYuTrainer 你是否曾在课堂上遇到过这样的困境&#xff1f;老师开启极域电子教…...

如何用lunar-javascript快速搞定农历计算?3个实用技巧让你轻松应对传统历法需求

如何用lunar-javascript快速搞定农历计算&#xff1f;3个实用技巧让你轻松应对传统历法需求 【免费下载链接】lunar-javascript 日历、公历(阳历)、农历(阴历、老黄历)、佛历、道历&#xff0c;支持节假日、星座、儒略日、干支、生肖、节气、节日、彭祖百忌、每日宜忌、吉神宜趋…...

Wear OS手表开发避坑:地图应用如何禁用全局滑动返回(附完整style.xml配置)

Wear OS手表开发实战&#xff1a;地图应用中禁用全局滑动返回的深度解决方案 在智能手表的小尺寸屏幕上开发地图导航应用时&#xff0c;最令人头疼的莫过于用户误触侧滑返回手势。想象一下这样的场景&#xff1a;用户正在骑行导航中&#xff0c;手腕自然摆动时不小心触发了返回…...

如何用BilibiliDown轻松提取B站音频:3分钟搞定高质量音乐下载 [特殊字符]

如何用BilibiliDown轻松提取B站音频&#xff1a;3分钟搞定高质量音乐下载 &#x1f3b5; 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader &#x1f633; 项目地址: https://git…...

AI建站工具避坑指南:企业用户最关心的十大核心问题解答

AI建站工具避坑指南&#xff1a;企业用户最关心的十大核心问题解答企业在考虑采用AI建站工具时&#xff0c;决策链条上的每个角色都有自己的顾虑&#xff1a;市场部担心内容质量&#xff0c;IT部门忧虑安全隐患&#xff0c;采购部纠结成本是否透明。这份指南汇总了十个最高频的…...