PostgreSQL关系型数据库介绍与部署

news/2024/5/20 0:02:28/文章来源:https://blog.csdn.net/qq_64612585/article/details/136954126

使用背景

在过去的几年中,PostgreSQL的使用量逐渐增加,而Oracle和MySQL的使用量则有所下降。这主要是由于以下几个原因:开源和免费、功能丰富、可扩展性强、安全性高、跨平台支持好、社区活跃、成熟稳定。这些因素使得PostgreSQL成为了许多开发者和组织的首选数据库解决方案,从而推动了它的流行。下面介绍一下这款关系型数据库PostgreSQL。

目录

一、PostgreSQL 介绍

1. 概念

2. 特点

3. 作用

4. 使用场景

5. PostgreSQL 与 MySQL 对比

5.1 PG 相对于 MySQL 的优势

5.2 MySQL 相对于 PG 的优势

二、PostgreSQL 部署

1. Yum 安装 PG

1.1 选择操作系统及版本

1.2 选择需要安装的软件版本及环境

1.3 安装并运行 

1.4 登录数据库

2. 编译安装

2.1 安装依赖包

2.2 源码编译安装

2.3 创建数据库用户和组

2.4 创建数据目录并授权

2.5 设置环境变量

2.6 初始化数据库

2.7 启动和关闭服务

2.8 创建 service 文件

2.9 登录数据库

三、PostgreSQL 远程登录

1. 编辑配置文件

2. 重启数据库服务

3. 远程登录


一、PostgreSQL 介绍

1. 概念

PostgreSQL 是当前功能最强大的开源的关系型数据库系统,支持跨平台的多种操作系统, 基于C语言开发。通常简称为PG或PGSQL。 PostgreSQL是100%社区驱动的开源项自,由全球范围内千人以上的社区责献者共同维护。PostgreSQL提供了一个完整功能的瓶本,而不像MySQL那样提供多个不同的版本,如社区版、商业版及企业版。

官网:PostgreSQL: The world's most advanced open source database

中文社区: PostgreSQL中文社区:: 世界上功能最强大的开源数据库...

中文手册: PostgreSQL 14.1 手册

2. 特点

① 开源和免费:是一款完全开源的数据库系统,用户可以免费使用、修改和分发它。

② 功能丰富:具有许多高级功能,包括复杂查询、事务支持、触发器、存储过程、视图、全文搜索、地理空间数据处理等。

③ 可扩展性:具有良好的可扩展性,支持水平扩展和垂直扩展。通过使用分区表、复制、流复制等功能,可以轻松地扩展数据库以满足不断增长的需求。

④ 安全性:注重数据安全性,提供了各种安全功能,如访问控制、SSL支持、加密存储、审计功能等,可以帮助保护数据免受恶意攻击和数据泄露。

⑤ 跨平台支持:可以在各种操作系统上运行,包括Linux、Unix、Windows和macOS等,这使得它具有很好的跨平台兼容性。

⑥ 社区支持:拥有一个庞大的全球开发者社区,提供了丰富的文档、教程和支持资源。用户可以通过邮件列表、论坛等渠道获得帮助和交流经验。

⑦ 成熟稳定:已经存在了30多年,经过了多次的版本迭代和改进,已经非常成熟和稳定。许多大型企业和组织都在使用PostgreSQL来处理他们的关键业务数据。

3. 作用

PostgreSQL是一款功能丰富、可靠稳定、安全性高的开源数据库管理系统,适用于各种规模的应用程序和企业,可以满足各种复杂的数据需求。

① 数据存储和管理:PostgreSQL可以存储和管理大量的数据,包括结构化数据、半结构化数据和非结构化数据。

② 数据查询和分析:PostgreSQL提供了强大的查询和分析功能,包括复杂查询、聚合函数、窗口函数、分析函数等。

③ 数据安全:PostgreSQL提供了各种安全功能,如访问控制、SSL支持、加密存储、审计功能等,可以帮助保护数据免受恶意攻击和数据泄露。

④ 数据一致性和完整性:PostgreSQL支持事务,可以确保数据的一致性和完整性。

⑤ 数据复制和高可用性:PostgreSQL支持数据复制和流复制,可以提供数据的备份和高可用性。

⑥ 数据分区和分布式处理:PostgreSQL支持分区表,可以将数据分布到多个物理存储设备上,从而提高查询性能。

⑦ 地理信息系统(GIS):PostgreSQL具有强大的地理信息系统支持,包括地理空间数据类型、索引和查询功能。

⑧ 全文搜索:PostgreSQL提供了全文搜索功能,包括全文索引和全文搜索查询。

4. 使用场景

① Web应用程序:PostgreSQL是许多Web应用程序的首选数据库解决方案,包括许多大型的社交网络、电子商务网站、新闻门户等。它的高级功能和可扩展性使得它能够处理大量的数据和复杂的查询需求。

② 地理信息系统(GIS):PostgreSQL具有强大的地理信息系统支持,包括地理空间数据类型、索引和查询功能。因此,它被许多GIS应用程序用作后端数据库。

③ 全文搜索:PostgreSQL提供了全文搜索功能,包括全文索引和全文搜索查询。这使得它成为许多需要全文搜索功能的应用程序的首选数据库解决方案。

④ 大数据处理:PostgreSQL的可扩展性和高级功能使得它能够处理大量的数据,包括大数据处理、数据仓库等。

⑤ 金融和电信行业:PostgreSQL被许多金融和电信公司用于处理他们的关键业务数据,包括交易数据、客户数据等。它的高级功能和数据安全性使得它成为这些行业的首选数据库解决方案。

⑥ 科学研究:PostgreSQL被许多科学研究机构用于处理和分析科学数据,包括天文学、生物学、气象学等。它的高级功能和可扩展性使得它能够满足这些领域的复杂数据需求。

5. PostgreSQL 与 MySQL 对比

5.1 PG 相对于 MySQL 的优势

  • 在SQL的标准实现上要比MySQL完善,而且功能实现比较严谨。
  • 对表连接支持较完整,优化器的功能较完整,支持的索引类型很多,复杂查询能力较强。
  • PG主表采用堆表存放,MySQL采用索引组织表,能够支持比MySQL更大的数据量。
  • PG的主备复制属于物理复制,相对于MySQL基于biniog的逻辑复制,数据的一致性更加可靠,复制性能更高,对主机性能的影响也更小。
  • PostgreSQL支持ISON和其他NOSQL功能,如本机XML支持和使用HSTORE的键值对。它还支持索引SON数据以加快访问速度,特别是10版本JSONB更是强大。
  • PostgreSQL完全免费,而且是BSD协议,如果你把PostgreSQL改一改,然后再拿去卖钱,也没有人管你,这一点很重要,这表明了PostgresQl数据库不会被其它公司控制。相反,MySQL现在主要是被Oracle公司控制。

5.2 MySQL 相对于 PG 的优势

  • innodb的基于回滚段实现的MVCC机制,相对PG新老数据一起存放的基于XID的MVCC机制,是占优的。新老数据一起存放,需要定时触 发VACUUM,会带来多余的IO和数据库对象加锁开销,引起数据库整体的并发能力下降。而且VACUUM清理不及时,还可能会引发数据膨胀。
  • MySQL采用索引组织表,这种存储方式非常适合基于主键匹配的查询、制改操作,但是对表结构设计存在约束。
  • MySQL的优化器较简单,系统表、运算符、数据类型的实现都很精简,非常适合简单的查询操作。
  • MySQL相对于PG在国内的流行度更高,PG在国内显得就有些落了。
  • MySQL的存储引擎插件化机制,使得它的应用场景更加广泛,比如除了innodb适合事务处理场景外,mvisam适合静态数据的查询场暴。

总结

从应用场景来说,PG更加适合严格的企业应用场景(比如金融、电信、ERP、CRM),但不仅仅限制于此,PostareSQl的ison,isonb,hstore等数据格式,特别适用于一些大数据格式的分析;而MySQL更加适合业务逻辑相对简单、数据可靠性要求较低的互联网场景(比如google、acebook、albaba),当然现在MySQL的在innodb引擎的大力发展,功能表现良好。

二、PostgreSQL 部署

1. Yum 安装 PG

使用官方源: PostgreSQL: Downloads

1.1 选择操作系统及版本

1.2 选择需要安装的软件版本及环境

1.3 安装并运行 

sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
# 使用yum包管理器安装PostgreSQL的官方YUM存储库。这个存储库包含了PostgreSQL的二进制安装包,可以让你使用yum来安装和更新PostgreSQL。
sudo yum install -y postgresql14-server
sudo /usr/pgsql-14/bin/postgresql-14-setup initdb
# 使用PostgreSQL 14的postgresql-14-setup脚本初始化一个新的PostgreSQL 14数据库。
sudo systemctl enable postgresql-14
sudo systemctl start postgresql-14

1.4 登录数据库

方法一:在默认配置下,本机访问 PostgreSQL

[root@localhost ~]# su - postgres               # 切换 postgres 用户
上一次登录:日 3月 24 12:49:21 CST 2024pts/0 上
-bash-4.2$ psql                                 # 登录 PostgreSQL 控制台
psql (14.11)
输入 "help" 来获取帮助信息.postgres=#                       # 此时说明用 postgres 身份登录数据库,且不需要密码
postgres=# \password postgres                   # 给 postgres 用户设置密码
Enter new password for user "postgres": 
再输入一遍:

方法二:创建新用户来访问 PostgreSQL

[root@localhost ~]# su - postgres              # 切换linux用户postgres
上一次登录:日 3月 24 13:03:32 CST 2024pts/0 上
-bash-4.2$ psql                                # 执行psql
psql (14.11)
输入 "help" 来获取帮助信息.postgres=# CREATE USER dbfql WITH PASSWORD '123456'; # 创建数据库用户dbfql
CREATE ROLE
postgres=# CREATE DATABASE db1 OWNER dbfql;    # 创建数据库db1
CREATE DATABASE
postgres=# GRANT ALL PRIVILEGES ON DATABASE db1 TO dbfql;  # 将db1数据库的所有权都赋予dbdql
GRANT  
postgres=# \q-bash-4.2$ exit
登出[root@localhost ~]# useradd dbfql  # 创建普通用户dbfql
[root@localhost ~]# passwd dbfql
[root@localhost ~]# su - dbfql
上一次登录:日 3月 24 13:42:25 CST 2024pts/0 上
[dbfql@localhost ~]$ psql -d db1
psql (14.11)
输入 "help" 来获取帮助信息.db1=> 

方法三:已存在普通用户,在数据库创建同名用户和数据库

[root@localhost ~]# id lisi
uid=1002(lisi) gid=1002(lisi) 组=1002(lisi)
[root@localhost ~]# su - postgres
上一次登录:日 3月 24 13:29:32 CST 2024pts/0 上
-bash-4.2$ psql
psql (14.11)
输入 "help" 来获取帮助信息
postgres=# CREATE USER lisi WITH PASSWORD '123456';
CREATE ROLE
postgres=# CREATE DATABASE lisidb OWNER lisi;
CREATE DATABASE
postgres=# GRANT ALL PRIVILEGES ON DATABASE lisidb TO lisi;
GRANT
postgres=# \q
-bash-4.2$ exit
登出[root@localhost ~]# su - lisi
上一次登录:日 3月 24 13:51:56 CST 2024pts/0 上
[lisi@localhost ~]$ psql -d lisidb
psql (14.11)
输入 "help" 来获取帮助信息.lisidb=> 

2. 编译安装

2.1 安装依赖包

[root@localhost ~]# systemctl stop firewalld.service 
[root@localhost ~]# setenforce 0
[root@localhost ~]# yum install -y gcc.x86_64 make readline-devel zlib-devel

2.2 源码编译安装

[root@localhost opt]# wget https://ftp.postgresql.org/pub/source/v14.1/postgresql-14.1.tar.gz
[root@localhost opt]# ls
postgresql-16.2.tar.gz  rh
[root@localhost opt]# tar xf postgresql-14.1.tar.gz 
[root@localhost opt]# cd postgresql-14.1/
[root@localhost postgresql-14.1]# ./configure --prefix=/apps/pgsql --with-pgport=5432
[root@localhost postgresql-14.1]# make -j 2 && make install

2.3 创建数据库用户和组

PostgreSQL 默认不支持 以 root 身份启动服务,虽然也可修改源码实现 root 启动,但基于安全考虑不建议,因此必须创建一个用于启动 PostgrepSQL 的普通用户。

[root@localhost postgresql-14.1]# useradd -s /bin/bash -m -d /home/postgres postgres
# 创建数据库用户和组,注意此用户需要可以交互登录
[root@localhost postgresql-14.1]# echo "123123" | passwd  --stdin  postgres
更改用户 postgres 的密码 。
passwd:所有的身份验证令牌已经成功更新。
# 修改postgres密码

2.4 创建数据目录并授权

[root@localhost postgresql-14.1]# mkdir /pgsql/data -pv
[root@localhost postgresql-14.1]# chown postgres.postgres /pgsql -R

2.5 设置环境变量

[root@localhost ~]# vim /etc/profile.d/pgsql.sh
export PGHOME=/apps/pgsql
export PATH=$PGHOME/bin/:$PATH
export PGDATA=/pgsql/data
export PGUSER=postgres
export MANPATH=/apps/pgsql/share/man:$MANPATH

2.6 初始化数据库

[root@localhost ~]# su - postgres
[postgres@localhost ~]$ initdb -D /pgsql/data  # -D 指定数据目录

2.7 启动和关闭服务

[postgres@localhost ~]$ pg_ctl start
#开启
[postgres@localhost ~]$ pg_ctl stop
#停止
[postgres@localhost ~]$ pg_ctl -l logfile start
#将日志记录到文件中,不加就打印在屏幕上
[postgres@localhost ~]$ pg_ctl restart
#重启

2.8 创建 service 文件

[root@localhost ~]# vim /lib/systemd/system/postgresql.service
[Unit]
Description=PostgreSQL database server
After=network.target
[Service]
User=postgres
Group=postgres
ExecStart=/apps/pgsql/bin/postmaster -D /pgsql/data
ExecReload=/bin/kill -HUP
[Install]
WantedBy=multi-user.target
[root@localhost ~]# systemctl start postgresql.service 
[root@localhost ~]# systemctl status postgresql
● postgresql.service - PostgreSQL database serverLoaded: loaded (/usr/lib/systemd/system/postgresql.service; disabled; vendor preset: disabled)Active: active (running) since 日 2024-03-24 15:17:25 CST; 2s ago

2.9 登录数据库

[root@localhost ~]# su - postgres
上一次登录:日 3月 24 15:01:04 CST 2024pts/0 上
[postgres@localhost ~]$ psql
psql (14.1)
Type "help" for help.postgres=# 

三、PostgreSQL 远程登录

1. 编辑配置文件

[root@localhost ~]# vim /pgsql/data/postgresql.conf
listen_address = '*'
# 在所有IP地址上监听,从而允许远程连接到数据库服务器[root@localhost ~]# vim  /pgsql/data/pg_hba.conf
host    all             all             0.0.0.0/0               md5
# 允许任意用户从任意地址上以密码方式访问数据库[root@localhost ~]# su - postgres
上一次登录:日 3月 24 15:17:53 CST 2024pts/1 上
[postgres@localhost ~]$ psql
psql (14.1)
Type "help" for help.postgres=# alter user postgres with password '123123';  # 登录数据修改密码
ALTER ROLE

2. 重启数据库服务

[root@localhost ~]# systemctl restart postgresql.service

3. 远程登录

[root@localhost ~]# psql -U postgres -h 192.168.190.104
用户 postgres 的口令:
psql (14.11, 服务器 14.1)
输入 "help" 来获取帮助信息.postgres=# 

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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024/3/23打卡数组分割(第14届蓝桥杯)——二项式+快速幂

题目 思路 分析该题,要将集合 划分成两个子集 ,且两个子集的和都是偶数。 可知:偶数 偶数 偶数;偶数 奇数 奇数;奇数 奇数 偶数; 分析可得:如果该集合的和为奇数,就不能分…

八、C#计数排序算法

简介 计数排序是一种非比较性的排序算法,适用于排序一定范围内的整数。它的基本思想是通过统计每个元素的出现次数,然后根据元素的大小依次输出排序结果。 实现原理 首先找出待排序数组中的最大值max和最小值min。 创建一个长度为max-min1的数组count…

IP如何异地共享文件?

【天联】 组网由于操作简单、跨平台应用、无网络要求、独创的安全加速方案等原因,被几十万用户广泛应用,解决了各行业客户的远程连接需求。采用穿透技术,简单易用,不需要在硬件设备中端口映射即可实现远程访问。 异地共享文件 在…

Calico配置路由反射器 (RR) 模式

RR介绍 在 Calico 网络中,默认使用 Node-to-Node Mesh 全互联模式,即集群中的每个节点之间都会相互建立 BGP 连接,用于路由交换。然而,随着集群规模的扩大,全互联模式会导致连接数成倍增加,产生性能问题。为…

Linux 注入依赖环境

文章目录 配置依赖程序安装 JDK安装 Tomcat安装 mysql 配置依赖程序 下面配置依赖程序都以CentOS为例。 安装 JDK 可以直接使用 yum(CentOS) 直接进行安装。 先搜索,确定软件包的完整名称。 yum list | grep jdk再进行安装 进行安装的时候一定要先确保处在“管理…

前端学习--品优购项目

文章目录 前端学习--品优购项目1.案例铺垫文件建立与命名必备文件网站favicon图标网站TDK三大标签SEO优化常用命名 2.LOGO SEO优化3.实际代码4.申请免费域名 前端学习–品优购项目 1.案例铺垫 文件建立与命名 一个项目中为了方便实用和查找内容会有多个文件夹,比如…

idea插件开发案例:将批量插入方法转换成分批批量插入

代码: idea-plugin-demo 1.背景 excel导入时都会使用批量插入或者批量更新到数据库,这在mysql下没有问题。 但因为公司国产化需求,换成达梦数据库就不行了,报sql超长。 一开始想写mybatis拦截器处理,又怕出现bug,这个问…

MySQL为什么会选错索引

在平时不知道一有没有遇到过这种情况,我明明创建了索引,但是MySQL为何不用索引呢?为何要进行全索引扫描呢? 一、对索引进行函数操作 假设现在维护了一个交易系统,其中交易记录表 tradelog 包含交易流水号(tradeid)、交…

Ubuntu 中如何选择Java版本

如何在 Ubuntu 上安装多个版本的 Java 首先,我们得检查一下你的系统里是否已经装了 Java。这个很简单,只需运行下面这条命令: 在 Linux 上安装 Java 的实战示例update-java-alternatives --list 输出结果: 检查是否安装了 Java…

存储的过程

一、存储过程 1.1 概述 存储过程可以轻松而高效的去完成这个需求,有点类似shell脚本里的函数 1.2 特点 存储过程在数据库中创建并保存,它不仅仅是 SQL 语句的集合,还可以加入一些特殊的控制结构,也可以控制数据的访问方式。存储过…

lora-scripts 训练IP形象

CodeWithGPU | 能复现才是好算法CodeWithGPU | GitHub AI算法复现社区,能复现才是好算法https://www.codewithgpu.com/i/Akegarasu/lora-scripts/lora-trainstable-diffusion打造自己的lora模型(使用lora-scripts)-CSDN博客文章浏览阅读1.1k次…

web 技术中前端和后端交互过程

1、客户端服务器交互过程 客户端:上网过程中,负责浏览资源的电脑,叫客户端服务器:在因特网中,负责存放和对外提供资源的电脑叫服务器 服务器的本质: 就是一台电脑,只不过相比个人电脑它的性能高很多,个人电脑中可以通过安装浏览器的形式,访问服务器对外提供的各种资源。 个人…

如何在vue中使用echarts,与jquery中有啥不同。

一、vue中使用echarts的步骤 在 Vue 中使用 ECharts 可以按照以下步骤进行: 安装 ECharts:使用 npm 或 yarn 安装 ECharts: npm install echarts 在 Vue 组件中引入 ECharts: import echarts from echarts 在 Vue 组件的 mou…

http响应练习—在服务器端渲染html(SSR)

一、什么是服务器端渲染(SSR) 简单说,就是在服务器上把网页生成好,整个的HTML页面生成出来,生成出的页面已经包含了所有必要的数据和结构信息,然后直接发给浏览器进行展现。 二、例题 要求搭建http服务&a…

QT_day4:对话框

1、完善对话框,点击登录对话框,如果账号和密码匹配,则弹出信息对话框,给出提示”登录成功“,提供一个Ok按钮,用户点击Ok后,关闭登录界面,跳转到其他界面 如果账号和密码不匹配&…

其实StartAI也是一款修图工具 用StartAI修图之“去除背景”

其实StartAI不仅仅是一款AI绘画插件,更是一款可以对我们的摄影图片、广告海报进行修图的AI修图工具。StartAI包含了AI绘画、AI修图等多种复合型AI智能实用工具。 用【背景移除】功能对图片一个背景修图 1.实体广告图片 我们可以通过【背景移除】将广告图中的实体…

软考中级 --网络工程师真题试卷 2023下半年

在EIGRP协议中,某个路由器收到了两条路径到达目标网络,路径1的带宽为100Mbps,延迟2ms,路径2的带宽为50Mbps,迟为4ms,如果EIGRP使用带宽和延迟的综合度量标准,那么该路由器选择的最佳路径是(D)。…

【Flink】WaterMark 实战

WaterMark 实战 1.WaterMark 触发详解2.实际案例 1.WaterMark 触发详解 例如,现在我们有了一个 [12:00:00-12:00:10) 的时间窗口,现在事件如下图所示顺序 A、B、C、D、E、F … 到达。 在未设置 WaterMark 的情况下,当元素 C 到达的时候&…

[Semi-笔记]Switching Temporary Teachers for Semi-Supervised Semantic Segmentation

目录 概要创新一:Dual Temporary Teacher挑战:解决: 创新二:Implicit Consistency Learning(隐式一致性学习)挑战:解决: 实验结果小结论文地址代码地址 分享一篇2023年NeurIPS的文章…

Fastjson反序列化漏洞原理与漏洞复现(基于vulhub靶场)

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~ ✨主攻领域:【渗透领域】【应急响应】 【Java、PHP】 【VulnHub靶场复现】【面试分析】 🎉点赞➕评论➕收…