sqlplus / as sysdba
sqlplus sys/midsoft@nyfy as sysdba
修改sga大小
1-1查看当前sga大小
SQL> show parameter sga
1-2修改sga_max_size为24G
SQL> alter system set sga_max_size=24G scope=spfile;
1-3修改sga_target为24G
SQL> alter system set sga_target=24G scope=spfile;
show parameter processes
show parameter sessions
alter system set processes=1000 scope=spfile
alter system set sessions=1105 scope=spfile
重点 : 两个文件由pfile创建spfile
spfileorcl 路径 D:\oracle\product\10.2.0\db_1\database (这个一定要备份,要不然 数据库启动不了有你哭的时候)
pfile 路径 D:\oracle\product\10.2.0\admin\orcl\pfile
pfile是系统二进制文件不可以修改
可以用下面方法恢复过来:
sqlplus /nolog
connect/ as sysdba
create spfile='D:\oracle\product\10.2.0\db_1\dbs\SPFILETESTING.ORA' from pfile='D:\oracle\product\10.2.0\admin\testing\pfile\init.ora.913200824649';
把SPFILETESTING.ORA' ,init.ora.913200824649'改成自己的。
1-4重启生效
SQL> shutdown immediate
SQL> startup
SQL> show parameter sga
修改pga大小
2-1查看当前pga大小
SQL> show parameter pga
2-2修改workarea_size_policy为AUTO
SQL> alter system set workarea_size_policy=auto scope=both;
SQL> show parameter workarea
2-3修改pga_aggregate_target为8G
SQL> alter system set pga_aggregate_target=8G scope=both;
pga为动态参数,不需要重启,修改完直接生效
SQL> show parameter pga
内存监控
3-1查看实际pga分配情况
SQL> SELECT * FROM V$PGASTAT;
aggregate PGA auto target
--当前可用于自动分配了的PGA大小,应该比PGA_AGGREGATE_TARGET 小
over allocation count
--实例启动后,发生的分配次数,如果这个值大于0,就要考虑增加pga的值
3-2查看sga和pga的使用情况
SQL> select name,total,round(total-free,2) used, round(free,2) free,round((total-free)/total*100,2) pctused from
(select 'SGA' name,(select sum(value/1024/1024) from v$sga) total,
(select sum(bytes/1024/1024) from v$sgastat where name='free memory')free from dual)
union
select name,total,round(used,2)used,round(total-used,2)free,round(used/total*100,2)pctused from (
select 'PGA' name,(select value/1024/1024 total from v$pgastat where name='aggregate PGA target parameter')total,
(select value/1024/1024 used from v$pgastat where name='total PGA allocated')used from dual);