【连载】关系型数据库是如何工作的?(7) - 数据库架构视图

现在我们可以看看数据库内部都有什么组件。一个数据库就是容易访问和修改的信息集合,实际上,一组简单的文件就可以做到。最简单的数据库SQLite就是由一组简单文件组成的,并且是一组精心设计的一组文件,它允许你:

  • 通过事务保证数据的安全性和一致性;
  • 即时海量数据也能保证快速处理数据。

通常,一个数据的组件视图如下:

在写下这部分内容之前,我阅读了很多书籍和论文,每一个都有其特有的方式来描述数据库。因此就不要纠结我怎么组织数据库,或者我怎么命名这些组件,因为我已经为此考虑良久来适合这篇文章。不同的组件并不重要,重要的是将一个数据库划分为多个组件及其之间的联系。

核心组件

  • 进程管理器:许多数据库都包含一个被管理的进程或线程池。而且为了支持纳秒,很多数据库使用它们自己的线程而不是操作系统线程。
  • 网络管理器:网络IO是一个很重要的议题,尤其对于分布式数据库,因此一些数据库有它们自己的网络管理器。
  • 文件系统管理器:磁盘IO是数据库的第一瓶颈,因此用一个管理器来完美的处理操作系统文件系统,甚至取而代之就极其重要。
  • 内存管理器:为了避免磁盘IO的瓶颈,一个大的内存是必要的。但是如果你处理一个很大的内存,那就需要一个高效的管理器,尤其是当你有大量并发的使用内存的查询请求时。
  • 安全管理器:用于管理身份认证和用户权限。
  • 客户端管理器:用于管理客户端连接。

工具

  • 备份管理器:保护和恢复数据;
  • 恢复管理器:宕机后保证数据状态的一致性,并正常重启;
  • 监控管理器:记录数据库的行为,并提供工具来监控;
  • 数据库管理器:存储元数据(像表的名字和结构),并提供工具管理数据库、Schemas、表空间…

查询管理

  • 查询解析器:检查查询语句是否有效;
  • 查询重写器:预优化查询;
  • 查询优化器:优化查询;
  • 查询执行器:编译并执行查询语句;

数据管理

  • 事务管理器:处理事务;
  • 缓存管理器:在从磁盘读或写之前,把数据先放入内存;
  • 数据访问管理器:访问在磁盘上的数据。

这篇文章的其余部分,我会聚焦于一个数据库如何管理一个查询的一下过程:

  • 客户端管理
  • 查询管理
  • 数据管理(包括数据恢复)

下一章节我们首先介绍客户端管理。

时间: 2024-11-10 17:38:16

【连载】关系型数据库是如何工作的?(7) - 数据库架构视图的相关文章

关系型数据库之Mysql编译安装及数据库基础(一)

一.为什么会有数据库呢? 刚开始接触数据库的朋友们,都会问数据库用来干啥的呢?字面表达的意思就是用来存储数据的仓库简称"数据库",在日常生活中我们与数据库相关的事务都是一大把一大把的,例如: 1.我们去做火车的时候需要实名认证,为什么安检人员可以通过我们的身份证就可以查询我们的个人信息呢,因为们都是有户口的群众,在公安居民信息库都录入着我们的信息,而们的信息也是存储在国家公民的信息库里面的,这也是我们所说的数据库,早期最传统的数据库就是文本文件,没当查询数据时都需要从头到尾把整个文件都

commit后数据库干的工作

用户提交commit后,数据库干的工作有: 1,oracle为用户的transaction生成一个SCN号. 2,LGWR把redo buffer中的数据写入到redo log file,同时把SCN号记录到redo log file中.这一步完成后,说明用户提 交的数据已经安全的写到磁盘 3,释放用户session占用的locks,这些locks可以在V$LOCK中查到.释放用户的lock后,那么其他在等待lock的session 就会被唤醒,继续它们的工作 4,如果在commit后,用户tr

SQL Server之 (一) 数据库简介 SQL Server环境配置 数据库基础知识

   前言 这个是我工作两年多后,再次从最基础的SQL入门开始,认真的学一遍SQL Server,捡漏和巩固都有;因为自己刚开始学的时候,总是心烦气躁,最近换工作,发现1到2年经验,问到基础性的东西还是很多,这个时候需要的是扎实的基础功夫,所以一系列打击+反省后,自己节假日在家从最基础重新认识一下SQL Server,继续沉淀一下.哪里有不对或需深入探讨,请直接留言或者小窗我;欢迎~ (一) 数据库简介   SQL Server环境配置   数据库基础知识 1.什么是数据库,数据库有哪些特点,为

基于C#的MongoDB数据库开发应用(1)--MongoDB数据库的基础知识和使用

在花了不少时间研究学习了MongoDB数据库的相关知识,以及利用C#对MongoDB数据库的封装.测试应用后,决定花一些时间来总结一下最近的研究心得,把这个数据库的应用单独作为一个系列来介绍,希望从各个方面来总结并记录一下这个新型.看似神秘的数据库使用过程.本文是这个系列的开篇,主要介绍一些MongoDB数据库的基础知识.安装过程.基础使用等方面. MongoDB是一款由C++编写的高性能.开源.无模式的常用非关系型数据库产品,是非关系数据库当中功能最丰富.最像关系数据库的数据库.它扩展了关系型

数据库复习总结(1)-数据库简介

一.什么是数据库 数据库Database:存储数据的仓库DB 随着电商的发展,仓库也越来越多的被大家所知道:关于仓库管理员的工作大家也有所了解 自古至今,都有很多种仓库:粮仓,弹药库等 仓库中还会有仓库管理员(DBA)对货物进行管理 从仓库中拿货物需要凭证,取货和进货的人(程序员) 二.我们怎么存储数据 发展历程:结绳记事->文件存储->计算机 对于数据不仅需要存储,更重要的是将数据进行存储以后怎么才能方便快捷的查询.修改 数据库特点:海量存储.查找速度快.并发性问题控制.安全性.数据完整性(

重新定义数据库的时刻,阿里云数据库专家带你了解POLARDB

摘要:POLARDB是阿里云ApsaraDB数据库团队研发的基于云计算架构的下一代关系型数据库,其最大的特色是计算节点与存储节点分离,借助优秀的RDMA网络以及最新的块存储技术.POLARDB不但满足了公有云计算环境下用户业务快速弹性扩展的刚性需求,同时也满足了互联网环境下用户对数据库服务器高可用的需求.本文就带领大家了解什么是"云原生数据库",云原生数据库的标准是什么,如何定义以及为何如此定义?为大家介绍下一代云原生数据库POLARDB的架构.产品设计.未来工作等内容. 以下内容根据

跨越数据库发展鸿沟,谈分布式数据库技术趋势

金融行业架构转型需求随着移动化与互联网化的不断发展,我国金融行业的商业模式与技术体系已经逐渐走上了与西方世界完全不同的道路.众所周知,欧美国家的移动化普及率远远不如我国,同时人口基数也有着数量级的不同,这就使得国内外金融行业所面临的业务类型.数据量.并发量都存在巨大的差异,导致对整个IT基础设施的需求截然不同. 在最近的一两年中,国内部分科技领先的银行已经率先对微服务与分布式技术进行了探索,一些新建的互联网金融类业务也已经开始尝试使用微服务架构.分布式技术.DevOps框架进行应用的开发与维护.

数据库设计 Step by Step (2)——数据库生命周期

引言:数据库设计 Step by Step (1)得到这么多朋友的关注着实出乎了我的意外.这也坚定了我把这一系列的博文写好的决心.近来工作上的事务比较繁重,加之我期望这个系列的文章能尽可能的系统.完整,需要花很多时间整理.思考数据库设计的各种资料,所以文章的更新速度可能会慢一些,也希望大家能够谅解. 系列的第二讲我们将站在高处俯瞰一下数据库的生命周期,了解数据库设计的整体流程 数据库生命周期 大家对软件生命周期较为熟悉,数据库也有其生命周期,如下图所示. 图(1)数据库生命周期 数据库的生命周期

CentOS6.4下Mysql数据库的安装与配置,导入数据库,授权远程ip

卸载掉原有mysql 因为mysql数据库在Linux上实在是太流行了,所以目前下载的主流Linux系统版本基本上都集成了mysql数据库在里面,我们可以通过如下命令来查看我们的操作系统上是否已经安装了mysql数据库 [[email protected] ~]# rpm -qa | grep mysql // 这个命令就会查看该操作系统上是否已经安装了mysql数据库 有的话,我们就通过 rpm -e 命令 或者 rpm -e --nodeps 命令来卸载掉 [[email protected

Winform开发框架中实现多种数据库类型切换以及分拆数据库的支持 - 伍华聪

在很多应用系统里面,虽然一般采用一种数据库运行,但是由于各种情况的需要,可能业务系统会部署在不同类型的数据库上,如果开发的系统能够很方便支持多种数据库的切换,那可以为我们减少很多烦恼,同时提高系统的适应性和强壮型.还有一种情况,由于业务数据库的不断膨胀或者方便数据库的切割隔离,有时候也会把不同的业务数据库进行分拆,如权限提供数据库,客户关系管理数据库,工作流程数据库,企业营运数据库等等,因此在一个系统里面,同时使用2个或者以上的数据库的情况也是有的.针对这两种情况,本文介绍在我的Winform开