Chinaunix首页 | 论坛 | 博客
  • 博客访问: 551592
  • 博文数量: 154
  • 博客积分: 4055
  • 博客等级: 上校
  • 技术积分: 1381
  • 用 户 组: 普通用户
  • 注册时间: 2006-04-01 14:26
文章分类

全部博文(154)

文章存档

2014年(2)

2013年(2)

2011年(2)

2010年(11)

2009年(9)

2008年(35)

2007年(22)

2006年(71)

我的朋友

分类: Oracle

2006-04-27 16:43:06

 

ORACLE 8.0.X 版本

SGA=((db_block_buffers * block size)+(shared_pool_size+large_pool_size+log_buffers)+1MB

ORACLE 8.1.X 版本

SGA=((db_block_buffers * block size)+(shared_pool_size+large_pool_size+java_pool_size+log_buffers)+1MB

理论上SGA可占OS系统物理内存的1/2——1/3,我们可以根据需求调整

我推荐SGA=0.45*(OS RAM)

假设服务器运行ORACLE 8.1.X 版本, OS系统内存为2G MEM, db_block_size 8192 bytes,
除了运行ORACLE数据库外, 没有其它的应用程序或服务器软件.

这样SGA合计约为921M ( 0.45*2048M ),

shared_pool_size 250M (250*1024*1024 bytes)

database buffer cache 620M (79360*8192 bytes)

initorasid.ora文件里具体各参数如下:

shared_pool_size = 262144000
# 250 M

db_block_buffers = 79360
# 620 M

log_buffer = 524288
# 512k (128K*CPU
个数)

large_pool_size = 31457280
# 30 M

java_pool_size = 20971520
# 20 M

sort_area_size = 524288
# 512k (65k--2M)

sort_area_retained_size = 524288
# MTS
sort_area_retained_size = sort_area_size

SUN Solaris/etc/system文件里的几个参数同样跟内存分配有关

ORACLE安装时缺省的设置: 建议修改的设置:
set shmsys:shminfo_shmmax=4294967295
set shmsys:shminfo_shmmin=1
set shmsys:shminfo_shmmni=100
set shmsys:shminfo_shmseg=15
set semsys:seminfo_semmns=200
set semsys:seminfo_semmni=70
set ulimit=3000000
set semsys:seminfo_semmni=315
set semsys:seminfo_semmsl=300
set semsys:seminfo_semmns=630
set semsys:seminfo_semopm=315
set semsys:seminfo_semvmx=32767
set shmsys:shminfo_shmmax=4294967295
set shmsys:shminfo_shmmni=315
set shmsys:shminfo_shmseg=10
set shmsys:shminfo_shmmin=1

其中这些参数的含义

shmmax - 共享内存段,建议设大点, 达到最大SGA
shmmin -
最小的共享内存段.
shmmni -
共享内存标志符的数量.
shmseg -
一个进程可分配的最大内存段数.
shmall -
最大可允许的内存数,比SGA还要大.
semmns -
信号灯,跟ORACLEPROCESS数有关.
semmsl -
一个信号灯中最大的信号灯数.

阅读(589) | 评论(0) | 转发(0) |
0

上一篇:Imp和exp

下一篇:Oracle专家调优秘密

给主人留下些什么吧!~~