Oracle12c中性能优化增强新特性之数据库智能闪存
智能闪存功能最初在XD中引入。从Oracle11.2.0.2开始,除了用于XD存储,还可用于任何闪盘。Oracle12c中,不需卷管理器就可以使用闪盘。
1. 简介
智能闪存在solaris和linux上都可用,允许用户把闪盘当做第二层缓冲使用来改善性能。通常,当缓存中的数据因超时而被刷出后,下次使用时需被再次从磁盘读取到内存。通过智能闪存,超时的数据可以被放在智能缓存中,当这些数据被再次使用时,比从磁盘上读取能更快些。
为了能优化性能,官方文档建议智能闪存应该为缓存的2~10倍。这里,我们有1G缓冲,因此,应该配置2G以上大小的闪存。如下,我通过两块磁盘来模拟闪存。
# dd if=/dev/zeroof=/mnt/smt_flschc1 bs=1024 count=1024000
# dd if=/dev/zeroof=/mnt/smt_flschc2 bs=1024 count=1024000
# chownoracle:oinstall /mnt/smt_flschc1 /mnt/smt_flschc2
智能闪存内容的元数据在缓存中,如果你不考虑这点,实际缓存的大小在用智能缓存时会被减小。为了计算减小的缓存大小,可以通过智能缓存中每个块占用100字节来计算。RAC中,你还需要考虑共享池的大小,每个GCS资源需要多占208个字节。
2. 启用智能缓存
DB_FLASH_CACHE_FILE参数用来鉴定用于智能闪存的闪盘。
DB_FLASH_CACHE_FILE = /mnt/smt_flschc1,/mnt/smt_flschc2
盘大小通过DB_FLASH_CACHE_SIZE参数确定。
DB_FLASH_CACHE_SIZE = 1G, 1G
这些参数可以通过ALTERSYSTEM命令来设置,也可以通过编辑pfile来进行设置,编辑pfile的方式如下。
SQL> CREATE PFILE='/tmp/pfile.txt' FROMSPFILE;
SQL>host edit;
*.db_flash_cache_file=/mnt/smt_flschc1,/mnt/smt_flschc2
*.db_flash_cache_size=1073741824,1073741824
SQL> CREATE SPFILE FROMPFILE='/tmp/pfile.txt';
重启数据库。
SHUTDOWN IMMEDIATE;
STARTUP;
重启后,可以看到配置的参数。
SQL> SHOW PARAMETER db_flash_cache
NAME TYPE VALUE
----------------------------------------------- ------------------------------
db_flash_cache_file string /mnt/smt_flschc1, /mnt/smt_flschc2
db_flash_cache_size big integer 1G, 1G
SQL>
智能闪存使用信息可以查询视图V$FLASHFILESTAT。
SET LINESIZE 100
COLUMN name FORMAT A20
SELECT * FROM v$flashfilestat;
FLASHFILE# NAME BYTES ENABLED SINGLEBLKRDSSINGLEBLKRDTIM_MICRO CON_ID
---------- -------------------- -------------------- ------------ -------------------- ----------
1 /mnt/smt_flschc1 1073741824 1 0 0 0
2 /mnt/smt_flschc2 1073741824 1 0 0 0
SQL>
3. 禁用智能闪存
重置初始化参数以禁用智能闪存。
ALTER SYSTEM RESET DB_FLASH_CACHE_FILESCOPE=SPFILE;
ALTER SYSTEM RESET DB_FLASH_CACHE_SIZESCOPE=SPFILE;
SHUTDOWN IMMEDIATE;
STARTUP;
SELECT * FROM v$flashfilestat;
no rows selected
SQL>
4. 修改表的智能闪存设置
缓存中过期数据块将被默认刷到智能闪存中。ALTER TABLE命令的FLASH_CACHE子句可以进行另外设置。
-- 禁止TEST表使用智能闪存
ALTER TABLE TEST.TEST STORAGE (FLASH_CACHENONE);
-- 强制TEST表保留在智能闪存中
ALTER TABLE TEST.TEST STORAGE (FLASH_CACHEKEEP);
-- 重置TEST表的默认行为
ALTER TABLE TEST.TEST STORAGE(FLASH_CACHE);
ALTER TABLE TEST.TEST STORAGE (FLASH_CACHEDEFAULT);
5. 性能
智能闪盘对性能的提升时,我们应该注意。很多人说,把数据文件放在闪盘上比用智能闪存性能更好。不过,测试结果和使用的硬件及应用需求有很大关系,不可一概而论。
Oracle12c中性能优化增强新特性之数据库智能闪存的更多相关文章
- Oracle12c 中RAC功能增强新特性之ASM&Grid
1. 自动存储管理(ASM)方面的增强 1.1. Flex ASM 在典型的网格架构安装中,每个节点有自己的ASM实例运行并扮演该节点上数据库的存储容器的角色,对这种安装配置,存在单点失败的 ...
- Oracle12c中性能优化&功能增强新特性之临时undo
临时表最有意思的特点之一是undo段也存储在常规undo表空间中,而它们的undo反过来被redo保护,这会导致一些问题. 1) 写undo表空间需要数据库以读写模式打开,因此,只读数据库和物理备库 ...
- java并发学习--第八章 JDK 8 中线程优化的新特性
一.新增原子类LongAdder LongAdder是JDK8中AtomicLong的增强工具类,它与AtomicLong最大的不同就是:在多线程场景下,LongAdder中对单一的变量进行拆分成多个 ...
- Oracle12c中性能优化&功能增强新特性之全局索引DROP和TRUNCATE 分区的异步维护
Oracle 12c中,通过延迟相关索引的维护可以优化某些DROP和TRUNCATE分区命令的性能,同时,保持全局索引为有效. 1. 设置 下面的例子演示带全局索引的表创建和加载数据的过程. -- ...
- Oracle12c中性能优化&功能增强新特性之重大突破——内存列存储新特性
内存列存储(IM column store) 是Oracle12.1.0.2版本的主要特点.该特点允许列,表,分区和物化视图在内存中以列格式存储,而不是通常的行格式.数据存在内存中的好处显而易见,而列 ...
- Oracle12c中性能优化新特性之新增APPROX_COUNT_DISTINCT 快速唯一值计数函数
Oracle11g中,为了改善DBMS_STATS包收集统计信息时的唯一值计数功能,增加了 APPROX_COUNT_DISTINCT函数,但文档中未记载.Oracle12c文档中包括了该函数,因此, ...
- Oracle12c中PL/SQL(DBMS_SQL)新特性之隐式语句结果(DBMS_SQL.RETURN_RESULT and DBMS_SQL.GET_NEXT_RESULT)
隐式数据结果特性将能简化从其他数据库到Oracle12c存储过程迁移.1. 背景T-SQL中允许查询结果的隐式返回.例如:下面T-SQL存储过程隐式返回查询结果.CREATE PROCEDURE Ge ...
- 【译】.NET 5. 0 中 Windows Form 的新特性
自从 Windows Form 在 2018 年底开源并移植到 .NET Core 以来,团队和我们的外部贡献者都在忙于修复旧的漏洞和添加新功能.在这篇文章中,我们将讨论 .NET 5.0 中 Win ...
- ABAP 7.52 中的Open SQL新特性
S/4 HANA 1709 已经在几个月前发布,随之而来的是ABAP 7.52. 本文翻译了更新文档中有关Open SQL的部分 本文链接:http://www.cnblogs.com/hhelibe ...
随机推荐
- Python面试题之装饰器漫谈
讲 Python 装饰器前,我想先举个例子,虽有点污,但跟装饰器这个话题很贴切. 每个人都有的内裤主要功能是用来遮羞,但是到了冬天它没法为我们防风御寒,咋办?我们想到的一个办法就是把内裤改造一下,让它 ...
- 20145106java实验四
实验名称:Java网络编程 实验内容: 1.掌握Socket程序的编写: 2.掌握密码技术的使用: 3.设计安全传输系统. 结对小伙伴 20145109竺文君 博客地址: 在本次实验中,是以我作为服务 ...
- 20145208 蔡野《网络对抗》shellcode注入&Return-to-libc攻击深入
20145208 蔡野<网络对抗>shellcode注入&Return-to-libc攻击深入 Shellcode注入 shellcode的获取代码 我使用了许心远同学博客中的代码 ...
- 強化 Python 在 Vim 裡的顏色
我習慣用 putty 連 Unix server 開 screen,再用 vim 寫 Python.這篇記錄如何改善 Python 的顏色. 啟動 256 色 terminal 首先將可用的色彩數增加 ...
- Python Sip [RuntimeError: the sip module implements API v11.0 to v11.2 but the PyQt5.QtCore module requires API v11.3]
不知道原因,尝试卸载.编译安装均失败.只有这样曲线救国 import matplotlib matplotlib.use("WXAgg",warn=True) import mat ...
- Cocos2d-x学习笔记(六)Label字体控制
BMFont使用链接--->> http://blog.csdn.net/qiurisuixiang/article/details/8984288 这里要注意.fnt文件可通过BMFo ...
- Struts2文件上传的大小限制问题
问题:上传大文件报错…… 解决:修改struts.xml文件中的参数如下 <constant name="struts.multipart.maxSize" value= ...
- 2018年全国多校算法寒假训练营练习比赛(第一场)C 六子冲
https://www.nowcoder.com/acm/contest/67/C 思路: 模拟. 代码: #include<bits/stdc++.h> using namespace ...
- js的单双引号
单引号开始: 有时候上边的不行 双引号开始. 一般最外边是单引号 属性是双引号. 如果属性中还是需要一个属性的话,那么我们用\“,里边用‘+data.id+'来区分. 今天又一次遇到一次单双引号,花了 ...
- 距离为K的节点 All Nodes Distance K in Binary Tree
2018-07-26 17:38:37 问题描述: 问题求解: 解法一. 第一种解法是使用Graph + BFS.换言之,就是将二叉树转化为无向图,然后在无向图中使用BFS进行层次遍历即可. 这种解法 ...