博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle 18c新特性详解:In-Memory 专题
阅读量:6547 次
发布时间:2019-06-24

本文共 2010 字,大约阅读时间需要 6 分钟。

前面我们分享了Oracle 18c 在多租户中的新特性,内容回顾:

今天我们来看一下在In Memory中有哪些振奋人心的新改变。

新特性1:IN-MEMORY对外部表支持

通过外部表可以透明地访问数据库外部的数据。外部表使得Oracle对外部数据操作更加灵活,并且基于内存列式存储压缩,能够更快的支持大数据量的运算,对于数据仓库环境将会是极大的增强。并且由于外部表的数据基本处于静态,更适合使用In-Memory来处理,Oracle声称这一改进将会带来100倍的提升。

新特性2:In-Memory 自动内存管理

自动内存管理,主要指的是指自动选择适合In-Memory的对象并压缩提速等。内存表和分区借助热图数据(HeatMap Data)列统计数据(column statistic)和其他相关统计数据来自动的管理IM列存储数据,无需人为干预,系统可以自动挑选热数据加载,并对内存中的冷数据会自动剔除。 由于无需用户干预,有益于Oracle管理的云服务,该特性会带来2x的性能提升。

新特性3:In-Memory动态扫描

内存中动态扫描提供了同时扫描多个IMCU的功能。 以前,这仅限于并行执行,并且每个并行服务器进程一次只能扫描一个IMCU(即每个颗粒一个IMCU)。 使用IN-MEMORY动态扫描每个扫描过程,无论是串行还是并行执行都可以使用IN-MEMORY中线程扫描多个IMCU。 实质上,这是一种非常有效的并行化IMCU扫描的方法,可以由串行执行查询和并行执行查询使用。

通过IN-MEMORY动态扫描,并行化操作使用轻量级线程下推到SCAN层,补充静态PQ计划,缩短查询的响应时间更快,实现单线程查询的PQ执行时间,使用资源管理器进行弹性DOP重新平衡

动态扫描具有以下优点:

•使用轻量级线程,快速并行化扫描

•资源管理器控制活动的线程数量

•充分利用CPU资源,最大限度提高列式扫描性能

•最高达到2X性能

新特性4:对XMEM的 支持,并非易失性内存(NVRAM)极大扩展内存容量

XMEM即为eXtended Memory。18c中内存算法扩展使用较慢但更高容量的 NVRAM,在使用中将性能关键的表放入DRAM,容量关键的表放入NVRAM。 XMEM可以有大于3x 列式存储

新特性5:Memoptimized Rowstore

该特性是访问OLTP工作负载的内存优化。在系统全局区域(SGA)中使用称为memoptimize池的内存区域,该池在启用快速查找时存储表的哈希索引。MEMOPTIMIZE_POOL_SIZE初始化参数控制memoptimize池的大小。

通过Memoptimized Rowstore 能够实现

1、超快速的基于主键的查找:

可以使用使用新的无锁内存散列索引,只需要为读数据声明表MEMOPTIMIZE属性,比如通过在CREATE TABLE或ALTER TABLE语句中包含MEMOPTIMIZE FOR READ子句,可以启用快速查找表。

2、新的低延迟客户端协议,可直接访问数据引擎Exadirect+RDMA

3、在性能上带来的提升:对于基于主键的检索,吞吐量增加了4倍;响应时间降低了50%。

新特性6:In-Memory 算法的优化

Oracle数据库NUMBER数据类型具有高保真度和高精度。但是由于算术运算无法在硬件中本地执行,因此NUMBER会为查询带来显着的性能开销。

在18c中对IN-MEMORY的算法做了一下优化:内存优化的NUMBER格式可以使用SIMD硬件进行快速计算,列存储将NUMBER数值列以原生二进制表示,通过使用SIMD矢量处理,简单聚合和Group by聚合可以显着受益。在某些情况下,性能可提高高达9倍。

新特性7:Dynamic Capture Window

Capture window用于在填充列存储中的表达式时,对内存中的表达进行评估,在以前的版本中,用户只能选择24小时内数据库中执行过的表达式,或自数据库创建以来的捕获间隔两种选择。 从18c开始,捕获窗口更灵活性,能够动态捕获,用户可以根据其工作负载周期进行调整。

新特性8:IN-MEMORY性能的提升

在Oracle 18c中,IN-MEMORY在性能上得到了大幅度的提升,主要提升的方面包括:

•增强的混合工作负载性能

–高达2X 性能提升

•聚合计算的性能提升

–聚合计算下放到Exadata

•增强的JSON 处理

•更快的表达式评估

•快速启动(Fast-Start)性能提升

•增强Join处理能力

•改进了Query

High 级别的压缩

•TPCH性能 ,快2X

更多新特性请查看Oracle 18c官方文档。

关于多租户新特性:

转载于:https://juejin.im/post/5be54a6fe51d4538c865c4fc

你可能感兴趣的文章
JSON字符串转成对象
查看>>
SaltStack 中ZMQ升级
查看>>
grep,egrep使用以及正则表达式的使用
查看>>
implode 和 explode
查看>>
exchange 2013 提示“HTTP 500内部服务器错误”
查看>>
Linux运维学习笔记之一:运维的原则和学习方法
查看>>
怎样使用原型设计中的组件样式功能
查看>>
python threading
查看>>
谷安天下2013年6月CISA考前辅导 第一季
查看>>
ARM程序规范
查看>>
我的友情链接
查看>>
Qt下的OpenGL 编程(8)文字、FPS、动画
查看>>
Android开发入门系列
查看>>
文件删除封装,懒得以后再写了
查看>>
Linux 脚本之用户创建
查看>>
Mysql字段类型设计相关问题!
查看>>
Xshell 密钥登陆
查看>>
所见不为真--图片格式文件检测python
查看>>
分享几种常用的嵌入式Linux GUI及其特点—干货
查看>>
Confluence 6 "Duplicate Key" 相关问题解决
查看>>