Oracle 内存参数调优设置

  Oracle 数据库系统中起到调节作用的参数叫初始化参数,数据库管理员根据实际情况需要适当调整这些 初始化参数以优化Oracle系统。

  1 主要系统参数调优介绍

  

  2 系统内存参数的分配

  2.1 Oracle 实例= 内存结构 + 进程结构

  内存结构 = SGA + PGA

  SGA(系统全局区): 用户存储数据库信息的内存区,该区域为数据库进程所共享。它包含服务器的数据和控制信息,主要包含高速数据缓冲区、共享池、重做日志缓存区、Java池,大型池等内存结构。

  SGA的设置,理论上SGA的大小应该占OS的内存的 1/3-1/2左右。

  SGA + PGA + OS使用的内存 < 总的物理内存

  查看当前系统SGA的信息

select name,bytes/1024/1024 as "Size(M)"
from v$sgainfo;

  根据查询信息显示当前还有148M可用的SGA内存,系统当前的内存配置并不是最优的,我们在实际使用过程中根据情况可以重新分配内存。

  2.2 SGA的设置原则

  SGA = (db_block_buffers * db_block_size) + (shared_pool_size + large_pool_size + java_pool_size + log_buffers)

  (1)缓冲区高速缓存(database_buffer_cache):主要存储由磁盘数据文件写入的数据

  大小:db_block_buffers * db_block_size

分配原则:缓冲区高速缓存的调整,用户进程所存取的所有数据都是经过缓冲区高速缓存来存取,所以该部分的命中率,对性能至关重要。缓冲区高速缓存的使用情况记录在动态性能表v$sysstat中,可通过查询该表来了解其活动情况,以决定如何调整。

  select name,value from v$sysstat where name in (‘dbblock gets‘,‘consistent gets‘,‘physical reads‘); 
     dbblock gets和consistent gets的值是请求数据缓冲区中读的总次数。physical reads的值是请求数据时引起从盘中读文件的次数。从缓冲区高速缓存中读的可能性的高低称为缓冲区的命中率,计算公式:

  Hit Ratio=1-(physical reds/(dbblock gets+consistent gets)) ,

select 1-(phys.value/(cur.value + con.value)) "HIT RATIO"
from    v$sysstat cur, v$sysstat con, v$sysstat phys
where  cur.name = ‘db block gets‘ 
       and con.name = ‘consistent gets‘ 
     and phys.name = ‘physical reads‘;

如果Hit
Ratio<60%~70%,则应增大db_block_buffers的参数值。db_block_buffers可以调整分配给缓冲区高速缓存的内存量,即db_block_buffers可设置分配缓冲区高速缓存的数据块的个数。缓冲区高速缓存的总字节数=db_block_buffers的值*db_block_size的值。db_block_size
的值表示数据块大小的字节数,可查询 v$parameter 表:

select name,value
from v$parameter
where name=‘db_block_size‘;

在修改了上述数据库的初始化参数以后,必须先关闭数据库,在重新启动数据库后才能使新的设置起作用。

  (2)共享池(shared_pool_size)

分配原则:在shared pool中,主要包含两个cache,即Library Cache和Data Dictionary Cache,但是不能对它们进行单独调整,只能通过调整shared_pool_size来进行。

Library
Cache用于存放共享SQL语句和PL/SQL语句,采用LRU(Least Recently
Used)算法进行管理,Oracle可以用已经cache在其中的SQL语句,而不需要re-parsing,我们可以通过下面的SQL语句来查询Library
Cache的命中率(Hit Ratio):

select GETHITRATIO
from v$librarycache
where namespace =‘SQL AREA‘;

  如果得到的结果小于90%,那么说明命中率不高,需要增大Library Cache了。

Data Dictionary
Cache的调整,数据字典缓冲区包含了有关数据库的结构、用户、实体信息。数据字典的命中率,对系统性能影响极大。数据字典缓冲区的使用情况记录在动态性能表v$librarycache中,可通过查询该表来了解其活动情况,以决定如何调整。
select sum(gets),sum(getmisses)

from v$rowcache;

gets列是对相应项请求次数的统计,getmisses
列是引起缓冲区出错的数据的请求次数。对于频繁访问的数据字典缓冲区,sum(getmisses)/sum(gets)<10%。若大于此百分数,则应考虑增加数据字典缓冲区的容量,即需调整初始化参数shared_pool_size来重新调整分配给共享池的内存量。

  

  (3) 大池(large_pool_size ): 主要用于数据库备份管理器RAM

  原则: 根据实际情况

  (4) Java池(java_pool_size): 主要用于Java语言开发

  原则: 根据实际情况

  (5) 日志缓冲区(log_buffers): 存储数据修改信息

  原则:根据实际情况

  2.3 PGA 程序全局区

  PGA包含单个服务器进程或者单个后台进程的数据和控制信息, 与几个进程共享的SGA正好相反,是一个只被一个进程使用的区域,PGA在创建进程时分配终止进程时回收。

  (1) sort_area_size 用户排序所占的内存

  (2) hash_area_size 用户散列联接, 位图索引

  这两个参数在非MTS模式下都是属于PGA,是为每个session单独分配的,在我们的服务器上除了OS + SGA一定要考虑这两部分大小的设置

  OS + SGA + 并发执行的进程数*(sort_area_size + hash_area_size) < 0.7 * OS的总物理内存

  3 实例配置

  (1) 物理内存大小

  (2) 操作系统及其他应用程序需要的内存

  (3) 数据库系统使用的是文件设备还是裸设备

  (4) 有多少并发连接

  (5) 应用是OLTP还是OLAP类型

  基本分配原则,db_block_buffers尽可能的大, shared_pool_size适度, log_buffer通常几百KB到1M就可以了。 

  1G内存,1个CPU, db_block_size 为8192B

  SGA = 1024 * 0.5 =512   -- 最大一般为OS 内存的一半左右,不超过60%

  (1) databse buffer cache:512 * 40% = 205M     db_block_buffer应设为:52352(409*1024*1024/8192)  -- 一般为sga_max_size的40%

  (2) shared_pool_size: 563* 40% = 205M  -- 一般为sga_max_size的40%

  (3) log_buffer: 128K (128K*CPU个数)

  (4) java_pool_size: 4M

  (5) large_pool_size: 4M

  (6) sort_area_size: 根据实际情况 65K - 2M

  (7) sort_area_retained_size: 根据实际情况

原文地址:https://www.cnblogs.com/lcword/p/8243703.html

时间: 2024-08-19 03:43:04

Oracle 内存参数调优设置的相关文章

Tomcat项目内存参数调优

一.常见的Java内存溢出有以下三种: 1. Java.lang.OutOfMemoryError: Java heap space 即JVM Heap溢出 解释说明:JVM在启动的时候会自动设置JVM Heap的值,JVM堆的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置.其初始空间默认是物理内存的1/64,最大空间不可超过物理内存.JVM提供-Xmn -Xms -Xmx等选项来进行设置. 出错场景:在JVM中,如果98%的时间是用于GC,且可用的Heap size不足2%时

mysql 5.6内存参数调优

mysql5.6,数据库自带performance_schema,占用内存400M. my.cnf文档 performance_schema = OFF innodb_buffer_pool_size = 8M innodb_additional_mem_pool_size = 1M innodb_log_buffer_size = 1M 引用:http://nosqldb.org/p/55ceaac5c3f8a8336f3bf727

Tomcat6 一些调优设置内存和连接数

公司的一个服务器使用Tomcat6默认配置,在后台一阵全点击服务器就报废了,查了一下就要是PERMSIZE默认值过小造成(16-64) TOMCAT_HOME/bin/catalina.sh 添加一行:JAVA_OPTS=" -XX:PermSize=64M -XX:MaxPermSize=128m" 问题解决(可能为调用JAR包过多原因)下面是网上看到一些设置 JAVA_OPTS="-server -Xms800m -Xmx800m -XX:PermSize=64M -XX

性能测试三十六:内存溢出和JVM常见参数及JVM参数调优

堆内存溢出: 此种溢出,加内存只能缓解问题,不能根除问题,需优化代码堆内存中存在大量对象,这些对象都有被引用,当所有对象占用空间达到堆内存的最大值,就会出现内存溢出OutOfMemory:Java heap space 永久代溢出 如果发生,则是在初始化的时候,空间太小,解决办法,扩大空间类的一些信息,如类名.访问修饰符.字段描述.方法描述等,所占空间大于永久代最大值,就会出现OutOfMemoryError:PermGen space 内存溢出的检测方法:pid=1730 Jdk/bin目录下

大数据技术之_30_JVM学习_01_JVM 位置+JVM 体系结构概览+堆体系结构概述+堆参数调优入门+JVM 的配置和优化+Tomcat 的配置和优化

1.JVM 位置2.JVM 体系结构概览3.堆体系结构概述4.堆参数调优入门5.JVM 的配置和优化6.Tomcat 的配置和优化 熟悉 JVM 架构与 GC 垃圾回收机制以及相应的 JVM 调优,有过在 Linux 系统下的调优经验. 淘宝的周志明<深入理解 Java 虚拟机>中说 JVM 的优化,其中 99% 优化的是堆,1% 优化的是方法区. 内地女歌手照片--李嘉欣,贴在桌面上. 1.JVM 位置 JVM 是运行在操作系统之上的,它与硬件没有直接的交互 2.JVM 体系结构概览 详解如

inux IO 内核参数调优 之 参数调节和场景分析

http://backend.blog.163.com/blog/static/2022941262013112081215609/ http://blog.csdn.net/icycode/article/category/5966733 http://blog.sina.cn/dpool/blog/s/blog_b374c0f30102wboi.html 1. pdflush刷新脏数据条件 (linux IO 内核参数调优 之 原理和参数介绍)上一章节讲述了IO内核调优介个重要参数参数. 总

spark参数调优

摘要 1.num-executors 2.executor-memory 3.executor-cores 4.driver-memory 5.spark.default.parallelism 6.spark.storage.memoryFraction 7.spark.shuffle.memoryFraction 8.资源参数参考示例 内容 1.num-executors 参数说明:该参数用于设置Spark作业总共要用多少个Executor进程来执行.Driver在向YARN集群管理器申请资

大并发高负载下的PHP-FPM参数调优

大并发高负载下的PHP-FPM参数调优 主要针对PHP在Linux下的参数调优 调整文件描述符限制 # ulimit -n 1000000 # vi /etc/security/limits.conf # Setting Shell Limits for File Descriptors *  soft nofile 1000000 *  hard nofile 1000000 禁止PHP代码文件所在分区的文件系统访问时间更新 # vi /etc/fstab 比如PHP代码所在分区: /dev/

php-fpm参数调优

关于php-fpm.conf参数调优,只对重要的参数进程调优.其它可参数前辈的. http://php.net/manual/zh/install.fpm.configuration.php (官方的) http://www.cnblogs.com/argb/p/3604340.html http://www.cnblogs.com/jonsea/p/5522018.html https://www.zybuluo.com/phper/note/89081 http://blog.64mazi.