oracle 12.2 local temp的原理和实现

从Oracle数据库12c开始可以将Oracle Clusterware和Oracle RAC配置在大型集群中,称为Oracle Flex集群。 这些集群包含两种类型的节点:Hub节点和Leaf节点。 Hub节点紧密连接,可以直接访问共享存储,并作为一个或多个Leaf 节点的锚点。 leaf 节点与Hub节点松动连接,可能无法直接访问共享存储。

关于Flex Cluster,详情请点击:Oracle Flex Clusters

随着12.2的发布,如果是FLEX集群,可以在LEAF NODE创建read only实例,从而引入了local temp表空间的概念。

local temp和local undo的概念不一样,首先pdb必须使用自己的temp表空间,local temp指的是RAC环境下,可以在各自的节点上创建local temp表空间,拥有各自的temp表空间就跟拥有各自的PGA一样,对于只读节点来说大的排序需要用到temp时就不需要去看这块空间另外一个节点有没有使用,另外避免了两边同时使用temp表空间产生的争用。

首先,PDB不能使用CDB的temp表空间,PDB和CDB上temp视图查出来的结果都不一样: 连接到PDB1,并查看当前的临时表空间

创建新的临时表空间,设置为默认,并删掉原来的临时表空间

测试最初的临时表空间不存在

查看当前的临时表空间

以sysdba连接,再次查询

dba_temp_files的SHARED字段中表明了类型,local有两种类型,RIM是read_only实例,ALL是所有实例

SHARED: for shared temporary tablespace LOCAL_ON_ALL: for local temporary tablespace on all instances LOCAL_ON_RIM: for local temporary tablespace on read-only instances

官方给的创建语句有两处问题,一是未指定tempfile的大小,二是local temp是BIGFILE类型,所以不能指定AUTOEXTEND,也不能添加第二个tempfile。

先来看LOCAL_ON_ALL,创建语句如下,(由于没有RAC环境只能在单实例上测试)

查询数据库当前的大文件表空间,临时文件和临时表空间

从操作系统层面查看

从上面可以看到,理论上会创建各自的tempfile,在指定文件名结尾加上_1和_2,但是不知V$TEMPFILE视图中为什么没有标明详细的文件名。 LOCAL_ON_RIM由于需要read only的实例,创建会报错ORA-32778

[oracle@orasql2 ~]$ oerr ORA 32778 32778, 00000, "DDL operations are disabled on local temporary tablespaces FOR LEAF." // *Cause: A DDL operation on a local temporary tablespace FOR LEAF was // attempted in a system without any read-only running instances. // *Action: Add at least one read-only instance to the cluster.

read writ的实例会优先使用shared的临时表空间,再使用local的临时表空间 ;read only的实例优先使用local的临时表空间,再使用shared的临时表空间 其他操作都类似,具体可以参考官方文档 http://docs.oracle.com/database/122/RACAD/introduction-to-oracle-rac.htm#RACAD-GUID-E84E3BA2-7F36-406B-B630-CD651E0C856F

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2017-05-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐沙弥的世界

RAC 环境下的重要参数

    Oracle 数据库启动时会根据参数文件中提供的相关参数启动Oracle实例。这些参数包括数据库名字、sga,pga的分配,控制文件的位置,undo,p...

441
来自专栏Rgc

mysql数据库优化(二)

https://www.cnblogs.com/sevck/p/6733702.html

892
来自专栏贾老师の博客

一些实用技巧与备忘

1013
来自专栏ChaMd5安全团队

LCTF “他们有什么秘密呢? ”详细解析

LCTF2017真有趣,让我长了不少见识,由于时间匆忙,我也就只做了一个web题,还是折腾了不久,我觉得这题考点还是蛮集中的,故此分享下。 进去后显示: ent...

25610
来自专栏一枝花算不算浪漫

TestNG的简单使用

3467
来自专栏后端之路

mybatis 批量更新

此前的方案在做批量时使用mybatis提供的batch model,该模式下将推迟所有的update(包括insert和delete)语句直到提交事务或者遇到一...

4539
来自专栏有趣的django

Django搭建blog网站(二)

10、页面侧边栏:使用自定义模板标签 我们的博客侧边栏有四项内容:最新文章、归档、分类和标签云。这些内容相对比较固定,且在各个页面都会显示,如果像文章列表或者文...

56210
来自专栏linux驱动个人学习

ELF文件的加载过程(load_elf_binary函数详解)--Linux进程的管理与调度(十三)

一种是固定的、静态的连接,就是把需要用到的库函数的目标代码(二进制)代码从程序库中抽取出来,链接进应用软件的目标映像中;

1055
来自专栏琯琯博客

Yii2 学习笔记之验证规则

3256
来自专栏杨建荣的学习笔记

一条SQL语句的执行计划变化探究(r10笔记第9天)

继续上次分析的一个问题,一个简单的SQL语句执行计划有些奇怪,明明可以走唯一性索引但是却走了另外一个索引。 当然了,最后逐步定位,发现是在直方图...

2593

扫码关注云+社区