Oracle数据库内存参数的优化

Ø       oracle相关的系统内核参数

Ø       SGAPGA参数设置

 

Oracle下磁盘存储性能优化

Ø       文件系统的选择(ext2/ext3xfsocfs2

Ø       Oracle ASM存储

 1.优化oracle性能参数之前要了解的情况

1)物理内存有多大

2)操作系统估计要使用多大内存

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

4)有多少并发连接

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

2.oracle数据库内存参数的优化

1)系统内核参数

修改 /etc/sysctl.conf 这个文件,加入以下的语句:

kernel.shmmax = 2147483648

kernel.shmmni = 4096

kernel.shmall = 2097152

kernel.sem = 250 32000 100 128

fs.file-max = 65536

net.ipv4.ip_local_port_range = 1024 65000

参数依次为:

Kernel.shmmax:共享内存段的最大尺寸(以字节为单位)。

Kernel.shmmni系统中共享内存段的最大数量。

Kernel.shmall:共享内存总量,以页为单位。

fs.file-max:文件句柄数,表示在Linux系统中可以打开的文件数量。

net.ipv4.ip_local_port_range:应用程序可使用的IPv4端口范围。

需要注意的几个问题

关于Kernel.shmmax

Oracle SGA 由共享内存组成,如果错误设置 SHMMAX可能会限制SGA 的大小,SHMMAX设置不足可能会导致以下问题:ORA-27123:unable to attach to shared memory segment,如果该参数设置小于Oracle SGA设置,那么SGA就会被分配多个共享内存段。这在繁忙的系统中可能成为性能负担,带来系统问题。

Oracle建议Kernel.shmmax最好大于sga,以让oracle共享内存区SGA在一个共享内存段中,从而提高性能。

关于Kernel.shmall

表示系统共享内存总大小,以页为单位。

一个32位的Linux系统,8G的内存,可以设置kernel.shmall = 2097152,即为: 2097152*4k/1024/1024 = 8G就是说可用共享内存一共8G,这里的4K是32位操作系统一页的大小,即4096字节。

关于Kernel.shmmni

表示系统中共享内存段的最大数量。系统默认是4096,一般无需修改,在SUN OS下还有Kernel.shmmin参数,表示共享内存段最小尺寸,勿要混肴!  (2)SGA、PAG参数的设置

A Oracle内存管理方面的改进

Oracle 9i通过参数PGA_AGGREGATE_TARGET参数实现PGA自动管理 Oracle 10g通过参数SGA_TARGET参数实现了SGA的自动管理,

Oracle 11g实现了数据库所有内存块的全自动化管理,使得动态管理SGA和PGA成为现实。

自动内存管理的两个参数:

MEMORY_TARGET:表示整个ORACLE实例所能使用的内存大小,包括PGA和SGA的整体大小,即这个参数是动态的,可以动态控制SGA和PGA的大小。

MEMORY_MAX_TARGET:这个参数定义了MEMORY_TARGET最大可以达到而不用重启实例的值,如果没有设置MEMORY_MAX_TARGET值,默认等于MEMORY_TARGET的值。

使用动态内存管理时,SGA_TARGET和PGA_AGGREGATE_TARGET代表它们各自内存区域的最小设置,要让Oracle完全控制内存管理,这两个参数应该设置为0。

B Oracle五种内存管理方式

Ø         自动内存管理,即AMM (Automatic Memory Management)

Ø         自动共享内存管理,即ASMM(Automatic Shared Memory Management)

Ø         手动共享内存管理

Ø         自动PGA管理

Ø         手动PGA管理

自动内存管理(AMM)

默认安装oracle11g的实例就是AMM方式。通过如下查看:

示例如下:

SQL> show parameters target  NAME                                       TYPE                  VALUE ------------ ---------------------      ------------------    ---------------------- archive_lag_target                     integer                      0 db_flashback_retention_target   integer                    1860 fast_start_io_target                    integer                      0 fast_start_mttr_target                 integer                      0 memory_max_target                  big integer              1400M memory_target                          big integer              1400M pga_aggregate_target                big integer                0 sga_target                                  big integer                0

注意:如果初始化参数 LOCK_SGA = true ,则 AMM 是不可用的。

自动共享内存管理

自动共享内存管理是oracle10g引进的,如果要使用自动共享内存管理,只需设置MEMORY_TARGET=0,然后显式指定SGA_TARGET即可。

示例如下:

SQL> alter system set memory_target=0 scope=both; System altered. SQL> alter system set sga_target=1024m scope=both; System altered. SQL>

手工共享内存管理

Oracle9i以及以前版本,只能手工设置共享内存管理,如果要使用手动共享内存管理,首先需要设置SGA_TARGET 与 MEMORY_TARGET为0。

SGA包含主要参数有:

share_pool_size:共享池大小,建议300-500M之间。

Log_buffer:日志缓冲区大小,建议1-3M之间。

Large_pool_size:大缓冲池大小,非MTS系统,建议在20-30M之间。

Java_pool_size:java池大小,没有java应用时,建议10-20M之间。

db_cache_size:数据缓冲区大小,根据可使用内存大小,尽可能大。

自动PAG管理

Oracle9i版本引入了自动PGA管理,如果使用的是AMM管理方式,则无需担心PGA的配置,但是如果对对AMM管理不放心的话,可以设置自动PGA管理,设置

WORKAREA_SIZE_POLICY = AUTO

然后指定PGA_AGGREGATE_TARGET大小即可。,

手工PAG管理

如果要做到精确的控制PGA,还可以设置手动管理PGA,设置

WORKAREA_SIZE_POLICY = manual

然后分别指定PGA相关参数即可:

PGA相关参数有:

SORT_AREA_SIZE

SORT_AREA_RETAINED_SIZE,

3.Oracle下磁盘存储性能优化

①      选择文件系统存取数据

文件系统的选择

单一文件系统(ext2、ext3、xfs等)

集群文件系统(gfs、ocfs2)

文件系统存储优缺点:

优点:管理维护方便。

缺点:数据读写要经过操作系统级的缓存,效率不是很高。

②      ASM(Automatic Storage Management)

ASM优点:

数据可直接读写,无需经过操作系统存取效率很高,读写效率与直接的原始设备基本相同。

Oracle提供了专门的管理和维护工具

Oracle在Linux下的性能优化的更多相关文章

  1. Linux 下网络性能优化方法简析

    概述 对于网络的行为,可以简单划分为 3 条路径:1) 发送路径,2) 转发路径,3) 接收路径,而网络性能的优化则可基于这 3 条路径来考虑.由于数据包的转发一般是具备路由功能的设备所关注,在本文中 ...

  2. Linux下Tomcat性能优化--文件句柄数增大

    今天在对项目进行性能压力测试时,设置并发量为1000,发现Tomcat控制报错: java.IOException:打开的文件过多 经搜索,发现是由于Linux默认设置的句柄数为1024,当并发量过大 ...

  3. 通过/proc/sys/net/ipv4/优化Linux下网络性能

    通过/proc/sys/net/ipv4/优化Linux下网络性能 /proc/sys/net/ipv4/优化1)      /proc/sys/net/ipv4/ip_forward该文件表示是否打 ...

  4. GNU Linux高并发性能优化方案

    /*********************************************************** * Author : Samson * Date : 07/14/2015 * ...

  5. 大并发连接的oracle在Linux下内存不足的问题的分析

    大并发连接的oracle在Linux下内存不足的问题的分析 2010-01-28 20:06:21 分类: Oracle 最近一台装有Rhel5.3的40G内存的机器上有一个oracle数据库,数据库 ...

  6. Spark Tungsten揭秘 Day1 jvm下的性能优化

    Spark Tungsten揭秘 Day1 jvm下的性能优化 今天开始谈下Tungsten,首先我们需要了解下其背后是符合了什么样的规律. jvm对分布式天生支持 整个Spark分布式系统是建立在分 ...

  7. Linux下Java性能监控

    Linux下Java性能监控 一.JVM堆内存使用监控 获取thread dump的3种方法: 1)使用$JAVA_HOME/bin/jcosole中的MBean,到MBean>com.sun. ...

  8. [转帖]etcd 在超大规模数据场景下的性能优化

    etcd 在超大规模数据场景下的性能优化   阿里系统软件技术 2019-05-27 09:13:17 本文共5419个字,预计阅读需要14分钟. http://www.itpub.net/2019/ ...

  9. ORACLE数据库学习之SQL性能优化详解

                                                                                    Oracle  sql 性能优化调整 ...

随机推荐

  1. 使用数组实现ArrayList的效果

    package day04.d2.shuzu; /** * 通过数组实现类似于集合的功能 * 包含功能有: * * 动态添加元素 * 在指定位置添加元素 * * 删除指定下标的元素 * 删除指定内容的 ...

  2. Java 系列之spring学习--依赖注入(二)

    一.依赖注入的三种方式 接口注入,set注入,构造函数注入 二.构造函数注入 2.1.测试类 package test; public class test01 { public String msg ...

  3. TensorFlow-LSTM序列预测

    问题情境:已知某一天内到目前为止股票各个时刻的价格,预测接下来短时间内的价格变化. import tushare as ts import time from collections import n ...

  4. hdu2853 Assignment 完美匹配 多校联赛的好题

    PS:好题.不看题解绝对AC不了. 题解来源: http://blog.csdn.net/niushuai666/article/details/7176290 http://www.cnblogs. ...

  5. Py基础+中级

    原文 Py学习博客 1:https://www.cnblogs.com/fu-yong/p/8060198.html2:while True:just do it 三.Python的默认编码 ▷pyt ...

  6. go开发和运行环境的配置

    1.运行环境的下载.安装.配置: 下载:http://www.golangtc.com/download  官网下载经常被墙屏蔽,所以就从golang中国下载; 安装及其配置:http://jingy ...

  7. QT线程使用收集示例

    关于多线程问题: Qt和Boost做跨平台的线程封装,OpenMP主要做并行计算,让不精通多线程的人也能高效地利用CPU的计算能力.个人倾向于用boost.thread, boost.mpi.   一 ...

  8. 文字纵向滚动marquee

    <div style="width:200px; height:300px"><marquee direction="up" truespee ...

  9. Visual Studio 2015中 安卓环境 cannot find adb.exe in specified sdk path

    安装完成后 发现 C:\Program Files (x86)\Android\android-sdk\platforms 是空的,用SDK Manager进行安装时发现 它需要往C:\Program ...

  10. java 常用API 时间

    package com.orcal.demc01; import java.text.ParseException; import java.text.SimpleDateFormat; import ...