Centos安装postgresql数据库以及postgis扩展的安装

这几天项目上的数据库迁移差点没把我弄死 ,因为项目上的使用的是postgis来处理地理数据 ,而开发环境的数据库以及postgis扩展并不是我安装的。所以在迁移的时候造成了不小的麻烦。记录一下迁移过程中遇到的。下面以Centos操作系统为例

文章目录

  • 卸载postgresql
  • 安装postgresql
  • 修改配置文件
    • `postgresql.conf`
    • `pg_hba.conf`
  • 下载安装postgis扩展
  • 安装postgis扩展
  • 迁移数据
    • gdal.driver没有安装

卸载postgresql

我选择直接执行这个指令暴力删除,这个会把postgresql数据库联通postgis(如果安装的话)一起删除

yum remove postgresql*

安装postgresql

直接去下面的官网上面下载就完事了
Centos7操作系统下的postgresql下载
Centos安装postgresql数据库以及postgis扩展的安装_第1张图片
点击copy script复制脚本在自己的服务器上粘贴一下就下载完成了。然后执行一下
netstat -tnlp | grep 5432
在这里插入图片描述
如果查询结果如上图则说明数据库已经被启动

以下是对数据库的常见操作:

  • 启动数据库
    systemctl start postgresql-14 后面的14是版本号,如果你下载的是别的版本,直接替换数字既可

  • 停止数据库
    systemctl stop postgresql-14

  • 重启数据库
    systemctl restart postgresql-14

修改配置文件

接下来需要修改数据库的配置文件来

postgresql.conf

首先我们要明确一下我们为什么需要修改这个配置文件,修改这个配置文件可以使postgresql-server监听所有ip而不是只监听localhost,换句话说是修改权限让我们从外部访问这个数据库,这样我们就可以拿datagrip或者naviicat之类的软件连接数据库了。
首先先找到配置文件的位置
find / -name postgresql.conf
在这里插入图片描述

使用vim打开配置文件的61行,如果是刚下载完的配置文件应该是listen addresses ='localhost' ,需要我们将其修改成下图的配置
Centos安装postgresql数据库以及postgis扩展的安装_第2张图片

pg_hba.conf

首先先找到配置文件的位置
find / -name pg_hba.conf
在这里插入图片描述

然后我们vim编辑这个文件:下面是我的配置

  • 本机登录数据库无需输入密码

  • 外面ip的登录需要输入密码(且使用MD5加密协议传输账号和密码)
    Centos安装postgresql数据库以及postgis扩展的安装_第3张图片

  • TYPE 参数设置
    TYPE 表示主机类型,值可能为:

    • 若为 local 表示是unix-domain的socket连接,
    • 若为 host 是TCP/IP socket
    • 若为 hostssl 是SSL加密的TCP/IP socket
  • DATABASE 参数设置
    DATABASE 表示数据库名称,值可能为:
    all ,sameuser,samerole,replication,数据库名称 ,或者多个
    数据库名称用 逗号,注意ALL不匹配 replication

  • USER 参数设置
    USER 表示用户名称,值可以为:
    all,一个用户名一组用户名 ,多个用户时,可以用 ,逗号隔开,
    或者在用户名称前缀 + ;在USER和DATABASE字段,也可以写一个单独的
    文件名称用 @ 前缀,该文件包含数据库名称或用户名称

  • ADDRESS 参数设置
    该参数可以为 主机名称 或者IP/32(IPV4) IP/128(IPV6),主机
    名称以 .开头,samehostsamenet 匹配任意Ip地址 ,这里我把ip设置成0.0.0.0/0代表所有ip均可登录数据库!

  • METHOD 参数设置
    该值可以为"trust", "reject", "md5", "password", "scram-sha-256",
    "gss", "sspi", "ident", "peer", "pam", "ldap", "radius" or "cert"
    注意 若为password则发送的为明文密码,我们一般把密码设置为md5加密格式进行传输

这么多操作下来之后,我们的数据库就已经可以被外面ip的软件所访问了。

下载安装postgis扩展

首先我们在yum源里面查看可用的postgisab
yum list | grep postgis*
红色的部分是 postgis 的版本 (在写这篇博客的时候postgis的最高版本为3.3),蓝色的框 是postgresql的版本号,大家选择自己对应的版本安装
Centos安装postgresql数据库以及postgis扩展的安装_第4张图片
例如我需要安装 postgresql 版本为14 的,postgis版本为 3.3的postgis扩展,
在这里插入图片描述
然后我们执行
yum install postgis33_14.x86_64
就可以完成postgis的安装!

安装postgis扩展

进入postgresql执行下面语句,安装所有的postgis的驱动

-- Enable Topology
CREATE EXTENSION postgis_topology;
-- Enable PostGIS Advanced 3D-- and other geoprocessing algorithms
-- sfcgal not available with all distributions
CREATE EXTENSION postgis_sfcgal;
-- fuzzy matching needed for Tiger
CREATE EXTENSION fuzzystrmatch;
-- rule based standardizer
CREATE EXTENSION address_standardizer;
-- example rule data set
CREATE EXTENSION address_standardizer_data_us;
-- Enable US Tiger Geocoder
CREATE EXTENSION postgis_tiger_geocoder;
CREATE EXTENSION postgis_raster;

迁移数据

gdal.driver没有安装

在数据库安装好之后,结果发现了st_astiff这个语句无法执行。总是报错:gdal的驱动没有加载。这个问题困扰了相当长的时间。后来才发现是环境变量的问题,有两种解决方法:

  • 在每次调用输出数据的时候,在事务开始的时候设置一下环境变量:
    set postgis.gdal_enabled_drivers ='ENABLE_ALL';
  • 或者直接在配置文件postgresql.conf里面设置改环境变量
    Centos安装postgresql数据库以及postgis扩展的安装_第5张图片
    然后重启一下数据库,接下来的所有执行就可以正常的执行了。

你可能感兴趣的:(数据库,centos,postgresql,postgis)