iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎样解析mysql与oracle 体系结构
  • 560
分享到

怎样解析mysql与oracle 体系结构

2024-04-02 19:04:59 560人浏览 八月长安
摘要

这篇文章给大家介绍怎样解析Mysql与oracle 体系结构,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 做为一个学习oracle的工程师,现在开始学

这篇文章给大家介绍怎样解析Mysqloracle 体系结构,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

做为一个学习oracle的工程师,现在开始学习mysql

  mysql数据库和oracle 相比作为一个开源数据库,从学习的角度来说的话。他不像oracle的教育体系。文档那么全面

学习oracle最好的方法是看oracle的官方文档。本人由于英语水平有限。所以看了高性能mysql和深入浅出mysql

看了俩本书都不错。所有的资料都是教你怎么干活的。对于体系架构等还是有点少。

我个人认为学习数据库,要先了解数据库的体系结构和sql的执行过程。经过查询很多资料。感觉自己应该是明白了

先说oracle 体系结构,oracle的体系结构图官方都有。网上也有好多讲这个东西的。如果不明白可以查找下看一下。oracle的资料市面非常多。
提示:只做了innodb的比较,剩下的存储引擎为在之中
怎样解析mysql与oracle 体系结构

   1,数据库(database):     |—物理存储:(os操作系统文件):        |— datafile      数据文件(存储的是实实在在数据的地方)业务数据、系统数据、临时数据(order by。。)回退数据

                                                |                                                               |—countralfile  控制文件(存储的是数据库的结构信息)

                                                |                                                               |—logfile         日志文件(存储的是改变的数据)做恢复用

                                                |—逻辑存储: |—表空间(table space)存数据字典的地方

                                                                      |—段(磁盘/io,存储各种类型的数据的地方)不能跨表空间                                                                         

                                                                      |—区(为段分配空间的)不能跨越段                                                                        

                                                                      |—块(最小的单位是block)不能跨越区

   2,实例(instance): |—sga:内存cpu: shard pool 共享池:最近使用的sql语句(程序)和最近使用的数据字典的信息

                                        |                         buffer cache  数据库缓冲区:最近使用的数据,大小由db_cache_size决定

                                        |                         redo log buffer  日志缓冲区:最近改变的数据log buffer。按顺序写,循环写

                                        |                         java pool

                                        |                         large pool

                                        |—后台进程: |—数据库写进程dbwr:把数据由数据库缓冲区写入数据文件里

                                                              |—日志写进程lgwr:把数据由日志缓冲区写入日志文件里

                                                              |—检查点进程ckpt:1,数据库同步的标志。三大核心文件必须保证在同一检查点上,数据库才能起来,最先写在日志文件里,写在数据文件的头里

                                                              |                           2,触发数据库写进程,把数据由数据库缓冲区写入数据文件里

                                                              |—系统监控进程smon:1,历程恢复

                                                              |                               2,释放临时段的空间

                                                              |                               3,合并相邻的空间碎片

                                                              |—程序监控进程pmon:释放资源(包括正常和异常资源)

                                                              |  MMON监视进程每到指定时间去访问统计数据,这样就知道表空间使用量到警告或边界没有

怎样解析mysql与oracle 体系结构

下面看一下mysql的结构图
怎样解析mysql与oracle 体系结构


对于mysql来说他是线程模式。所以对应的上面oracle进程

master thread 主要负责将脏缓存页刷新到数据文件,执行purge操作,触发检查点,合并插入缓冲区

insert buffer thread 负责插入缓冲区的合并操作

read thread 负责数据库 读读操作,可配置多个读线程

write theead 负责数据库 读写操作,可配置多个写线程

log theead 用于数据库的重做日志刷新到logfile 中

purage theead   mysql5.5之后单独的purage theead  执行purge操作 

事务被提交后,其所使用的undolog可能不再需要,因此需要PurgeThread来回收已经使用并分配的undo页。在InnoDB 1.1版本之前,purge操作仅在InnoDB存储引擎的Master Thread中完成。而从InnoDB 1.1版本开始,purge操作可以独立到单独的线程中进行,以此来减轻Master Thread的工作,从而提高CPU的使用率以及提升存储引擎的性能。用户可以在MySQL数据库的配置文件中添加如下命令来启用独立的Purge Thread:

look thread 负责控制和死锁检测等

错误检测线程: 主要负责错误监控和错误处理

write theead master thread 相当于 dbwr 
数据库写进程dbwr:把数据由数据库缓冲区写入数据文件里
master thread 主要负责将脏缓存页刷新到数据文件,执行purge操作,触发检查点,合并插入缓冲区
write theead 负责数据库 读写操作,可配置多个写线程

insert buffer thread 类似于  smon

系统监控进程smon:

1,历程恢复     

2,释放临时段的空间    

3,合并相邻的空间碎片
insert buffer thread 负责插入缓冲区的合并操作

log theead  
日志写进程lgwr:把数据由日志缓冲区写入日志文件里
log theead 用于数据库的重做日志刷新到logfile 中

上述基本是我总结的mysql和oracle的instace中进程线程的结构

现在分析mysql的内存结构

共享池
shard pool 共享池:最近使用的sql语句(程序)和最近使用的数据字典的信息
QueryCache(下面简称QC)是根据SQL语句来cache的。一个SQL查询如果以select开头,那么MySQL服务器将尝试对其使用QC。每个Cache都是以SQL文本作为key来存的。在应用QC之前,SQL文本不会被作任何处理
mysql的QC 很简陋啊只要数据进行更改就会清除qc里的数据。原来我非常不理解的东西。现在明白了。不过深入解析没有看

buffer cache 和innodb buffer cache
存储数据的地方。mysql 是在innodb层处理这个问题。

      buffer cache  数据库缓冲区:最近使用的数据,大小由db_cache_size决定redo log buffer 和innodb redo log buffer              

写入数据库时候先写入redo log buffer  顺序写入内存,刷新到硬盘,顺序写。最后通过写进程刷新到datafile里面
保证写入的io。
综上所述:mysql 和mysql innodb的别也就上述几点基本差不多。只是mysql简陋了好多。
学习mysql是可以更好的了解数据库。

关于怎样解析mysql与oracle 体系结构就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: 怎样解析mysql与oracle 体系结构

本文链接: https://www.lsjlt.com/news/66211.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎样解析mysql与oracle 体系结构
    这篇文章给大家介绍怎样解析mysql与oracle 体系结构,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 做为一个学习oracle的工程师,现在开始学...
    99+
    2024-04-02
  • 怎样深度解析Lustre体系结构
    这期内容当中小编将会给大家带来有关怎样深度解析Lustre体系结构,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。  Lustre架构是一种集群存储体系结构,其核心组件就是Lustre文件系统。该文件系统可...
    99+
    2023-06-04
  • Oracle体系结构分析
    这篇文章主要讲解了“Oracle体系结构分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle体系结构分析”吧! 一、什么是Oracle数...
    99+
    2024-04-02
  • oracle体系结构是怎么样的
    本篇内容介绍了“oracle体系结构是怎么样的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!oracle ...
    99+
    2024-04-02
  • oracle中体系结构是怎么样的
    这篇文章主要为大家展示了“oracle中体系结构是怎么样的”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle中体系结构是怎么样的”这篇文章吧。oracl...
    99+
    2024-04-02
  • 怎么理解Oracle体系结构
    本篇内容介绍了“怎么理解Oracle体系结构”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. ...
    99+
    2024-04-02
  • mysql体系结构
    一.MySQL分层架构 1.链接层 处理网络的链接,链接的网络认证。 - 查看链接权限 点击(此处)折叠或打开 ...
    99+
    2024-04-02
  • MySQL体系结构图详解
    体系结构图如下: 连接层 思想 为解决资源的频繁分配﹑释放所造成的问题,为数据库连接建立一个“缓冲池”。 原理 预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使...
    99+
    2024-04-02
  • PG体系结构是怎样的
    本篇内容介绍了“PG体系结构是怎样的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!##pg 结构...
    99+
    2024-04-02
  • MySQL体系结构的实例分析
    这期内容当中小编将会给大家带来有关MySQL体系结构的实例分析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 MySQL是由SQL接口,解析...
    99+
    2024-04-02
  • 如何解析ADO.NET体系结构
    这期内容当中小编将会给大家带来有关如何解析ADO.NET体系结构,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。ADO.NET体系结构有很多值得学习的地方,这里我们主要介绍ADO.NET体系结构,在向大家详...
    99+
    2023-06-17
  • 如何解析vRouter体系结构
    今天就跟大家聊聊有关如何解析vRouter体系结构,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。先来看一张Tungsten Fabric vRouter功能组件的概念视图。vRout...
    99+
    2023-06-03
  • 如何理解Oracle 11g体系结构
    这篇文章给大家介绍如何理解Oracle 11g体系结构,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 Oracle 11g体系结构:oracle运行原理:...
    99+
    2024-04-02
  • MySQL架构体系是怎样的
    本篇内容主要讲解“MySQL架构体系是怎样的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL架构体系是怎样的”吧!一 : 数据库和数据库实例 在MySQL的学习研究中,存在两个...
    99+
    2023-06-05
  • Oracle数据库的体系结构是什么样的
    Oracle数据库的体系结构通常分为三层:物理层、逻辑层和用户层。 物理层:物理层包括数据库的存储结构和文件系统,是数据库中最底层...
    99+
    2024-04-09
    Oracle
  • ORACLE体系结构,很详细
    转子:http://blog.csdn.net/sinat_33363493/article/details/51782609 数据库(Database) 数据库是一个数据的集合,不仅是指物理上的...
    99+
    2024-04-02
  • MySQL整体架构与内存结构
    一  mysql 整体框架: MySQL是由SQL接口,解析器,优化器,缓存,存储引擎等组成的。   1. Connectors指的是不同语言中与SQL的交...
    99+
    2024-04-02
  • MySQL体系结构有哪些
    本篇文章为大家展示了MySQL体系结构有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  MySQL体系结构分别有哪些  1、Connectors指的是不同语言...
    99+
    2024-04-02
  • MongoDB特点与体系结构的示例分析
    小编给大家分享一下MongoDB特点与体系结构的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.1什么是MongoDB...
    99+
    2024-04-02
  • Linux的底层体系结构是怎样的
    本文小编为大家详细介绍“Linux的底层体系结构是怎样的”,内容详细,步骤清晰,细节处理妥当,希望这篇“Linux的底层体系结构是怎样的”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。计算机的工作模式对于一个计算机...
    99+
    2023-06-16
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作