Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >达梦数据库_达梦的数据库什么水平

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

作者头像
全栈程序员站长
发布于 2022-11-03 02:19:37
发布于 2022-11-03 02:19:37
1K0
举报

达梦(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 process视图查看当前数据库的进程信息。通过vthreads视图查看当前数据库启动的线程及其每个线程的功能描述。

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.cn/180132.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月19日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【赵渝强老师】达梦数据库的内存结构
数据库管理系统是一种对内存申请和释放操作频率很高的软件,如果每次对内存的使用都使用操作系统函数来申请和释放,效率会比较低,加入自己的内存管理是DBMS系统所必须的。通常内存管理系统会带来以下好处:
赵渝强老师
2025/03/25
960
【赵渝强老师】达梦数据库的内存结构
【赵渝强老师】达梦数据库的线程结构
达梦数据库服务器使用“对称服务器构架”的单进程、多线程结构。这种对称服务器构架在有效地利用了系统资源的同时又提供了较高的可伸缩性能,这里所指的线程即为操作系统的线程。服务器在运行时由各种内存数据结构和一系列的线程组成,线程分为多种类型,不同类型的线程完成不同的任务。线程通过一定的同步机制对数据结构进行并发访问和处理,以完成客户提交的各种任务。执行下面的语句将查看当前达梦数据库中的线程信息。
赵渝强老师
2025/03/25
970
【赵渝强老师】达梦数据库的线程结构
达梦数据库8安装
在/etc/sysctl.conf文件最后加上如下内容(数据仅供参考,解释内容来源于网络)
青丝束马尾
2024/11/02
1690
达梦数据库8安装
【赵渝强老师】达梦数据库的物理存储结构
达梦数据库由硬盘上的文件组成,而要读写数据需要通过达梦实例来完成。那么,达梦数据库是如何存储数据的呢?要搞清楚这个问题,就需要理解什么是达梦数据库的存储结构。达梦数据库的存储结构是由逻辑存储结构和物理存储结构组成。一般来说数据库无论是关系型数据库,还是NoSQL数据库在存储结构上,都是通过逻辑存储结构来管理物理存储结构。
赵渝强老师
2025/03/24
890
【赵渝强老师】达梦数据库的物理存储结构
达梦数据库性能优化
正文先获取硬件信息获取达梦基本信息vlicens 优先排查 MAX_CPU_NUM查看达梦内存分配状态dual 方式一vsysstat 方式二:正在执行的SQL统计不同账号连接的数量慢SQL排查查看缓冲池命中率内存分配查看死锁杀死 Session查询历史死锁查看当前活跃的会话消耗的内存统计信息(提升很有效)统计信息概述收集统计信息手动收集自动收集查看统计信息更新统计信息删除统计信息
收心
2025/04/08
1980
猿创征文|国产数据库---达梦应用技巧及使用案例
第一步:DM8数据库的.iso镜像文件上传到redhat 7操作系统的 /opt/dm8.iso目录下
芯动大师
2022/11/15
5890
达梦数据库主备部署
在 dm.ini 同级目录下新建文件 dmmonitor_manual.ini,该文件为非确认监视器的配置文件,主要用于平常运维中监控集群状态、手动切换主从节点等
陳斯托洛夫斯記
2024/08/07
2900
达梦数据库主备部署
【Docker】搭建达梦数据库(基于 X86 架构)
近期,团队研发同学向笔者提出搭建达梦数据库以进行适配的需求,笔者完成调研后着手搭建了一套测试环境,本文详细介绍达梦数据库的搭建步骤。
行者Sun
2024/09/02
4250
【Docker】搭建达梦数据库(基于 X86 架构)
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)
对于常年占据国产数据库排行榜前三的 达梦 数据库,早已 “垂涎a已久” (¯﹃¯)!
Lucifer三思而后行
2021/09/10
6.3K0
达梦 DM8 数据库安装详细手册(Windows+Linux+Docker)
达梦数据库的物理备份和还原简解
在bin下执行dmrman命令,进入dmrman交互界面,输入==backup database '$DM_HOME/data/实例名/dm.ini' (full);== 进行备份,默认就是全备份。
Echo_Wish
2023/11/30
4890
达梦数据库的物理备份和还原简解
达梦数据库阻塞死锁及解锁
达梦数据库管理系统是由达梦公司推出的具有完全自主知识产权的高性能数据库管理系统,简称DM,其最新版本为8.0版本(DM8)。达梦数据库在性能方面表现极为出色,这主要体现在多个关键方面。
六月的雨在Tencent
2025/01/03
3940
达梦数据库V8 命令行静默安装
达梦数据库是一款完全自主研发的国产数据库,具有高安全性、高可靠性、高可用性等特点,可与国产操作系统 kylin 配合使用。
以谁为师
2023/12/21
5580
达梦数据库V8 命令行静默安装
达梦数据库启用日志方法,达梦数据库查看日志是否启用,达梦数据库日志文件位置查找
注: 日志启用时会非常占用硬盘的读写资源,使正常读写数据库的效率大大降低,因为日志文件很大,之前我们有个服务器一直起着日志,一个月就达到 500G 的大小了,平时的一个操作都几十兆的涨。 查看日志
小蓝枣
2020/09/24
5.4K0
达梦数据库启用日志方法,达梦数据库查看日志是否启用,达梦数据库日志文件位置查找
Linux部署达梦数据库
本文共 799 个字数,平均阅读时长 ≈ 2分钟 客户现场部署,所以没有来得及截图,后续有环境后再补充截图 一、创建安装目录 找一个风水宝地,dm用来安装数据库,dmdata用来挂载镜像 mkdir dm mkdir dmdata 然后将达梦ISO上传到dmdata 二、挂载ISO 进入dmdata文件夹下 mount dm8_20230104_HWarm_centos7_64.iso ../dmdata/ 三、安装 进入dmdata,可以看到挂载出来两个文件,执行安装 ./DMInstall.bi
小东东
2023/03/20
1.4K0
CentOS7 部署达梦 DM8
陳斯托洛夫斯記
2024/08/07
1610
国产数据库达梦Dm8部署
用户应根据 DM 及应用系统的需求来选择合适的硬件配置,如 CPU 的指标、内存及磁盘容量等。档次一般应尽可能高一些,尤其是作为数据库服务器的机器,基于 Java 的程序运行时最好有较大的内存。其它设备如 UPS 等在重要应用中也应考虑。下面给出安装 DM 所需的硬件基本配置:
俊才
2023/11/01
8050
国产数据库达梦Dm8部署
Oracle实例和Oracle数据库(Oracle体系结构)
--==========================================
Leshami
2018/08/07
2.8K0
YashanDB进程线程体系
YashanDB采用多线程架构,充分利用多核处理器的计算能力,提高系统的并发性和响应性。在多线程架构中,由一个主线程负责程序的初始化和协调工作,然后创建多个子线程来执行具体的任务。每个线程可以独立地执行特定的代码块,但它们共享进程的资源和内存空间。
用户11512874
2025/02/19
610
DM8数据守护集群安装部署_手动切换
数据守护集群安装部署前需要额外注意网络环境和磁盘 IO 配置情况,其他环境配置项建议请参考安装前准备工作。
用户10843414
2023/11/15
5340
DM8数据守护集群安装部署_手动切换
POSTGRESQL MYSQL MONGODB 配置文件总结(感谢我的三个DBA)
最近在整理POSTGRESQL MYSQL MONGODB REDIS 的标准化模板配置参数,当然这里面还包含 LINUX 的一些基本配置. 相关的整理的工作是我的三个 DBA 操作的, 针对目前的参数进行了相关的整理和重新设定. 昨天有人问我要,这边进贴出来,如果大家有什么问题 ,告诉我们, 大家一起进步.
AustinDatabases
2021/02/26
7910
相关推荐
【赵渝强老师】达梦数据库的内存结构
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档