本文认为已安装PostgreSQL9.6,安装步骤如 Centos7安装PostgreSQL9.6。
注意,作者将Pg9.6直接安装到了postgres用户下如下图:
下文其他依赖编译到pg的目录下最好,自行对照自己的修改下。
从源码安装,需要安装/编译GEOS, Proj.4, GDAL,LibXML2 和JSON-C,所以一步步安装。
一 编译GEOS
$ cd ~
$ wget http://download.osgeo.org/geos/geos-3.5.0.tar.bz2
$ tar -jxvf geos-3.5.0.tar.bz2
$ cd geos-3.5.0
$ ./configure --prefix=/home/postgres/geos --安装到PostgreSQL的账户里
$ make -j 32
$ make install
作者在执行make -j 32时报错如下:
g++: command not found
于是直接yum先装上再说:
yum install gcc-c++
但是执行make -j 32时仍然报错,报错显示:
error:#error "Can not compile without isnan function or macro"
经过网友指点如下:
# 在geos解压的文件中,找到/include/config.h
# 编辑该文件,取消#undef HAVE_ISNAN的注释,保存退出
#然后重新配置geos如下:
$ ./configure --prefix=/home/postgres/geos
$ make -j 32 #等待编译完成时间蛮长的。
$ make install #正常编译完成
二 编译Proj
$ cd ~
$ wget http://download.osgeo.org/proj/proj-4.9.2.tar.gz
$ tar -zxvf proj-4.9.2.tar.gz
$ cd proj-4.9.2
$ ./configure --prefix=/home/postgres/proj4
$ make -j 32
$ make install
三 编译GDAL
$ cd ~
$ wget http://download.osgeo.org/gdal/2.1.1/gdal-2.1.1.tar.gz
$ tar -zxvf gdal-2.1.1.tar.gz
$ cd gdal-2.1.1
#以下编译安装要花很长时间,想死
$ ./configure --prefix=/home/postgres/gdal --with-pg=/home/postgres/bin/pg_config
$ make -j 32
$ make install
四 LibXML2 json-c 等等
# yum install -y libtool libxml2 libxml2-devel libxslt libxslt-devel json-c json-c-devel cmake gmp gmp-devel mpfr mpfr-devel boost-devel pcre-devel
五 安装PostGIS
看PostGIS官网的描述很简单,直接就典型的make makeinstall编译安装,很简洁,但是实际安就装会发现很多依赖库根本找不到如下图某个could not find GDAL这样,即使明明安装了,也找不到。
这种问题一般都是链接库找不到,需要手动进行软连接等各种配置,正确配置后才能正确编译。
5.1 配置依赖库软连接
#编辑ld.so.conf文件。
[root@pg1 postgres]# vim /etc/ld.so.conf
#边界内容如下
/home/postgres/lib
/home/postgres/geos/lib
/home/postgres/proj4/lib
/home/postgres/gdal/lib
#编辑完成后wq!保存退出
[root@pg1 postgres]# ldconfig #保存配置生效
5.2 配置Postgres用户环境变量
[root@pg1 postgres]# su - postgres
[root@pg1 postgres]# vim .bashrc
#原先这个用户环境变量配置了Postgres的东西,现在加进一些依赖进来
PGHOME=/home/postgres
export PGHOME
PGDATA=$PGHOME/data
export PGDATA
export LD_LIBRARY_PATH=/home/postgres/geos/lib:/home/postgres/proj4/lib:/home/postgres/gdal/lib::$PGHOME/lib:/lib64:/usr/lib64:/usr/local/lib64:/lib:/usr/lib:/usr/local/lib:$LD_LIBRARY_PATH
PATH=$PATH:$HOME/.local/bin:$HOME/bin:$PGHOME/bin
export PATH
#编辑完成wq!保存退出。
[root@pg1 postgres]# source .bashrc #重启配置生效
5.3 编译安装PostGIS
$ wget http://download.osgeo.org/postgis/source/postgis-2.3.0.tar.gz
$ tar -zxvf postgis-2.3.0.tar.gz
$ cd postgis-2.3.0
$ ./configure --prefix=/home/postgres
--with-gdalconfig=/home/postgres/gdal/bin/gdal-config
--with-pgconfig=/home/postgres/bin/pg_config
--with-geosconfig=/home/postgres/geos/bin/geos-config
--with-projdir=/home/postgres/proj4
$ make
$ make install
六 创建postgis扩展
[root@pg1 postgres]# psql Test
Test=# create extension postgis;
CREATE EXTENSION
#在测试数据库中创建扩展成功。