“Oracle内存管理可分为两大类,自动内存管理和手动内存管理。其中手动内存管理又可分为自动共享内存管理,手动共享内存管理,自动PGA内存管理以及手动PGA内存管理。本文会简单的介绍不同的内存管理方式以及如何启用它们”

在工作中发现,很多客户的数据库设置都是由运维负责操作。尤其是内存的调整大多数都是由运维来完成。但是运维对于如何设置数据库内存基本不了解,甚至连各参数有什么用都不知道。对于大部分运维来说只要有百度,就敢改参数。所以很多时候运维设定的参数实际上对于系统的运行仍有极大的调优空间。

阅读文章你将了解到Oracle的内存管理方式,以及如何启用它们,并且你也将初步了解如何分配内存。

自动内存管理

自动内存管理的英文全称为AutomaticMemory Management。是指Oracle自动的对SGA和PGA进行管理。如果我们要启动自动内存管理,只需设置MEMORY_TARGET和MEMORY_MAX_TARGET即可。

MEMORY_TARGET用于设置目标内存大小,Oracle会尝试将内存稳定在该值。如果你修改了MEMORY_TARGET并不需要重启数据库。

MEMORY_MAX_TARGET用于设置最大允许的内存大小,Oracle以此来限制内存使用的最大值。如果你修改了该参数,你需要重启数据库。

在修改以上两个值时需要特别注意,MEMORY_MAX_TARGET必须大于或者等于MEMORY_TARGET。

调整内存的参考命令如下:

ALTER SYSTEM SETMEMORY_MAX_TARGET = 1000M SCOPE = SPFILE;

ALTER SYSTEM SET MEMORY_TARGET =1000MSCOPE= SPFILE;

在上述命令中:

SCOPE指的是修改范围,一共有三个值分别是SPFILE,BOTH和MEMORY

SPFILE:指修改服务器参数文件中的数据。

MEMORY:指修改内存中的数据,对于要重启数据库才生效的参数,该值不可用

BOTH:指同时修改服务器参数文件和内存中的数据。

什么情况下使用自动内存管理

Oracle官方推荐SGA+PGA的内存总大小如果小于或等于4GB,建议使用自动内存管理。如果你的SGA+PGA大于4G也使用了自动内存管理,那么建议最好设置SGA_TARGET和PGA_AGGREGATE_TARGET的值。那么这些值将作为SGA和PGA的最小值。该设置主要是为了避免过大的内存抖动。

自动共享内存管理

自动共享内存管理的英文全称为Automatic Shared Memory Management。简称为ASMM。当启用自动共享内存管理时,Oracle会自动的调整SGA的各个组件的值。如果需要启动自动共享内存管理,需要将SGA_TARGET和SGA_MAX_SIZE设置为非0值,同时还需要将MEMORY_TARGET和MEMORY_MAX_TARGET设置为0,否则MEMORY_TARGET不为0,Oracle采用的是自动内存管理而不是自动共享内存管理。

SGA_TARGET用于设置共享内存目标大小,Oracle会努力维持共享内存在此目标值,如果你修改了该参数,你并不需要重启数据库。

SGA_MAX_SIZE用于设置最大允许的共享内存大小,Oracle以此来限制共享内存的最大值,如果你修改了该参数,你需要重启数据库。

在修改以上两个值时需要注意,SGA_MAX_SIZE必须大于或者等于SGA_TARGET。

调整内存的参考命令如下:

ALTER SYSTEM SET SGA_TARGET =1000M SCOPE = SPFILE;

ALTER SYSTEM SET SGA_MAX_SIZE =1000MSCOPE= SPFILE;

ALTER SYSTEM SETMEMORY_MAX_TARGET = 0 SCOPE = SPFILE;

ALTER SYSTEM SET MEMORY_TARGET = 0SCOPE = SPFILE;

在上述命令中:

SCOPE指的是修改范围,一共有三个值分别是SPFILE,BOTH和MEMORY

SPFILE:指修改服务器参数文件中的数据。

MEMORY:指修改内存中的数据,对于要重启数据库才生效的参数,该值不可用

BOTH:指同时修改服务器参数文件和内存中的数据。

什么情况下使用自动共享内存管理

Oracle官方推荐SGA+PGA的总大小大于4GB,建议使用自动共享内存管理。如果我们启用了自动共享内存管理,Oracle会自动的调整SGA各组件大小,一般我们并不需要干预。但如果我们知道各组件高峰期时这些值的使用量,那么我们也可以为这些组件设置指定值,这些值将作为组件的最小值。从而避免高峰期时不必要的内存调整

手动共享内存管理

手动共享内存管理的英文全称为Manual Shared Memory Management。要手动管理共享内存,首先必须禁用自动内存管理和自动共享内存管理。因此MEMORY_TARGET和SGA_TARGET都必须设置为0。同时需要手工设置其他组件的值

DB_CACHE_SIZE:缓冲区缓存,主要用于缓存数据,较大的缓存通常会减少磁盘的读写数量,因此缓冲区缓存的大小对性能影响较为明显,因此设置一个合理的缓冲区缓存尤为重要。

SHARED_POOL_SIZE:共享池,存储多种类型的数据,例如解析后的SQL,PL/SQL代码,数据字典,查询的结果集缓存等数据。因此在多用户环境下,较大的共享池对于性能提升也是非常有帮助的。

LARGE_POOL_SIZE:大池是一个可选组件。一般用于备份进程,并行执行等。

JAVA_POOL_SIZE:JAVA池,JAVA代码所需要的内存将从此分配。

STREAMS_POOL_SIZE:流池,存储缓冲队列消息的内存池。

什么情况下使用手动共享内存管理

不推荐使用手动共享内存管理,首先你需要对内存的各参数的作用非常的了解。其次你必须对系统各阶段内存的使用情况非常了解。并且由于不同时期对各个组件内存使用的多少可能有较大的差异,这极大的增加了管理成本。所以不推荐使用手动共享内存管理。

自动PGA内存管理

自动PGA内存管理的英文全称为Automatic PGA Memory Management。当使用自动PGA内存管理时,Oracle会自动的管理实例PGA的内存总量。我们可以通过设置初始化参数PGA_AGGREGATE_TARGET为非0值来开启自动PGA内存管理。Oracle会尝试确保分配给所有数据库服务器进程和后台进程的PGA内存总量不会超过这个目标,但实际使用时可能超过该设置。当我们使用自动PGA内存管理时,SQL工作区的大小是自动的,并且会忽略所有*_AREA_SIZE初始化参数

注意:Oracle推荐使用自动PGA内存管理

手动PGA内存管理

手动PGA内存管理的英文全称为Manual PGA Memory Management。当自动内存管理被禁用并且PGA_AGGREGATE_TARGET被设置为0时,将启用手动PGA内存管理。使用手动PGA内存管理时,意味着你需要手工设置*_AREA_SIZE初始化参数。

注意:Oracle不推荐使用手动PGA内存管理

如何分配内存

不管是采用自动内存管理还是自动共享内存管理+自动PGA内存管理。在分配内存时,普遍的做法是分配机器总内存的50%~75%。例如:机器内存是128G,SGA+PGA合计会分配64G~96G。需要注意的是50%~75%只是一个普遍值,但不是个绝对值。机器内存只有4G的情况下,分配50%是很有必要的,但是如果机器内存有512G,对于只部署数据库的机器来说分配75%仍然有大量的内存未使用。

SGA需要多大?PGA需要多大?这个并没有参考的指标,一般需要根据实际情况来分配,一般可以先确定PGA大小,然后剩余内存都分配给SGA。如果你的系统有大量的并发访问,那么PGA分配就需要比较多,而如果你的系统并发访问人数非常少。那么几百MB的PGA就可满足了。而剩下的内存则都可以分配给SGA。

原文链接:https://baijiahao.baidu.com/s?id=1709116934036677066&wfr=spider&for=pc

Oracle内存管理方式介绍(转载)的更多相关文章

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

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

  2. Oracle内存管理方式由amm切换为asmm

    (一)ASMM和AMM 在Oracle 10g时,Orale推出ASMM(Automatic Shared Memory Managed),实现了SGA和PGA各自内部的自调节.在Oracle 11g ...

  3. 24小时学通Linux内核之内存管理方式

    昨天分析的进程的代码让自己还在头昏目眩,脑子中这几天都是关于Linux内核的,对于自己出现的一些问题我会继续改正,希望和大家好好分享,共同进步.今天将会讲诉Linux如何追踪和管理用户空间进程的可用内 ...

  4. 十天学Linux内核之第三天---内存管理方式

    原文:十天学Linux内核之第三天---内存管理方式 昨天分析的进程的代码让自己还在头昏目眩,脑子中这几天都是关于Linux内核的,对于自己出现的一些问题我会继续改正,希望和大家好好分享,共同进步.今 ...

  5. Oracle内存管理技术

    1.Oracle内存管理技术 2.配置自动内存管理(AMM) 3.监视自动内存管理(AMM) 4.配置自动共享内存管理(ASMM) 5.配置自动PGA内存管理 Reference 1.Oracle内存 ...

  6. glusterfs 内存管理方式

    glusterfs中的内存管理方式: 首先来看看glusterfs的内存管理结构吧: struct mem_pool { struct list_head list; int hot_count; i ...

  7. windows内存管理方式以及优缺点

    Windows内存管理方式:页式管理,段式管理,段页式管理 页式管理 将各进程的虚拟空间(逻辑地址)划分为若干个长度相等的页,业内管理把内存空间(物理内存)按照页的大小划分为片或者页面,从而实现了离散 ...

  8. ObjC如何通过runtime修改Ivar的内存管理方式

    ObjC如何通过runtime修改Ivar的内存管理方式 为什么要这么做? 在iOS 9之前,UITableView(或者更确切的说是 UIScrollView)有一个众所周知的问题: propert ...

  9. php中的内存管理的介绍(转)

    本篇文章给大家带来的内容是关于php中的内存管理的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 一.php内存管理概述——Zend引擎 由于计算机的内存由操作系统进行管理,所以 ...

  10. oracle内存管理

    关于内存管理 必须管理的内存结构是系统全局区(SGA)和实例程序全局区(instance PGA).Oracle 数据库支持各种内存管理方法,这些方法由初始化参数设置选择. 自动内存管理 Oracle ...

随机推荐

  1. Syncthing 忽略模式

    忽略模式 概要 .stignore 描述 这是 Syncthing 同步文件夹的忽略模式语法指南 语法 .stignore 文件可包含一系列路径匹配模式,对指定文件的处理方式由第一个匹配到它的模式决定 ...

  2. 文心一言 VS chatgpt (6)-- 算法导论2.3 1~2题

    一.使用图 2-4作为模型,说明归并排序在数组 A=(3,41,52,26,38,57,9,49)上的操作. 文心一言: 使用图 2-4作为模型,说明归并排序在数组 A=(3,41,52,26,38, ...

  3. 2021-08-09:给定一个有正、有负、有0的数组arr,给定一个整数k,返回arr的子集是否能累加出k。1)正常怎么做?2)如果arr中的数值很大,但是arr的长度不大,怎么做?

    2021-08-09:给定一个有正.有负.有0的数组arr,给定一个整数k,返回arr的子集是否能累加出k.1)正常怎么做?2)如果arr中的数值很大,但是arr的长度不大,怎么做? 福大大 答案20 ...

  4. Django笔记四十之运行Django环境的python脚本

    本文首发于公众号:Hunter后端 原文链接:Django笔记四十之运行Django环境的python脚本 这一篇笔记介绍如何在 Django 中运行脚本. 假设说我们要实现一个功能,需要获取 blo ...

  5. Serverless冷扩机器在压测中被击穿问题

    一.现象回顾 在今天ForceBot全链路压测中,有位同事负责的服务做Serverless扩容(负载达到50%之后自动扩容并上线接入流量)中,发现新扩容的机器被击穿,监控如下(关注2:40-3:15时 ...

  6. 5.5. Java并发工具类(如CountDownLatch、CyclicBarrier等)

    5.5.1 CountDownLatch CountDownLatch是一个同步辅助类,它允许一个或多个线程等待,直到其他线程完成一组操作.CountDownLatch有一个计数器,当计数器减为0时, ...

  7. Java的标识符、关键字、 常量、变量、数据类型、 数据类型转换、字符ASCII码表(基础语法的学习)

    一.Java的关键字和标识符 关键字 1.定义: 在Java程序中,已经定义好的被预先使用的一些特殊的单词称为关键字,一共有50个关键字(48+2个保留字),关键字都是小写的英文单词 2.关键字的分类 ...

  8. 自学FHQ-treap的草稿

    更新:能过模板题(和加强版)的代码: 普通平衡树: (请自行实现读入和输出函数) 点击查看代码 #include <iostream> #include <random> #i ...

  9. 【HMS Core】Health Kit健康数据采样, 原子采样数据问题

    [问题描述] 1.体脂数据中的肌肉量和水份量是如何获得的,都有些什么?体脂数据中的体重,体脂是用户自己上传的,然后通过计算公式得到数据吗 2.日常活动统计数据包含什么内容,怎么获取这些数据? 3. 锻 ...

  10. 【了解LLM】—— LLM&& SD 基本概念

    本文地址:https://www.cnblogs.com/wanger-sjtu/p/17417312.html Causual LM 这里以llama模型为例,通常在执行用户输入之前会有一个[[文章 ...