Oracle修改数据库SGA和PGA的大小

Oracle修改数据库SGA和PGA的大小

1、解决oracle乱码问题:
vi ~/.bashrc
export LANG=en_US.UTF-8
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

退出之后就不再显示乱码问题。

2、设置参数大小

查看PGA和SGA信息:

SQL>show parameter sga;
SQL>show parameter pga;
Login via sysdba, e.g sqlplus / as sysdba
       SQL> alter system set sga_max_size=25g scope=spfile;  ##replace 8g as the maximum memory can be assigned to Oracle
       SQL> alter system set sga_target=25g scope=spfile;    ##replace 8g same as sga_max_size above.
       SQL> alter system set optimizer_index_cost_adj=10 scope=spfile;
       SQL> alter system set pga_aggregate_limit=19g scope=spfile;

SQL> alter system set pga_aggregate_target=9g scope=spfile;

       SQL> shutdown immediate;
       SQL> startup;
SQL> execute dbms_stats.gather_schema_stats(ownname=>'windchill', cascade=>true);  
####收集Oracle统计的命令,可能要跑几个小时。要替换oracle_user成为用户真正的WindchillOracle用户名。

注意,重启前一定先完成上述两部操作,且sga_target不得大于sga_max_size,一般保持两者相等,否则可能导致数据库无法启动。

3、其中如果SPfile坏掉了之后,需要从初始化ora文件来创建

## 不确定是否可以成功使用,当时创建失败了
CREATE SPFILE FROM PFILE = '/opt/oracle/product/19c/dbhome_1/dbs/init.ora';

4、oracle SGA与PGA区别:

SGA:是用于存储数据库信息的内存区,该信息为数据库进程所共享。它包含Oracle 服务器的数据和控制信息,它是在Oracle服务器所驻留的计算机的实际内存中得以分配,如果实际内存不够再往虚拟内存中写。
PGA:包含单个服务器进程或单个后台进程的数据和控制信息,与几个进程共享的SGA 正相反,PGA 是只被一个进程使用的区域,PGA 在创建进程时分配,在终止进程时回收。

Oracle的内存,从总体上讲,可以分为两大块:共享部分(主要是SGA)和进程独享部分(主要是PGA和UGA)。而这两部分内存里面,根据功能不同,还分为不同内存池(Pool)和内存区(Area)

5、内存结构=SGA(系统全局区)+PGA(程序全局区)

我们重点就是设置SGA,理论上SGA可占OS系统物理内存的1/2——1/3
原则:SGA+PGA+OS使用内存<总物理RAM
SGA=((db_block_buffers*blocksize)+(shared_pool_size+large_pool_size+java_pool_size+log_buffers)+1MB
1、SGA系统全局区.(包括以下五个区)
A、数据缓冲区:(db_block_buffers)存储由磁盘数据文件读入的数据。
大小: db_block_buffers*db_block_size
Oracle9i设置数据缓冲区为:Db_cache_size
原则:SGA中主要设置对象,一般为可用内存40%。
B、共享池:(shared_pool_size):数据字典,sql缓冲,pl/sql语法分析.加大可提速度。
原则:SGA中主要设置对象,一般为可用内存10%
C、日志缓冲区:(log_buffer)存储数据库的修改信息.
原则:128K ---- 1M 之间,不应该太大
D 、JAVA池(Java_pool_size)主要用于JAVA语言的开发.
原则:若不使用java,原则上不能小于20M,给30M通常就够了
E、 大池(Large_pool_size) 如果不设置MTS,主要用于数据库备份恢复管理器RMAN。
原则:若不使用MTS,5---- 10M 之间,不应该太大
SGA=. db_block_buffers*db_block_size+ shared_pool_size+ log_buffer+Java_pool+size+large_pool_size

默认值配置关系:‌如果设置了MEMORY_TARGET参数,‌那么PGA_AGGREGATE_LIMIT等于MEMORY_MAX_TARGET的值。‌如果没有设置MEMORY_TARGET参数,‌那么PGA_AGGREGATE_LIMIT参数值是PGA_AGGREGATE_TARGET的2倍

转载于:

https://blog.csdn.net/weixin_62839327/article/details/134117029

修改oracle数据库SGA和PGA大小 - 耀阳居士 - 博客园 (cnblogs.com)

SGA和PGA的分配原则及更改大小 - melontree - 博客园 (cnblogs.com)

PGA内存分析:

ORACLE 19C版本PGA使用率告警问题分析处理_oracle11g oracle pga使用率-CSDN博客

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值