PostgreSQL学习笔记二:PostgreSQL的系统架构

PostgreSQL 是一种功能强大的开源关系型数据库管理系统,其架构具有以下特点:

一、客户端/服务器架构

  1. 客户端

    • 客户端可以是各种应用程序,如 Web 应用、桌面应用等,它们通过网络连接与 PostgreSQL 服务器进行通信。
    • 客户端使用标准的数据库连接协议(如 ODBC、JDBC 等)向服务器发送 SQL 查询和命令,并接收服务器返回的结果。
  2. 服务器

    • PostgreSQL 服务器负责存储和管理数据,并处理来自客户端的请求。
    • 服务器由多个进程组成,包括主进程(postmaster)和多个后端进程(backend process)。主进程负责监听客户端连接请求,并为每个连接分配一个后端进程来处理具体的查询。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、存储引擎

  1. 表和索引存储

    • PostgreSQL 使用磁盘上的文件来存储数据库表和索引。表数据以行的形式存储,每行包含多个列的值。索引用于加速数据的检索,可以是 B 树索引、哈希索引等多种类型。
    • 存储引擎负责管理数据的存储、检索和更新操作,确保数据的完整性和一致性。
  2. 事务处理

    • PostgreSQL 支持事务处理,确保一组数据库操作要么全部成功执行,要么全部回滚。事务具有原子性、一致性、隔离性和持久性(ACID)特性。
    • 存储引擎通过日志记录和锁机制来实现事务的并发控制和恢复。

在这里插入图片描述

三、查询处理

  1. 查询解析和优化

    • 当客户端发送一个 SQL 查询时,PostgreSQL 首先对查询进行解析,将其转换为内部的查询树表示。
    • 然后,查询优化器对查询树进行优化,选择最优的执行计划。优化器考虑多个因素,如索引的使用、表连接顺序、数据分布等,以提高查询性能。
      在这里插入图片描述
  2. 执行引擎

    • 执行引擎根据优化后的执行计划执行查询。它可以执行各种操作,如表扫描、索引查找、连接操作、聚合函数计算等。
    • 执行引擎与存储引擎紧密协作,从磁盘上读取数据,并将结果返回给客户端。
      在这里插入图片描述

四、并发控制

  1. 多版本并发控制(MVCC)

    • PostgreSQL 使用 MVCC 来实现并发控制。MVCC 允许多个事务同时对数据库进行读写操作,而不会相互阻塞。
    • 每个事务看到的是数据库的一个一致性快照,而不是直接修改数据库的实际数据。当事务提交时,它的修改才会对其他事务可见。
  2. 锁机制

    • PostgreSQL 也使用锁来防止并发事务之间的冲突。锁可以是行级锁、表级锁等不同级别,用于保护数据的完整性和一致性。
    • 锁的管理是自动进行的,数据库系统会根据事务的需求自动获取和释放锁。
      在这里插入图片描述

五、高可用性和扩展性

  1. 复制和备份

    • PostgreSQL 支持数据复制,可以将数据复制到多个服务器上,以实现高可用性和负载均衡。
    • 可以使用主从复制或流复制等方式进行数据复制。同时,PostgreSQL 还提供了备份和恢复工具,以便在数据丢失或损坏时进行恢复。
      在这里插入图片描述
      在这里插入图片描述
  2. 扩展插件

    • PostgreSQL 具有良好的可扩展性,可以通过安装扩展插件来增加新的功能。例如,可以安装地理信息系统(GIS)扩展、全文搜索扩展等。
    • 扩展插件可以由第三方开发者开发,也可以由用户自己编写。
      在这里插入图片描述

    总之,PostgreSQL 的架构设计使其成为一个功能强大、可靠且可扩展的数据库管理系统。它的客户端/服务器架构、存储引擎、查询处理、并发控制和高可用性等方面的特点,使其适用于各种应用场景,从小型项目到大型企业级应用。

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

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

相关文章

学习 PostgreSQL + Spring Boot 3 +mybatisplus整合过程中的报错记录

今天计划学习 PostgreSQL,并顺便尝试使用 Spring Boot 3.x 框架,打算整合 Spring Boot 3、PostgreSQL 和 MyBatis-Plus。整合后一直出现以下报错: 去AI上面搜了讲的是sqlSessionFactory 或 sqlSessionTemplate 没有正确配置 初始分析&#…

03 django管理系统 - 部门管理 - 部门列表

部门管理 首先我们需要在models里定义Dept类 # 创建部门表 class Dept(models.Model):name models.CharField(max_length100)head models.CharField(max_length100)phone models.CharField(max_length15)email models.EmailField()address models.CharField(max_length2…

【2024年10月测试通过】conda下使用虚拟环境安装最新版pytorch2.4+cuda12.4

开头先说重点: 1.采用conda的虚拟环境,会在沙盒环境下安装好所有所需包,而且该虚拟环境拷贝给其他人员可以直接用,很方便。 2.pytorch官网访问不了,有一个国内镜像推荐,地址为PyTorch - PyTorch 中文 3.…

怎么ping网络ip地址通不通

怎么Ping网络IP地址通不通?要检查网络中的IP地址是否连通,可以使用‌Ping命令。Ping命令通过发送ICMP(Internet Control Message Protocol,因特网控制消息协议)Echo请求报文并等待回应,来判断目标主机是否可…

MongoDB-aggregate流式计算:带条件的关联查询使用案例分析

在数据库的查询中,是一定会遇到表关联查询的。当两张大表关联时,时常会遇到性能和资源问题。这篇文章就是用一个例子来分享MongoDB带条件的关联查询发挥的作用。 假设工作环境中有两张MongoDB集合:SC_DATA(学生基本信息集合&…

python发邮件附件:配置SMTP服务器与认证?

python发邮件附件技巧?Python发送多附件邮件的方法? Python作为一种强大的编程语言,提供了丰富的库和工具来实现这一功能。AokSend将深入探讨如何使用Python发邮件附件,并详细介绍配置SMTP服务器与认证的关键步骤。 python发邮件…

【Windows】【DevOps】Windows Server 2022平台启用WinRM实现远程powershell登陆 采用自签名证书开启HTTPS方案

快速配置开启WinRM(HTTP) quiciconfig 在目标服务器上,管理员权限启动powershell,执行指令 winrm quickconfig 输入y,完整日志如下 PS C:\Windows\system32> winrm quickconfig 已在此计算机上运行 WinRM 服务。 WinRM 没有设置成为了…

《Spring Microservices in Action, 2nd Edition》读后总结

总体来说有种时过境迁的感觉,有些章节的内容已经跟不上现在,特别对于云原生大行其道的当下, 越来越多东西下沉到基础设施层,然后应用层尽量轻量化成了一种新趋势;当然任何事物都具有多面性,云原生那套也要投…

vue3+vite@4+ts+elementplus创建项目详解

1、第一步创建项目cnpm init vite4 2、设置vue3.2局域网可访问配置: 找到项目路径下的package.json目录下找到script对象下面添加一下代码: "serve": "vite --host 0.0.0.0" 启动项目命令不在是dev而是:cnpm run serve 3…

固体废物处理(一)——MDPI特刊推荐

特刊征稿 01 期刊名称: Advances in Organic Solid Waste and Wastewater Management 截止时间: 投稿截止日期:11月30日2024 目标及范围: 本主题旨在收集有关有机固体废物和废水管理最新进展的贡献。感兴趣的主题包括与废水…

AI赋能!0基础小白自媒体创业,成功率提升90%的秘诀?

本文背景 好多小伙伴也想写公众号文章,但是自己又没有写过,不知道如何开始。 今天分享个小方法,就算是写作新手,也能靠 AI 快速上手,写出好内容! 一起来看看怎么用 AI 工具 助力写作,提高效率&a…

【计算机网络】详解IP协议网段划分路由转发子网掩码网络号

一、IP功能 IP可以实现主机定位和路由选择,提供一种能力,将数据可靠地从A点跨网络送到B点。数据先根据目的IP在局域网之间进行转发,再在局域网内进行内网转发。 二、IP协议报头 4 位版本号(version):指定 IP 协议的版本&#xff…

shell案例(shell中输出彩色Hello world)

Shell中输出彩色Hello world 循环遍历不同的ANSI转义序列代码,展示了各种字体颜色、背景颜色和显示方式的效果,每个部分都包含了一个简单的循环,通过echo -e命令输出带有相应颜色或显示方式的字符串,并在每部分之间输出空行以分割…

MyBatis XML映射文件

XML映射文件 XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)XML映射文件的namespace属性为Mapper接口全限定名一致XML映射文件中SQL语句的id与Mapper接口中的方法名一致,并保持返…

ICLR 2024 Spotlight|SEAL:面向真实场景超分辨率的系统性评估框架

研究背景 现实世界图像超分辨率(Real-World Super-Resolution, Real-SR)技术,作为提升图像清晰度的关键技术,正变得越来越重要。然而,如何准确评估Real-SR方法的性能,一直是该领域的一大挑战。目前的评估…

步步精科技诚邀您参加2024慕尼黑华南电子展

尊敬的客户: 我们诚挚地邀请您参加即将于2024年10月14日至10月16日在深圳国际会展中心 (宝安新馆)举办的慕尼黑华南电子展(electronica South China)。本届将聚焦人工智能、数据中心、新型储能、无线通信、硬件安全、新能源汽车、第三代半导…

云原生(四十四) | 远程连接ECS服务器

文章目录 远程连接ECS服务器 一、自带连接工具连接ECS云服务器 二、为什么要使用远程连接工具 三、远程连接ECS服务器四要素 1、用户名 密码 2、IP地址(公网IP) 3、SSH端口号 4、阿里云安全组 四、使用MobaXterm远程连接ECS云服务器 五、ECS云…

讯飞星火与昇腾AI双向奔赴:本土化技术创新应对全球化挑战的一次成功验证

文 | 智能相对论 作者 | 陈泊丞 2019年,彼时的AI赛道还不像今天这么热。 这一年,人工智能连续第三年出现在政府工作报告中,政策关键词从“加快”“加强”转变为“深化”,开始进入行业需求快速增长的应用探索期。而华为也在这个…

爬虫(反调试)

其实就是一种给页面反爬机制,一般页面用不到。 万能解决反调试方法:

vue-插槽作用域实用场景

vue-插槽作用域实用场景 1.插槽1.1 自定义列表渲染1.2 数据表格组件1.3 树形组件1.4 表单验证组件1.5 无限滚动组件 1.插槽 插槽感觉知道有这个东西,但是挺少用过的,每次看到基本都会再去看一遍用法和概念。但是在项目里,自己还是没有用到过…