PostgreSQL【部署 01】离线安装PostgreSQL+PostGIS踩坑及问题解决经验分享(含安装文件PostgreSQL+PostGIS及多个依赖+测试SQL)

本文涉及的产品
云数据库 PolarDB MySQL 版,列存表分析加速 4核8GB
PolarDB Agent Express,2核4GB
简介: PostgreSQL【部署 01】离线安装PostgreSQL+PostGIS踩坑及问题解决经验分享(含安装文件PostgreSQL+PostGIS及多个依赖+测试SQL)

PostGIS 官网 本次为离线安装, 资源分享【有的安装包比较难下载】

链接:https://pan.baidu.com/s/1XPUoyReHOKyjNINpcyrMRQ 
提取码:9f26

包含资源:

1. postgresql-9.5.9.tar.gz
2. postgis-2.2.3.tar.gz
3. bzip2-1.0.6.tar.gz
4. gdal-2.1.2.tar.gz
5. geos-3.3.7.tar.bz2
6. json-c-0.12.1.tar.gz
7. libxml2-2.6.26.tar.gz
8. proj-4.9.3.tar.gz
9. protobuf-cpp-3.1.0.tar.gz

1.准备

# 组件安装
yum -y install gcc
yum -y install bzip2
yum -y install autoconf
yum -y install zlib-devel
yum -y install gcc gcc-c++ 
yum -y install readline-devel
# 添加用户组和用户(postgreSQL不能以root用户运行)
groupadd postgres
useradd -g postgres postgres
passwd postgres

2.安装PostgreSQL

# 1.解压
tar -zxvf postgresql-9.5.9.tar.gz 
# 2.在解压的目录内执行命令: prefix为安装目录
./configure –prefix=/usr/local/pgsql # 这个阶段要注意error信息,解决完全部error后再进行安装。
make
make install
# 3.环境变量配置
vi /etc/profile
  # ---添加配置---
  export LD_LIBRARY_PATH=/usr/local/pgsql/lib:$LD_LIBRARY_PATH
  export PATH=/usr/local/pgsql/bin:$PATH
  export MANPATH=/usr/local/pgsql/man:$MANPATH
# ---配置生效---
source /etc/profile
# 4.在/usr/local/pgsql文件夹下创建数据库数据文件夹
mkdir /usr/local/pgsql/data
chown -R postgres.postgres /usr/local/pgsql/data
# 切换为postgres用户
su postgres
# 5.在/usr/local/pgsql/bin文件夹下执行数据库初始化 
# 设置locale为C,并且template编码为UNICODE,使数据库支持中文
./initdb --locale=C -E UNICODE -D ../data/
# 6.使用root用户,更改日志文件的属主为postgres,修改后切回postgres用户
chown postgres /var/log/pgsql.log
# 7.修改配置/usr/local/pgsql/data
vi postgresql.conf # 使监听生效
listen_addresses='*'
port=5432
vi pg_hba.conf
host all all 0.0.0.0/0 md5
# 8.设置密码 /usl/local/pgsql/bin/ 否则用户postgres无法连接数据库
psql
ALTER USER postgres WITH PASSWORD 'postgres'; 
# 9.启动停止数据库 /usl/local/pgsql/bin/
./pg_ctl start -D /usr/local/pgsql/data/
./pg_ctl stop -D /usr/local/pgsql/data/

3.安装PostGIS

安装PostGIS之前须先安装proj4,geos,libxml2,gdal2,json-c,protobuf

1.安装proj4

# 1.解压 配置 编译 安装
tar -zxvf proj-4.8.0.tar.gz
cd proj-4.8.0
./configure --prefix=/opt/proj-4.8.0
make
make install
# 2.库的路径添加到系统中
vi /etc/ld.so.conf.d/proj-4.8.0.conf
  # ---添加配置---
  /opt/proj-4.8.0/lib
# 配置生效
ldconfig

2.安装geos

# 1.解压 配置 编译 安装
tar -jxvf geos-3.3.7.tar.bz2
cd geos-3.3.7
./configure --prefix=/opt/geos-3.3.7
make
make install
# 2.库的路径添加到系统中
vi /etc/ld.so.conf.d/geos-3.3.7.conf
  # ---添加配置---
  /opt/geos-3.3.7/lib
# 配置生效
ldconfig

3.安装libxml2

方式相同

4.安装gdal2

方式相同,make阶段时间较长(半小时)

5.安装json-c

方式相同

6.安装protobuf

方式相同,make阶段时间较长(20分钟左右)

7.安装postgis

安装前

# 解决gdal无法获取的问题
vi /etc/ld.so.conf
  # ---配置---
  include /etc/ld.so.conf.d/*.conf
  /usr/local/pgsql/lib
# 使配置生效
ldconfig –v

安装

tar -zxvf postgis-2.2.3.tar.gz
cd postgis-2.2.3
# 具体目录要根据扩展文件安装目录而定 
./configure --prefix=/opt/postgis --with-pgconfig=/usr/local/pgsql/bin/pg_config --with-geosconfig=/opt/geos-3.3.7/bin/geos-config --with-projdir=/opt/proj-4.9.3/  --with-xml2config=/opt/libxml2-2.6.26/bin/xml2-config --with-gdalconfig=/opt/gdal-2.1.2/bin/gdal-config 
make
make install

4.PostGIS验证(copy)

-- 建表
CREATE TABLE cities ( id int4, name varchar(50) );
-- 添加位置字段
SELECT AddGeometryColumn ('cities', 'the_geom', 4326, 'POINT', 2);
-- 插入几条数据
INSERT INTO cities (id, the_geom, name) VALUES (1,ST_GeomFromText('POINT(-5.911 3.115)',4326),'BeiJing,China');
INSERT INTO cities (id, the_geom, name) VALUES (2,ST_GeomFromText('POINT(-5.921 3.215)',4326),'BeiJing,China');
INSERT INTO cities (id, the_geom, name) VALUES (3,ST_GeomFromText('POINT(-5.931 3.315)',4326),'BeiJing,China');
INSERT INTO cities (id, the_geom, name) VALUES (4,ST_GeomFromText('POINT(-5.941 3.415)',4326),'BeiJing,China');
INSERT INTO cities (id, the_geom, name) VALUES (5,ST_GeomFromText('POINT(-5.951 3.515)',4326),'BeiJing,China');
INSERT INTO cities (id, the_geom, name) VALUES (6,ST_GeomFromText('POINT(-15.951 13.515)',4326),'Out,BeiJing,China');
-- 查询全表
select id,name,ST_AsText(the_geom) from cities ;
-- 查询任意两点间球面距离,并以id排序
SELECT p1.name,p2.name,ST_Distance_Sphere(p1.the_geom,p2.the_geom) FROM cities AS p1, cities AS p2 WHERE p1.id > p2.id;
-- 查询矩形内的点
select id, name, ST_AsText(the_geom) from cities where the_geom && ST_SetSRID(ST_MakeBox2D(ST_POINT(-10.0,-10.0),ST_POINT(10.0,10.0)),4326);
-- 任意给出几个点,查询该空间范围内的点,第一个点和最后一个点应是同一个点
select id,name,ST_AsText(cities.the_geom) from cities where the_geom && ST_AsText(ST_MakePolygon(ST_GeomFromText('LINESTRING ( -10.31 10.97 , -10.15 -10.09 , 10.35 10.27 , 10.31 -10.97 , -10.31 10.97)')));
-- 同上
select id,name,ST_AsText(cities.the_geom) from cities where the_geom && ST_MakePolygon(ST_GeomFromText('LINESTRING ( -10.31 10.97 , -10.15 -10.09 , 10.35 10.27 , 10.09 -10.88 , 30.31 -40.97 , -1.11 60.33 , -10.31 10.97)'));
-- string应该用单引号,双引号会报错
update cities set name = 'America,LAS' where id = 5;
-- 删除数据
delete from cities where id = 6;
-- 查询距离点(-87.71 43.741)距离为151600000米的所有点
SELECT name,st_astext(the_geom) FROM cities WHERE ST_DWithin(ST_Transform(ST_GeomFromText('POINT(-87.71 43.741)',4326),26986),ST_Transform(the_geom,26986), 151600000);

5.总结

离线安装PostgreSQL稍显繁琐【主要是用户的切换】,PostGIS插件的安装出现报错信息解决就好,也不是很麻烦。

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍如何基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
SQL Ubuntu 关系型数据库
PostgreSQL介绍和PostgreSQL包安装
PostgreSQL 是一个功能强大、可扩展的开源关系型数据库系统,以其可靠性、数据完整性和高性能著称。它支持复杂查询、事务、多版本并发控制及丰富的数据类型,适用于各种应用场景。本文介绍 PostgreSQL 的核心特性,并详细说明在多种 Linux 发行版上的安装与配置方法,帮助用户快速部署和使用该数据库系统。
1099 0
|
关系型数据库 Go 网络安全
go语言中PostgreSQL驱动安装
【11月更文挑战第2天】
810 5
|
存储 人工智能 编译器
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
1015 11
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
|
机器学习/深度学习 编解码 监控
目标检测实战(六): 使用YOLOv8完成对图像的目标检测任务(从数据准备到训练测试部署的完整流程)
这篇文章详细介绍了如何使用YOLOv8进行目标检测任务,包括环境搭建、数据准备、模型训练、验证测试以及模型转换等完整流程。
26661 59
目标检测实战(六): 使用YOLOv8完成对图像的目标检测任务(从数据准备到训练测试部署的完整流程)
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
机器学习/深度学习 自然语言处理 API
阿里云零门槛、轻松部署您的专属 DeepSeek模型体验测试
DeepSeek R1是基于Transformer架构的先进大规模深度学习模型,2025年1月20日发布并开源,遵循MIT License。它在自然语言处理等任务上表现出色,高效提取特征,缩短训练时间。阿里云推出的满血版方案解决了服务器压力问题,提供100万免费token,云端部署降低成本,用户可快速启动体验。虽然回答速度有待提升,但整体表现优异,备受关注。
549 8
|
关系型数据库 Linux 数据库
PostgreSQL 入门指南:安装、配置与基本命令
本文从零开始,详细介绍如何在 Windows、Linux 和 macOS 上安装和配置 PostgreSQL,涵盖30+个实操代码示例。内容包括安装步骤、配置远程访问和用户权限、基础数据库操作命令(如创建表、插入和查询数据),以及常见问题的解决方案。通过学习,你将掌握 PostgreSQL 的基本使用方法,并为后续深入学习打下坚实基础。
14809 1
|
Java 测试技术 应用服务中间件
Spring Boot 如何测试打包部署
本文介绍了 Spring Boot 项目的开发、调试、打包及投产上线的全流程。主要内容包括: 1. **单元测试**:通过添加 `spring-boot-starter-test` 包,使用 `@RunWith(SpringRunner.class)` 和 `@SpringBootTest` 注解进行测试类开发。 2. **集成测试**:支持热部署,通过添加 `spring-boot-devtools` 实现代码修改后自动重启。 3. **投产上线**:提供两种部署方案,一是打包成 jar 包直接运行,二是打包成 war 包部署到 Tomcat 服务器。
484 10
|
JavaScript NoSQL Java
基于SpringBoot+Vue实现的大学生体质测试管理系统设计与实现(系统源码+文档+数据库+部署)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!

推荐镜像

更多