原来的oracle数据库服务器运行在hp dl388g7服务器上面,内存32g,由于业务增长,内存吃紧,加上时不时出现服务器硬件故障,由于是
项目背景:
原来的oracle数据库服务器运行在hp dl388g7服务器上面,内存32g,由于业务增长,内存吃紧,加上时不时出现服务器硬件故障,由于是单实例单服务器,存在单点发现,于是打算采取一些措施改善一下:
1)升级服务器内存
2)并搭建服务器操作系统级别的双机
3)迁移数据库数据到新服务器
前面已经写过数据迁移相关的文章,题目为“exp/imp迁移数据”,链接如下:
前面已经写过数据迁移相关的文章,题目为“suse linux ha双机搭建”,链接如下:
————————————————————————————————————————————
如果你的系统业务量加大,数据库服务器的压力加大,需要物理主机加内存,应该加多少,需要如何调整参数?本文教你一步一步做。
1 理论方法需要调整的参数包括sga, pga, process,session数值,还有内核参数中的shmall,shmmax。
1.1 sga和pga的计算方法
sga=物理内存总和*50%
pga=物理内存总和*20%
剩下的30%留给操作系统使用。如果内存资源比较紧张,需要考虑成本的系统,如果数据库压力也并不大的话,其实可以将sga和pga的大小都设置得小一些,一点一点做调整。比如将物理内存的20%分配给sga,将5%分配给pga,然后根据实际情况做调整即可。
1.2 内核参数设置计算方法解释一下内核中shmall,shmmax这俩参数的设置方法:
shmmax
shmall>=sga(g)*1024*1024*1024/page_size
这里推荐大家直接使用sga和pga的和来计算比较好。
page_size可以通过如下命令查询:
getconf page_size
shmmax是指单个共享内存段的最大值,单位为bytes,就是俗称的b. 一般推荐为物理内存的一半,可以稍微大点,我喜欢设置为sga和pga的和的大小。
shmall=sga(g)/page_size(bytes)=sga(g)*1024*1024*1024/page_size, 比如sga大小为22g,page_size=4kb=4096bytes,那么shmall=22*1024*1024*1024bytes/4096bytes=5767168
shmall是指共享内存页面的总数目,共享内存你可以连接为sga,因为对oracle来说,pga是不共享的,好吧就当我说的废话。
页面的大小一般情况下是4kb,单位是bytes,通过命令get page_size查到的数值一般都是4096bytes
总结:要注意单位,shmmax指的是内存值,有单位,单位是bytes,page_size的单位为bytes,shmall无单位,它只是一个数目,表示页面数量。
单位换算表:
1 byte (b) = 8 bits (b) 字节=8个二进制位
1 kilobyte(k/kb)=2^10 bytes=1,024 bytes 千字节
1 megabyte(m/mb)=2^20 bytes=1,048,576 bytes 兆字节
1 gigabyte(g/gb)=2^30 bytes=1,073,741,824 bytes 千兆字节
1 terabyte(t/tb)=2^40 bytes=1,099,511,627,776 bytes吉字节
2 操作实例2.1收集数据库内存分配现状# free -m
total used free shared buffers cached
mem: 32096 29072 3024 0 49 22406
-/+ buffers/cache: 6616 25480
swap: 32765 847 31918
su - oracle
sqlplus / as sysdba
sql*plus: release 10.2.0.5.0 - production on fri mar 29 16:09:42 2013
copyright (c) 1982, 2010, oracle. all rights reserved.
connected to:
oracle database 10g enterprise edition release 10.2.0.5.0 - 64bit production
with the partitioning, olap, data mining and real application testing options
sql> show parameter sga
name type value
------------------------------------ ----------- ------------------------------
lock_sga boolean false
pre_page_sga boolean false
sga_max_size big integer 8000m
sga_target big integer 8000m
sql> show parameter pga
name type value
------------------------------------ ----------- ------------------------------
pga_aggregate_target big integer 5606m
sql> show parameter processes
name type value
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 0
db_writer_processes integer 8
gcs_server_processes integer 0
job_queue_processes integer 10
log_archive_max_processes integer 2
processes integer 900
sql> show parameter sessions
name type value
------------------------------------ ----------- ------------------------------
java_max_sessionspace_size integer 0
java_soft_sessionspace_limit integer 0
license_max_sessions integer 0
license_sessions_warning integer 0
logmnr_max_persistent_sessions integer 1
sessions integer 995
shared_server_sessions integer
,