实例内存优化

开启自动内存管理

1. 设置memory_max_target

alter system set memory_max_target=1G scope=spfile;
/*init.ora memory_max_target = 2000M memory_target = 1000M*/

2. 关闭sga_target和pga_aggregate_target的设置

alter system set sga_target = 0;
alter system set pga_aggregate_target = 0;

3. 设置memory_target来开启自动内存管理

alter system set memory_target=1000M

数据库开始自动内存管理,通过memory_target/memory_max_target设置的数据,系统会根据工作负载来增加或减少分配给不同组件的内存值(memory_max_target > PGA + SGA)

sga,读取数据块的cache,共享语句,日志等的cache

pga,排序,散列等

如果使用了一个较小的缓冲池,为防止过期,可以使用多个缓冲池,缓冲区告诉缓存之外,包含keep/recycle缓冲区,作用就是将频繁访问的数据集中化独立cache,将大对象访问几次的及时回收

db_keep_cache_size=1000m
db_recycle_cache_size=1000m
alter table tt storage (buffer_pool=keep)

虽然是自动内存管理,但可以设置pga_aggregate_target的值而不必重启db,将会从memory_target减去下面的设置分配个sga

alter system set pga_aggregate_target = 1000M;

查看实例中内存分配的情况

select  * from v$memory_dynamic_components

在运行完一个具有代表性的工作负载之后,运行视图来快速查看数据库中memory_target分配的优化程度

select  * from v$memory_target_advice

还可以查看过去800个已经完成的内存调整操作

select * from v$memory_resize_ops

pga命中率相关查询,尽量通过调整pga最小值可以让排序和散列都在内存完成,减少io提升运算速度

select * from v$pgastat
select * from v$sgastat
select * from v$sysstat
select * from v$sql_workarea_histogra

为oracle分配一部分查询缓存,存储sql查询结果以及plsql函数的结果,跟物化视图相比的话,物化视图是存储在磁盘上,这个结果缓存是保存在sga共享缓冲池,有利于频繁执行的,结果大的sql

RESULT_CACHE_MAXSIZE=500M /* 0-禁用服务器结果缓存 */
RESULT_CACHE_MAX_RESULT=20
RESULT_CACHE_REMOTE_EXPIRATION=3600

检查服务器缓存的状态

select dbms_result_cache.status() from dual;
set serveroutput on;
execute dbms_result_cache.memory_report;
select * from v$result_cache_statstics;

对于单条查询和表使用缓存,force强制查询结果都缓存,manual仅在应用了提示或表设置之后才缓存,表设置在user_tables中有result_cache列

RESULT_CACHE_MODE
/* 动态参数,FORCE: 强制所有sql查询结果都被数据库缓存起来, MANUAL: 数据库仅将使用查询提示或者表注释来启用缓存的特定查询结果进行缓存
* select /*+ RESULT_CACHE*/ ****
* select /*+ NO_RESULT_CACHE*/ ****
*/
alter table stores RESULT_CACHE (MODE FORCE)

缓存结果在客户端,仅推荐只读或几乎只读的查询使用,客户端缓存是基于进程,所以多个客户端会话能共享一个缓存结果集,这些会话可以同时通过多个线程和多个语句来访问同一个结果集

CLIENT_RESULT_CACHE_SIZE /* 启用则设置一个大于32k的值,设为0关闭 */
CLIENT_RESULT_CACHE_LAG /* 缓存落后于真实值的时间 */

Oracle 学习总结 - 内存优化的更多相关文章

  1. Redis学习手册(内存优化)

    自从Redis 2.2之后,很多数据类型都可以通过特殊编码的方式来进行存储空间的优化.其中,Hash.List和由Integer组成的Sets都可以通过该方式来优化存储结构,以便占用更少的空间,在有些 ...

  2. [转]探索 Android 内存优化方法

    前言 这篇文章的内容是我回顾和再学习 Android 内存优化的过程中整理出来的,整理的目的是让我自己对 Android 内存优化相关知识的认识更全面一些,分享的目的是希望大家也能从这些知识中得到一些 ...

  3. oracle内存优化

    一直都想总结一下oracle内存调整方面的知识,最近正好优化一个数据库内存参数,查找一些资料并且google很多下.现在记录下来,做下备份.         一.概述:                ...

  4. Redis学习-内存优化

    以下为个人学习Redis的备忘录--内存优化 1.随时查看info memory,了解内存使用状况:127.0.0.1:6379> info memory# Memoryused_memory: ...

  5. MYSQL进阶学习笔记十三:MySQL 内存优化!(视频序号:进阶_31)

    知识点十四:MySQL 内存的优化(31) 一.优化MySQL SERVER 7组后台进程: masterthread:主要负责将脏缓存页刷新到数据文件,执行purge操作,触发检查点,合并插入缓冲区 ...

  6. Oracle学习线路

    出自huyangg的博客,地址是:oracle学习路线图 1.sql.pl/sql(网上有很多的视频,可以做一个简单的入手,然后看几本书,多做实验)    作为oracle的基本功,需要大家对sql和 ...

  7. Oracle 11g R2性能优化 10046 event

    作为SQL Trace的扩展功能,Oracle 10046 event(10046事件)是一个重要的调试事件,也可以说是系统性能分析时最重要的一个事件,它包含比SQL Trace更多的信息.但可惜的是 ...

  8. Oracle学习笔记—数据字典和常用命令(转载)

    转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...

  9. 【Java EE 学习 28 上】【oracle学习第二天】【子查询】【集合运算】【几种数据库对象】

    一.子查询 1.为什么要使用子查询:问题不能一步求解或者一个查询不能通过一步查询得到. 2.分类:单行子查询和多行子查询. 3.子查询的本质:一个查询中包含了另外一个或者多个查询. 4.使用子查询的规 ...

随机推荐

  1. 可变卷积Deforable ConvNet 迁移训练自己的数据集 MXNet框架 GPU版

    [引言] 最近在用可变卷积的rfcn 模型迁移训练自己的数据集, MSRA官方使用的MXNet框架 环境搭建及配置:http://www.cnblogs.com/andre-ma/p/8867031. ...

  2. 通过mysqlclient操作MySQL数据库

    一,安装mysql 如果是windows 用户,mysql 的安装非常简单,直接下载安装文件,双击安装文件一步一步进行操作即可. Linux 下的安装可能会更加简单,除了下载安装包进行安装外,一般的l ...

  3. C# Microsoft.Office不存在空间名称Interop和Excel

    在实际开发过程中,我们经常会对Excel表进行操作.相信大家都都已经很熟悉C#操作Excel的步骤:添加引用->COM->Microsoft Office Excel 11 Object. ...

  4. 把Excel选手名单信息导入到评委计分软件Access数据库的步骤

    第一步:用Excel制作选手名单 根据比赛要求,制作选手Excel名单信息,前4列要符合要求 A列:比赛顺序,整数数值类型.所以A列数值选中后,右击设置单元格格式 数字/数值/小数位数为0(见下图). ...

  5. concurrent.futures进线程池和协程

    concurrent.futures 异步执行进程线程池的模块,一个抽象类,定义submit,map,shutdown方法 from concurrent.futures import Process ...

  6. Phpstorm的强大功能

    你是否也是重复,重复,一直重复的打着重复的代码? 你是否也一直重复重复 的 Ctrl+c .Ctrl+v? 当你看到此项操作的时候就会发现,原来复制粘贴还能这么玩儿... 演示效果(以phpExcel ...

  7. 踩过的坑:InteliIJ IDEA 打开的项目突然左侧目录结构消失了,如何处理?

    试了很多的办法,删除项目,然后重新从git下载,再导入项目,但是对于暂存未上传到git的文件也会被一并删除,这样就亏大发了 之前一直没有找到解决办法,这里记一下终身有效的办法,并且比较好操作 按下列步 ...

  8. JVM总结-虚拟机加载类

    从 class 文件到内存中的类,按先后顺序需要经过加载.链接以及初始化三大步骤.其中,链接过程中同样需要验证:而内存中的类没有经过初始化,同样不能使用.那么,是否所有的 Java 类都需要经过这几步 ...

  9. java中六个时间类的使用和区别

    java.util.Date java.sql.Date   java.sql.Time   java.sql.Timestamp java.text.SimpleDateFormat java.ut ...

  10. [Lua]string与中文

    参考链接: https://baike.baidu.com/item/%E5%AD%97%E7%AC%A6%E7%BC%96%E7%A0%81/8446880?fr=aladdin#7 http:// ...