实例内存优化

开启自动内存管理

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. Jmeter(十三)Debug Sampler

    上篇记录了关联的一些内容.当然,关联是有“风险”的,经常写的正则表达式,jsonpath,xpath自己认为是没问题的,可是就是跑起来有问题,百思不得其解,究竟是数据问题还是表达式的问题,本篇就来记录 ...

  2. int main(int argc,char* argv[])浅析

    int main(int argc,char* argv[])浅析 argc : 指输入参数个数,默认值1,就是执行程序名称 argv[] : 输入参数数组指针 举个栗子: 1. 编写一个argc.c ...

  3. adb显示 部分乱码修改方法

    用windows自带的命令行[cmd]软件链接adb 设备后,部分显示乱码,如下图片所示: 图1 修改方法如下: alias ls='busybox ls --color=never' 修改后显示正常 ...

  4. [SQL]SQL Server 事务及回滚事务

    第一种: Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/ ...

  5. 第11章 拾遗3:虚拟局域网(VLAN)

    1. 虚拟局域网(VLAN) (1)VLAN是建立在物理网络基础上的一种逻辑子网,它将把一个LAN划分成多个逻辑的局域网(VLAN),每个VLAN是一个广播域,VLAN内的主机间通信就和在一个LAN内 ...

  6. 第5章 IP地址和子网划分(3)_子网划分

    6.子网划分 6.1 地址浪费 (1)IPv4公网地址资源日益紧张,为减少浪费,使IP地址能够充分利用,就要用到子网划分技术. (2)传统上一个C类地址,如212.2.3.0/24,其可用的地址范围为 ...

  7. Select模式和超时

    fd_set rset; FD_ZERO(&rset); int nready; int maxfd; int fd_stdin = fileno(stdin); if(fd_stdin &g ...

  8. Linux下Mysql自启动

    如果你都是按照默认配置安装的那么只要按照如下步骤就可以了 1.cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql   将服 ...

  9. Postgresql ERROR: permission denied for relation app_info

    启用终端,: 进入mydb数据库:\c mydb 然后给当前数据库的角色赋予权限:GRANT ALL PRIVILEGES ON TABLE 表名  TO 角色名;

  10. python - requests中添加配置文件

        HttpRequests.py #-*- coding:utf-8 -*- import requests class HttpRequests(): def http_requests(se ...