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

news2024/12/28 12:55:46

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

文章目录

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

卸载postgresql

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

yum remove postgresql*

安装postgresql

直接去下面的👇官网上面下载就完事了
Centos7操作系统下的postgresql下载
在这里插入图片描述
点击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' ,需要我们将其修改成下图的配置
在这里插入图片描述

pg_hba.conf

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

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

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

  • 外面ip的登录需要输入密码(且使用MD5加密协议传输账号和密码)
    在这里插入图片描述

  • 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的版本号,大家选择自己对应的版本安装
在这里插入图片描述
例如我需要安装 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里面设置改环境变量
    在这里插入图片描述
    然后重启一下数据库,接下来的所有执行就可以正常的执行了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/787847.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信小程序——实现手机振动效果

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…

解决行业反复“造轮子”现象,全新地平线RDK系列机器人开发者套件上线

7月25日,“地平线2023机器人开发者创享日”在深圳举办,地平线RDK系列机器人开发者套件正式上线,机器人操作系统TogetheROS.Bot™2.0版发布,应用中心NodeHub首发亮相,地平线开发者社区改版上线。 地平线2023机器人开发者…

go性能分析工具之trace

参考文章: https://eddycjy.gitbook.io/golang/di-9-ke-gong-ju/go-tool-trace https://mp.weixin.qq.com/s__bizMzUxMDQxMDMyNg&mid2247484297&idx1&sn7a01fa4f454189fc3ccdb32a6e0d6897&scene21#wechat_redirect 你有没有考虑过,你的g…

HTTP1、 HTTP2、HTTP3 区别

HTTP1、 HTTP2、HTTP3 区别 HTTP1HTTP/1.0和HTTP/1.1的区别HTTP1的缺陷 HTTP2SPDY协议HTTP/2 新特性(即HTTP/2.0和HTTP/1.x的区别)HTTP/2 的缺点 HTTP3QUIC协议HTTP/3 新特性(HTTP/3与HTTP/2、HTTP/1的区别)基于QUIC的0RTT是如何实…

【Linux后端服务器开发】HTTP协议

目录 一、HTTP协议概述 二、HTTP应用层服务器实现 Util.hpp Protocal.hpp Http_Server.hpp http_server.cc indext.html 一、HTTP协议概述 请求和响应怎么保证应用层完整读取完毕了? 读取完整的一行(识别行分隔符),while&…

MobPush Android SDK 厂商推送限制

概述 厂商推送限制 每个厂商通道都有对应的厂商配额和 QPS 限制,当请求超过限制且已配置厂商回执时,MobPush会采取以下措施: 当开发者推送请求超过厂商配额时,MobPush将通过自有通道进行消息下发。当开发者推送请求超过厂商 QP…

elementui el-table 封装表格

ps: 1.3版本 案例&#xff1a; 完整代码&#xff1a; 可直接复制粘贴&#xff0c;但一定要全看完&#xff01; v-slot"scopeRows" 是vue3的写法&#xff1b; vue2是 slot-scope"scope" <template><!-- 简单表格、多层表头、页码、没有合并列行…

2023年度盘点:网络电视盒子哪个好?目前性能最好的电视盒子

挑选电视盒子时配置性能是最重要的&#xff0c;芯片、运存、存储全部会影响到我们的观影体验&#xff0c;想播放流畅、响应速度快&#xff0c;要在预算范围内选择配置最高的产品&#xff0c;那么哪些电视盒子称得上是目前性能最好的电视盒子呢&#xff1f;不懂网络电视盒子哪个…

自定义view - 玩转字体变色

自定义View步骤&#xff1a; 1>&#xff1a;values__attrs.xml&#xff0c;定义自定义属性&#xff1b; 2>&#xff1a;在第三个构造方法中获取自定义属性&#xff1b; 3>&#xff1a;onMeasure【不是必须的】&#xff1b; 4>&#xff1a;onDraw&#xff1a;绘制代…

【Java中的Thread线程的简单方法介绍和使用详细分析】

文章目录 前言一、run() 和 start() 方法二、sleep() 方法三、join() 方法总结 前言 提示&#xff1a;若对Thread没有基本的了解&#xff0c;可以先阅读以下文章&#xff0c;同时部分的方法已经在如下两篇文章中介绍过了&#xff0c;本文不再重复介绍&#xff01;&#xff01;…

海量遥感数据处理与云计算技术教程

详情点击链接&#xff1a;海量遥感数据处理与GEE云计算技术 一&#xff0c;GEE及开发平台 1.GEE平台及典型应用&#xff1b; 2.GEE JavaScript开发环境及常用数据资源&#xff1b; 3.JavaScript基础&#xff0c;包括变量&#xff0c;运算符&#xff0c;数组&#xff0c;判断及…

【数据结构和算法15】二叉树的实现

二叉树是这么一种树状结构&#xff1a;每个节点最多有两个孩子&#xff0c;左孩子和右孩子 重要的二叉树结构 完全二叉树&#xff08;complete binary tree&#xff09;是一种二叉树结构&#xff0c;除最后一层以外&#xff0c;每一层都必须填满&#xff0c;填充时要遵从先左后…

程序员千万别碰这3种副业!!!

最近&#xff0c;“消费降级”这个词频频被大家提及&#xff0c;某瓣上&#xff0c;“今天消费降级了吗”小组的常驻人口有36万&#xff0c;某书上&#xff0c;跟消费降级有关的笔记近7万条...... 不少网友晒出了自己消费降级后的生活&#xff1a;由从前每天一杯的星巴克变成了…

ROS noetic,ROS melodic 安装 MoveIt 并运行

ROS noetic&#xff0c;ROS melodic 安装 MoveIt 并运行 前言更新功能包版本下载依赖文件创建工作区和软件源下载源代码安装编译器缓存&#xff08;可选环节&#xff09;编译Moveit&#xff01;安装Moveit&#xff01;检测是否安装成功 前言 在安装过程中我也碰壁过很多次&…

[算法通关村] 1.3 链表的删除

上一节我们谈到了链表的头插、尾插、中间插入的方法&#xff0c;忘记的小伙伴可以复习一下&#xff1a; [算法通关村] 1.2 链表的插入 接下来&#xff0c;完成链表的删除工作&#xff0c;我们在上一节的学习中&#xff0c;分别在链表的开头、中间和结尾插入了节点&#xff0c;…

【USACO OPEN12铜组】岛屿

【USACO OPEN12铜组】岛屿 文章目录 【USACO OPEN12铜组】岛屿题目描述输入格式输出格式数据范围输入样例&#xff1a;输出样例&#xff1a; 思路code 2014. 岛 - AcWing题库 题目描述 每当下雨时&#xff0c;农夫约翰的田地总是被洪水淹没。 由于田地不是完全水平的&#xf…

Cesium态势标绘专题-扇形(标绘+编辑)

标绘专题介绍:态势标绘专题介绍_总要学点什么的博客-CSDN博客 入口文件:Cesium态势标绘专题-入口_总要学点什么的博客-CSDN博客 辅助文件:Cesium态势标绘专题-辅助文件_总要学点什么的博客-CSDN博客 本专题没有废话,只有代码,代码中涉及到的引入文件方法,从上面三个链…

(五)FLUX中的数据类型

以下内容来自 尚硅谷&#xff0c;写这一系列的文章&#xff0c;主要是为了方便后续自己的查看&#xff0c;不用带着个PDF找来找去的&#xff0c;太麻烦&#xff01; 第 5 章 FLUX中的数据类型 5.1 10 个基本数据类型 5.1.1 Boolean &#xff08;布尔型&#xff09; 5.1.1.1 …

Pytorch学习笔记 | 利用线性回归实现最简单的梯度下降 | 含代码和数据

代码 import torch import numpy as np import matplotlib.pyplot as plt import pandas as pddef make_linear_regression_data():x = np.linspace(start=10

IIC通讯故障纠错一例

1.问题描述 IIC在既有的工作中&#xff0c;用来协调两个外围芯片。一个芯片扩展IO&#xff0c;一个处理显示。仔细核对了IIC的种种配置&#xff0c;并且最终测量了输出的时钟和数据波形&#xff0c;最终的时钟线波形是这样的&#xff1a; 单片机master模式&#xff0c;输出前面…