达梦数据库_达梦的数据库什么水平

达梦数据库_达梦的数据库什么水平达梦(DM8)数据库由实例和数据库共同组成。实例由一组正在运行的后台进程及其所fork出的一系列线程和分配内存组成。数据库是由一系列存放在操作系统上的文件组成。体系结构图大致为:本文只要针对体系结构中的实例,也就是达梦(DM8)数据库中内存结构与线程结构进行介绍。1.内存池达梦(DM8)实例内存池包括运行时内存和共享内存池组成,可以通过查询动态视图V$MEM_POOL查看当前数据库系统中所有内存池的状态:1.1共享内存池数据库运行时的主要内存池,由数据库参数文件dm.ini中的参数MEMO

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

达梦(DM8)数据库由实例和数据库共同组成。
实例由一组正在运行的后台进程及其所fork出的一系列线程和分配内存组成。数据库是由一系列存放在操作系统上的文件组成。
体系结构图大致为:
在这里插入图片描述

本文只要针对体系结构中的实例,也就是达梦(DM8)数据库中内存结构与线程结构进行介绍。

1.内存池

达梦(DM8)实例内存池包括运行时内存和共享内存池组成,可以通过查询动态视图V$MEM_POOL查看当前数据库系统中所有内存池的状态:
1.1 共享内存池
数据库运行时的主要内存池,由数据库参数文件dm.ini中的参数MEMORY_POOL决定共享内存池大小(根据服务器系统会有所变化),可根据生产环境需要进行修改,修改后必须重启数据库生效。
在这里插入图片描述

1.1.1 SQL缓冲区,属于共享内存池一部分,是数据库执行SQL语句需要分配的内存,主要用于生成解析SQL语句、缓存重用执行计划以及结果集缓存等。参数CACHE_POOL_SIZE决定缓冲区代销,默认为20M,修改后需重启数据库。

在这里插入图片描述

1.1.2 字典缓冲区,属于共享内存池一部分,有缓存数据字典信息,如模式信息、表信息、列信息、触发器信息等,才去LRU算法加载数据字典,可以加快SQL语句的解析。由参数DICT_BUF_SIZE决定缓冲区大小,默认为5M。修改后需重启数据库。

在这里插入图片描述

1.1.3 数据缓冲区,用于缓存从磁盘读取的数据页。是共享内存池中最重要的内存区域之一。由四种类型的数据缓冲区组成,分别是NORMAL、KEEP、FAST、RECYCLE。
NORMAL缓冲区主要处理没有特殊指定缓冲区的数据页,由参数BUFFER决定大小,默认100M;KEEP缓冲区缓冲需要长期缓存的在内存数据页,由参数KEEP参数决定大小,默认8M;RECYCLE缓冲区主要用户临时表空间数据缓存,由参数RECYCLE决定大小,默认64M;FAST缓冲区根据用户指定的参数FAST_POOL_PAGES大小由系统自动进行管理,默认值为3000,单位是数据页数量(实际参数值根据服务器系统会有所变化)。

在这里插入图片描述

1.1.4 日志缓冲区,用于存放重做日志的内存缓冲区,记录数据库中的改动向量。由参数RLOG_BUF_SIZE决定大小。默认值为1024,单位数据页数量。

在这里插入图片描述

1.1.5 排序区,对数据操作排序时所占用的内存空间,由参数SORT_BUF_SIZE决定大小,默认39M。每次排序操作先申请排序区内存,排序结束后释放内存。

在这里插入图片描述

1.1.6 哈希区,达梦(DM8)为哈希连接设定的虚拟内存缓冲区,但并不是专门创建的特定属于用于哈希连接的内存,只有使用哈希连接时排序的数据量大小达到了哈希缓冲区带下才会使用。
1.1.7 SSD缓冲区,是达梦(DM8)针对内存、机械磁盘、SSD磁盘之间数据分配的缓冲层。

1.2 运行时内存
DM8数据库中一些功能模块运行时属于自己特有的内存池,例如会话内存池一般是在会话连接时分配属于当前会话的内存。

2.线程

达梦(DM8)数据库只有一个进程,但会fork出多个线程来完成数据库中的各项操作,主要线程有:监听线程、IO线程、工作线程、调度线程、日志想成等。通过v p r o c e s s 视 图 查 看 当 前 数 据 库 的 进 程 信 息 。 通 过 v process视图查看当前数据库的进程信息。通过v processvthreads视图查看当前数据库启动的线程及其每个线程的功能描述。

在这里插入图片描述

2.1 监听线程,在服务器上数据库端口循环监听是否有客户端连接请求,每次会生成会话申请交给工作线程进行处理。
2.2 工作线程,DM8数据库核心线程,处理监听线程生成的会话申请以及处理其他数据先关操作类型的任务。每个会话有专门的工作线程处理请求,所以工作线程随着会话连接增加而增加。但当会话连接超出阈值时就不再增加,转而轮询请求加入队列,等待工作线程空闲后再处理。
2.3 IO线程,负责将内存中的脏数据写到磁盘文件中,将数据持久化处理。通常情况有三种情况会触发IO线程:
(1)sql查询的数据页不在缓冲区,需要从磁盘中读取数据页。
(2)缓冲区中数据页满或者数据库关闭会触发IO线程将脏数据页写入磁盘。
(3)生成检查点。
IO线程个数可以通过参数文件dm.ini中的IO_THR_GROUPS进行设置,默认值为2.

2.4 调度线程,数据库中管理所有定时任务或定时电镀任务。每秒轮询一次。

2.5 日志FLUSH线程,负责将内存池中日志缓冲区中的产生的redo log写入磁盘中的联机日志文件中。日志FLUSH线程要先于IO线程,也就是日志写入磁盘在脏数据页写入磁盘之前进行。

2.6 日志归档线程,主要负责将联机日志进行归档操作。

2.7 日志APPLY线程,主要是在数据守护系统中生成的线程,用于备库接收主库的物理redo日志后在备库上将日志重做,并生成自己的日志,保持备库和主库数据的同步一致。

2.8 定时器线程,处理数据库中配置的定时操作,例如备份等,默认是不启动的,触发定时器线程的场景有:
(1)逻辑日志异步归档。
(2)主库发送异步归档日志给备库。
(3)定时作业。

2.9 逻辑日志归档线程、MAL线程及其他线程,

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180132.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 安卓漏洞扫描工具_软件漏洞扫描工具

    安卓漏洞扫描工具_软件漏洞扫描工具?Acunetix漏洞扫描工具概括:???Acunetix是一个自动化的Web应用程序安全测试工具,是通过检查SQL注入,跨站点脚本(XSS)和其他可利用漏洞等来审核您的Web应用程序。一般来说,Acunetix能够扫描任何通过网络浏览器访问并使用HTTP/HTTPS协议的网站或web应用程序。???Acunetix提供了强大的的解决方案,然后可以用于分析现成的和自定义的Web应用程序,包括使用JavaScript,AJAX和Web2.0的Web

    2025年11月26日
    4
  • InnoDB中的索引类型

    InnoDB中的索引类型InnoDB数据引擎使用B+树构造索引结构,其中的索引类型依据参与检索的字段不同可以分为主索引和非主索引;依据B+树叶子节点上真实数据的组织情况又可以分为聚族索引和非聚族索引。每一个索引B+树结构都会有一个独立的存储区域来存放,并且在需要进行检索时将这个结构加载到内存区域。真实情况是InnoDB引擎会加载索引B+树结构到内存的BufferPool区域。聚簇索引(聚集索引)聚簇索引指的是这样的数据组织结构:索引B+树的每个叶子节点直接对应了真实的DataPage。并且B+树所有的叶子节点在最底层共同描

    2022年6月1日
    37
  • pycharm安装程序包_Python不可以安装的软件包

    pycharm安装程序包_Python不可以安装的软件包(1)命令行安装pipinstallXXX或者condainstallXXXXXX为包的名称,命令输入的位置如下图所示(两个均可使用,如果一个安装失败则使用另一个)(2)操作界面安装(i)依次点击file——settings,出现如下界面(2)点击图中+,出现如下界面,在搜索框中输入相应的包的名称,选中后点击installPackage(3)直接根据提示安装打开一个python源程序,在下面画有红色波浪线的均为未安装的包,将光标移动至红色波浪线处,会出现installp

    2022年8月29日
    8
  • oracle命令创建新用户

    oracle命令创建新用户一、sqlplus连接oracle1、sqlplus登录Windows需要sqlplus命令框,获取CMD窗口下输入sqlplus(需要先安装成功oracle)2、输入用户名和口令(密码)3、以sysdba身份连接oracleconnsys/密码assysdba4、查看当前查看当前实例名selectinstance_namefr…

    2022年5月19日
    59
  • 虚拟机安装ubuntu12.04LTS及相关设置和常见问题的解决

    虚拟机安装ubuntu12.04LTS及相关设置和常见问题的解决前几天达内的来我们学校给我们培训,学习的是C++,使用的是用虚拟机安装的ubuntu,我不喜欢用他们的,于是自己在自己的电脑上安装,我安装过14版本的ubuntu,不过很卡,后来安装12.04LTS,

    2022年7月2日
    20
  • 谓词表示法表示猴子摘香蕉_猴子妈妈有14个香蕉

    谓词表示法表示猴子摘香蕉_猴子妈妈有14个香蕉案例:我们要实现以下步骤:这个案例共有以下几种情况,猴子香蕉箱子在同一处,猴子香蕉在同一处,香蕉箱子在同一出,还有三者均不在同一处,但不论是哪种情况,我们需要清楚一点就算是香蕉和猴子在同一位置,猴子也无法直接获得香蕉,因此我们第一步必须需要先找到箱子,然后再去搬着箱子移动到香蕉处。本案例中有以下四个谓词逻辑: Run(monkey,box)代表猴子去搬箱子 Getbox(monkey,box)代表猴子得到了箱子 Run(monkey,banana)代表了.

    2022年9月26日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号