1.Oracle内存管理技术

  • 11g 新特性: AMM(Automatic Memory Management)
  • 10g 新特性: ASMM(Automatic Shared Memory Management)

Tips:

  • 即便启动了AMM,仍然可以将相关的内存初始化参数设置为下限值,防止Oracle自动调整为低值或零值。
  • Oracle11g 建议使用AMM配置新数据库,然后监视总体内存分配的效果,后续可以将数据库切换到ASMM,以便更精准的控制SGA的总大小。

2.配置自动内存管理(AMM)

-- memory_max_target是静态参数,是memory_target的上限,修改需要重启库
SQL> alter system set memory_max_target = 3G scope=spfile;
SQL> shutdown immediate
SQL> startup
-- 配置AMM,memory_target值
SQL> alter system set memory_target = 2G;
-- 为更好的发挥AMM调整作用,设置下面参数为零值
SQL> alter system set sga_target = 0;
SQL> alter system set pga_aggregate_target = 0;

3.监视自动内存管理(AMM)

## 3.1 通过EM查看 ##
EM主页:服务器(Server) -> 数据库配置(Database Configuration) -> 内存指导(Memory Advisors)
## 3.2 直接查询动态性能视图 ##
```
SQL> select * from v$memory_target_advice order by memory_size;

MEMORY_SIZE MEMORY_SIZE_FACTOR ESTD_DB_TIME ESTD_DB_TIME_FACTOR VERSION


    768                .25          402                   1          1
1536 .5 402 1 1
2304 .75 402 1 1
3072 1 402 1 1
3840 1.25 402 1 1
4608 1.5 402 1 1
5376 1.75 402 1 1
6144 2 402 1 1

8 rows selected.

<h1 id="4">4.配置自动共享内存管理(ASMM)</h1>
## 4.1 从手动内存管理切换到ASMM ##

-- 从手动内存管理切换到ASMM

alter system set sga_target = 1G;

-- 为更好的发挥ASMM作用,设置下面参数为零值

SQL> alter system set shared_pool_size = 0;

SQL> alter system set db_cache_size = 0;

SQL> alter system set java_pool_size = 0;

SQL> alter system set large_pool_size = 0;

SQL> alter system set streams_pool_size = 0;

## 4.2 从AMM切换到ASMM ##

-- 从AMM切换到ASMM,会根据当前SGA内存使用情况自动设置SGA_TARGET

alter system set memory_target = 0;

## 4.3 禁用ASMM ##

--下面命令使得所有初始化参数被设置为当前自动调整的值,禁用ASMM

alter system set sga_target = 0;

## 4.4 ASMM需要手工调整下面的参数 ##

ASMM只可以自动调整4.1中设置为零值的5个参数大小,而剩下的需要手工调整

-- DB_KEEP_CACHE_SIZE

-- DB_RECYCLE_CACHE_SIZE

-- DB_nK_CACHE_SIZE

-- LOG_BUFFER

手工设置这些参数值,会从SGA_TRAGET指定的内存中减去这些内存量。

<h1 id="5">5.配置自动PGA内存管理</h1>
PGA_AGGREGATE_TARGET的值可以由AMM推出来,也可以明确设置。

--PGA设置起点

Oracle单实例可用内存设置为占机器物理内存的80%

OLTP(在线事务处理):PGA占可用内存的20%

DSS(查询使用大量内存):PGA占可用内存的50%~70%

--查询pga相关动态视图

select * from v$pgastat;

select PGA_USED_MEM, PGA_ALLOC_MEM, PGA_FREEABLE_MEM, PGA_MAX_MEM from v$process;

更多PGA相关可参考:《[相克军_Oracle体系_随堂笔记007-PGA](http://www.cnblogs.com/jyzhao/p/3819372.html)》
<h1 id="6">Reference</h1>
- OCP 认证考试指南 (1Z0-053)[M]. 清华大学出版社, 2010.

Oracle内存管理技术的更多相关文章

  1. iOS开发ARC内存管理技术要点

    本文来源于我个人的ARC学习笔记,旨在通过简明扼要的方式总结出iOS开发中ARC(Automatic Reference Counting,自动引用计数)内存管理技术的要点,所以不会涉及全部细节.这篇 ...

  2. (转)iOS开发ARC内存管理技术要点

    转自:http://www.cnblogs.com/flyFreeZn/p/4264220.html 本文来源于我个人的ARC学习笔记,旨在通过简明扼要的方式总结出iOS开发中ARC(Automati ...

  3. iOS开发ARC机制下的内存管理技术要点

    转载一篇: iOS开发ARC内存管理技术要点.ARC内存管理原则总结.iOS ARC内存管理总结 ARC内存管理机制 (一)ARC的判断准则: 只要没有任何一个强指针指向该对象,该对象就会被释放. ( ...

  4. 这篇关于Oracle内存管理方式的介绍太棒了!我必须要转发,很全面。哈哈~

    "Oracle内存管理可分为两大类,自动内存管理和手动内存管理.其中手动内存管理又可分为自动共享内存管理,手动共享内存管理,自动PGA内存管理以及手动PGA内存管理.本文会简单的介绍不同的内 ...

  5. Oracle 内存管理

    --内存分配建库时可以先分配系统内存的50%-80%给Oracle,后期根据业务再进行调整.SGA.PGA分配比例:OLTP:SGA %80 , PGA %20OLAP:SGA %50 , PGA % ...

  6. Paddle源码之内存管理技术

    前言 在深度学习模型训练中,每次迭代过程中都涉及到Tensor的创建和销毁,伴随着的是内存的频繁 malloc和free操作,可能对模型训练带来不必要的 overhead. 在主流的深度学习框架中,会 ...

  7. [转载]linux段页式内存管理技术

    原始博客地址: http://blog.csdn.net/qq_26626709/article/details/52742470 一.概述 1.虚拟地址空间 内存是通过指针寻址的,因而CPU的字长决 ...

  8. Oracle内存管理(之二)

    [深入解析--eygle] 学习笔记 1.2.2 UGA和CGA UGA(用户全局区)由用户会话数据.游标状态和索引区组成.在共享server模式下,一个共享服务进程被多个用户进程共享,此时UGA是S ...

  9. Oracle内存管理(之四)

    [深入解析--eygle]学习笔记 1.3 SGA管理 SGA指系统全局区(System Global Area),是一块用于载入数据.对象并保存执行状态和数据库控制信息的一块内存区域,在数据库实例启 ...

随机推荐

  1. android studio/Intellij idea之proguard实践

    默认情况下,build->Gene Signed APK 反编译后发现,没有混淆... 多次爬stackoverflow才搞定这个问题: 首先 build variants这里由debug设置为 ...

  2. .Net程序员之不学Java做安卓开发:Android Studio中的即时调试窗口

    对学.Net的人来说,JAVA开发是一场噩梦. .net中的即时窗口,调试时直接在里面写代码,对程序中的各种方法/属性进行调用,很方便. Android Studio中找了好久,参考如下网址,也有类似 ...

  3. Spring MVC注解的一些案列

    1.  spring MVC-annotation(注解)的配置文件ApplicationContext.xml <?xml version="1.0" encoding=& ...

  4. 输入框三种输入方式(selenium webdriver 干货)

    在机票预定的页面,输入出发城市和到达城市输入框的时候, 发现直接使用sendkeys不好使, 大部分情况出现输入某城市后没有输入进去, 经过几天的研究,发现可以采取三种方式: 1. 先点击输入框,待弹 ...

  5. Android再学习

    1.点击事件的几种实现方式 Button Btn1 = (Button)findViewById(R.id.button1);//获取按钮资源 Btn1.setOnClickListener(new ...

  6. CGI和ISAPI

    1) CGI概念CGI即通用网关接口(Common Gateway Interface),它是一段程序,运行在服务器上,提供同客户端HTML页面的交互,通俗的讲CGI就象是一座桥,把网页和WEB服务器 ...

  7. [Window Title] (没有登录) [Content] ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务 [OK]

    重启Oracle服务

  8. 微软借力.NET开源跨平台支持,布局物联网平台开发

    今天科技类最大的新闻,莫过于微软宣布.NET开发框架开源计划..NET 开源,集成 Clang 和 LLVM 并且自带 Android 模拟器,这意味着 Visual Studio 这个当下最好没有之 ...

  9. 我的第一段jQuery代码

    说起 jQuery,很多人可能觉得,不算什么,就是个js类库.而,对于我,下面这几行代码,是一个新的开始. 多年来,我一直在使用MooTools ,他面向对象,写起来结构清晰分明,都是在原生js的基础 ...

  10. ABP理论学习之多租户

    返回总目录 本篇目录 什么是多租户 ABP中的多租户 什么是多租户 维基百科:"软件多租户是指一种软件架构,在这种软件架构中,软件的一个实例运行在服务器上并且为多个租户服务".一个 ...