当前位置: 首页 > 工具软件 > PostGIS > 使用案例 >

【Postgis】PostgresXL安装Postgis

董胡非
2023-12-01

PostGIS具有以下构建和使用要求:

需要

  1. Postgresql 9.5或更高版本。我使用PostgresXL10-基于Postgresql 10.6 ;
  2. GNU C编译器(gcc);
  3. GNU Make(gmake或make);
  4. Proj4重新投影库,版本4.6.0或更高 ;
  5. GEOS几何库(版本3.6或更高版本),但建议使用GEOS 3.7+以充分利用所有新功能 ;
  6. LibXML2,版本2.5.x或更高版本。LibXML2当前用于某些导入功能(ST_GeomFromGML和ST_GeomFromKML)。
  7. JSON-C,版本0.9或更高。JSON-C当前用于通过功能ST_GeomFromGeoJson导入GeoJSON。
  8. GDAL,版本1.8或更高(强烈建议使用1.9或更高版本,因为某些功能无法正常运行,或者行为与较低版本不同。)这是栅格支持所必需的。

可选的

  • GDAL(伪可选)仅在您不想要栅格时才可以将其忽略。另外,请确保按照第2.2节“配置栅格”中所述启用要使用的驱动程序。

  • GTK(需要GTK + 2.0、2.8 +)来编译shp2pgsql-gui形状文件加载器。 http://www.gtk.org/ 。

  • SFCGAL 1.1版(或更高版本)可用于为PostGIS cf 第8.19节“
    SFCGAL函数”提供附加的2D和3D高级分析功能。并且还允许将SFCGAL而不是GEOS用于两个后端提供的某些2D函数(例如,例如ST_Intersection或ST_Area)。postgis.backend如果安装了SFCGAL(默认为GEOS),则PostgreSQL配置变量允许最终用户控制他要使用哪个后端。注意:SFCGAL
    1.2至少需要CGAL 4.3和Boost 1.54(cf:http /oslandia.github.io/SFCGAL/installation.html )
    https://github.com/Oslandia/SFCGAL。

  • 为了构建第12章,地址标准化器,您还将需要PCRE http://www.pcre.org(通常已经在nix系统上安装了)。
    Regex::Assemble仅当您要重建以编码的数据时,才需要perl CPAN软件包parseaddress-stcities.h。
    如果第12章检测到PCRE库,或者–with-pcre-dir=/path/to/pcre在配置过程中传递了有效值,则将自动构建Address
    Standardizer。

  • 要启用ST_AsMVT,需要protobuf-c库(用于用法)和protoc-c编译器(用于构建)。另外,需要pkg-config来验证protobuf-c的正确最低版本。参见protobuf-c。默认情况下,Postgis将使用Wagyu来更快地验证MVT多边形,这需要使用c
    ++ 11编译器。它将使用CXXFLAGS和与PostgreSQL安装相同的编译器。要禁用此功能并使用GEOS,请–without-wagyu在配置步骤中使用

  • CUnit(CUnit)。这是回归测试所必需的。http://cunit.sourceforge.net/

  • DocBook(xsltproc)是构建文档所必需的。可以从 http://www.docbook.org/ 获得Docbook 。

  • dblatex以PDF格式构建文档需要 DBLatex()。可从 http://dblatex.sourceforge.net/获得
    DBLatex 。

  • 需要ImageMagick(convert)来生成文档中使用的图像。可从 http://www.imagemagick.org/
    获得ImageMagick 。

下载Postgis

http://postgis.net/source/

我下载的是3.0.2版本

安装GCC

yum install -y gcc gcc-c++

安装Proj4

wget http://download.osgeo.org/proj/proj-5.2.0.tar.gz
tar -zxvf proj-5.2.0.tar.gz
cd proj-5.2.0
./configure  --prefix=/usr/local/proj-5.2.0
make
make install

安装GEOS

wget https://download.osgeo.org/geos/geos-3.7.0.tar.bz2
tar -jxvf geos-3.7.0.tar.bz2
cd geos-3.7.0
./configure --prefix=/usr/local/geos-3.7.0
make
make install

安装GDAL

wget https://download.osgeo.org/gdal/2.3.2/gdal-2.3.2.tar.gz
tar -zxvf gdal-2.3.2.tar.gz
cd gdal-2.3.2
./configure  --prefix=/usr/local/gdal-2.3.2 --with-pg=/usr/pgsql-10/bin/pg_config
make
make install

安装JSON-C

wget https://github.com/json-c/json-c/archive/json-c-0.13.1-20180305.tar.gz
tar -zxvf json-c-0.13.1-20180305.tar.gz
cd json-c-0.13.1-20180305
./configure  --prefix=/usr/local/json-c-0.13.1
make
make install

安装LIBXML2

wget https://github.com/GNOME/libxml2/archive/v2.9.7.tar.gz
tar -zxvf libxml2-sources-2.9.7.tar.gz
cd libxml2-2.9.7
./configure  --prefix=/usr/local/libxml2-2.9.7
make
make install

安装Protobuf

wget https://github.com/google/protobuf/releases/download/v3.6.1/protobuf-all-3.6.1.tar.gz
tar zxvf protobuf-all-3.6.1.tar.gz
./autogen.sh
#配置安装目录
./configure  --prefix=/usr/local/protobuf-3.6.1
make
make install
#配置环境变量,增加/usr/local/protobuf-3.6.1安装目录
vi /etc/profile
export CMAKE_HOME=/usr/bin/cmake
export PKG_CONFIG_PATH=/usr/local/protobuf-3.6.1/lib/pkgconfig
export PROTOBUF_HOME=/usr/local/protobuf-3.6.1
export PATH=$CMAKE_HOME/bin:$PROTOBUF_HOME/bin:$PATH
#保存退出
source /etc/profile
#验证protobuf执行程序
protoc --version
#出现libprotoc 3.6.1说明安装成功

安装protobuf-c

wget https://github.com/protobuf-c/protobuf-c/releases/download/v1.3.1/protobuf-c-1.3.1.tar.gz
tar -zxvf protobuf-c-1.3.1.tar.gz    
cd protobuf-c-1.3.1  
#导入protobuf的pkgconfig,否则"--No package 'protobuf' found"
export PKG_CONFIG_PATH=/usr/local/protobuf-3.6.1/lib/pkgconfig
./configure  --prefix=/usr/local/protobuf-c-1.3.1
make    
make install   
#配置环境变量,增加下protobuf-c-1.3.1/bin
vi /etc/profile
export PATH=:/usr/local/protobuf-c-1.3.1/bin
#保存退出
source /etc/profile

安装CGAL

yum install boost-devel
# 安装指定版本cgal-4.13
wget https://github.com/CGAL/cgal/archive/releases/CGAL-4.13.tar.gz
tar -zxvf CGAL-4.13.tar.gz   
cd CGAL-4.13  
mkdir build & cd build 
#cmake不要指定安装路径
cmake ..
make    
make install

安装sfcgal

wget https://github.com/Oslandia/SFCGAL/archive/v1.3.6.tar.gz
tar -zxvf v1.3.6.tar.gz   
cd SFCGAL-1.3.6  
mkdir build & cd build 
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/sfcgal-1.3.6 ..
make    
make install

安装Postgis

[root@xx /]# vi /etc/ld.so.conf
#编辑内容如下
include ld.so.conf.d/*.conf
/home/postgres/lib
/usr/local/proj-5.2.0/lib
/usr/local/gdal-2.3.2/lib
/usr/local/geos-3.7.0/lib
/usr/local//sfcgal-1.3.6/lib64
/usr/local/json-c-0.13.1/lib
/usr/local/libxml2-2.9.7/lib
/usr/local/protobuf-3.6.1/lib
/usr/local/protobuf-c-1.3.1/lib
#编辑完成后wq!保存退出
#保存配置,重启生效
[root@xx /]# ldconfig -v
wget http://download.osgeo.org/postgis/source/postgis-2.5.0.tar.gz    
tar -zxvf postgis-2.5.0.tar.gz    
cd postgis-2.5.0 
#根据安装不同的要求,选择任意一个configure
#基本安装,不带protobuf,sfcgal
./configure --prefix=/home/postgres --with-gdalconfig=/usr/local/gdal-2.3.2/bin/gdal-config --with-pgconfig=/home/postgres/bin/pg_config --with-geosconfig=/usr/local/geos-3.7.0/bin/geos-config --with-projdir=/usr/local/proj-5.2.0 --with-xml2config=/usr/local/libxml2-2.9.7/bin/xml2-config --with-jsondir=/usr/local/json-c-0.13.1
#带protobuf安装,支持mvt
./configure --prefix=/home/postgres --with-gdalconfig=/usr/local/gdal-2.3.2/bin/gdal-config --with-pgconfig=/home/postgres/bin/pg_config --with-geosconfig=/usr/local/geos-3.7.0/bin/geos-config --with-projdir=/usr/local/proj-5.2.0 --with-xml2config=/usr/local/libxml2-2.9.7/bin/xml2-config --with-jsondir=/usr/local/json-c-0.13.1 --with-protobufdir=/usr/local/protobuf-c-1.3.1
# 带protobuf,sfcgal安装
./configure --prefix=/home/postgres --with-gdalconfig=/usr/local/gdal-2.3.2/bin/gdal-config --with-pgconfig=/home/postgres/bin/pg_config --with-geosconfig=/usr/local/geos-3.7.0/bin/geos-config --with-projdir=/usr/local/proj-5.2.0 --with-xml2config=/usr/local/libxml2-2.9.7/bin/xml2-config --with-jsondir=/usr/local/json-c-0.13.1 --with-protobufdir=/usr/local/protobuf-c-1.3.1 --with-sfcgal=/usr/local/sfcgal-1.3.6/bin/sfcgal-config

make
make install


# 我需要st_asmvt()
./configure --prefix=/usr/local/postgis-3.0.2 --with-gdalconfig=/usr/local/gdal-2.3.2/bin/gdal-config --with-pgconfig=/home/postgres/pgxl/bin/pg_config --with-geosconfig=/usr/local/geos-3.7.0/bin/geos-config --with-projdir=/usr/local/proj-5.2.0 --with-xml2config=/usr/local/libxml2-2.9.1/bin/xml2-config --with-jsondir=/usr/local/json-c-0.13.1 --with-protobufdir=/usr/local/protobuf-c-1.3.1

make && make install

测试st_asmvt()功能

postgres=# WITH mvtgeom AS
(
  SELECT ST_TileEnvelope(12,513,412) AS geom
)
SELECT ST_AsMVT(mvtgeom.*)
FROM mvtgeom;
                                           st_asmvt                                           
----------------------------------------------------------------------------------------------
 \x1a2b0a0764656661756c74121b1803221709d5a5a90e8adda00f1a00f09801f098010000ef98010f2880207802
(1 row)

postgres=# \q

其他

geos-3.7.0正常安装,但是创建扩展时报错找不到libgeos-3.6.0.so,这时候安装并使用geos-3.6.0,然后把libgeos-3.6.0.so复制到对应的地方就可以了。
 类似资料: