ORA-00064 processes設置過大導致數據庫打不開

processes設置過大導致數據庫打不開

在processes設置過大後,可能導致數據庫打不開,開啓數據庫後會報錯:

SQL> startup

ORA-00064: object is too large to allocate on this O/S (1,7746920)

SQL>

解決辦法:

  1. 首先找到pfile位置,然後從pfile啓動數據庫;

    startup pfile=$ORACLE_BASE/admin/SID/pfile/init.ora.49201715235'

    pfile一般在$ORACLE_BASE/admin/$ORACLE_SID/pfile目錄下。

  2. 找到spfile位置。然後用spfile生成pfile;

    create pfile='/tmp/pfile.ora' from spfile='+DATADG/SID/spfileSID.ora'

    spfile文件位置會在文件$ORACLE_HOME/dbs/init${ORACLE_SID}.ora文件中標明。

  3. 修改新生成的pfile,把process值改小後,用pfile生成spfile;

    create spfile='+DATADG/SID/spfileSID.ora' from pfile='/tmp/pfile.ora';

  4. 重啓數據庫後執行 show parameter spfile,查看當前spfile位置,如果位置和 $ORACLE_HOME/dbs/init${ORACLE_SID}.ora文件中標明的位置不一致,請把當前的spfile別名後,重新啓動數據庫。

解決步驟示例:

  1. 查看spfile的位置

[oracle@kdb01 ~]$   more /opt/oracle/product/10.2.0/db_1/dbs/initkhadb1.ora

SPFILE='+MYDATA/khadb/spfilekhadb.ora'
  1. 用spfile生成pfile

SQL>

SQL> startup

ORA-00064: object is too large to allocate on this O/S (1,7746920)

SQL> startup pfile='/opt/oracle/admin/khadb/pfile/init.ora.492017152117';

ORACLE instance started.

Total System Global Area  343932928 bytes

Fixed Size          2096152 bytes

Variable Size         113247208 bytes

Database Buffers      222298112 bytes

Redo Buffers            6291456 bytes

Database mounted.

Database opened.

SQL>

SQL> show parameter spfile;

NAME                     TYPE    VALUE

------------------------------------ ----------- ------------------------------

spfile                   string

SQL>

SQL> create pfile='/tmp/pfile.ora' from SPFILE='+MYDATA/khadb/spfilekhadb.ora';

File created.
  1. 修改新生成的pfile,把process值改小後,用pfile生成spfile

wKiom1kehK3h21sZAAAhpXYQ8_o151.png-wh_50

SQL> create SPFILE='+MYDATA/khadb/spfilekhadb.ora' from pfile='/tmp/pfile.ora';

File created.
  1. 重啓數據庫,查看processes設置

SQL> shutdown immediate

Database closed.

Database dismounted.

ORACLE instance shut down.

SQL> startup

ORACLE instance started.

Total System Global Area  343932928 bytes

Fixed Size          2096152 bytes

Variable Size         142607336 bytes

Database Buffers      192937984 bytes

Redo Buffers            6291456 bytes

Database mounted.

Database opened.

SQL> show parameter processes;

NAME                     TYPE    VALUE

------------------------------------ ----------- ------------------------------

aq_tm_processes              integer     0

db_writer_processes          integer     1

gcs_server_processes             integer     1

job_queue_processes          integer     10

log_archive_max_processes        integer     2

processes                integer     1000

SQL>

SQL> show parameter spfile;

NAME                     TYPE    VALUE

------------------------------------ ----------- ------------------------------

spfile                   string  +MYDATA/khadb/spfilekhadb.ora

SQL>

原因分析

當 PROCESSES > 1500時,候需要確保ksmg_granule_size=16M  or 32M;而ksmg_granule_size大小是根據sga_max_size來決定,當sga_max_size<=1024時,ksmg_granule_size=4M;sga_max_size是根據sga_target來決定的,修改sga_target>=1025M即可;

此處通過下面的方法,先恢復數據庫,後續可根據自己規劃先修改sga_target後,再修改process值

  1. alter system set sga_target=1200m scope=spfile

    修改sga_target=1200M,重啓數據庫時,sga_max_size=1200m;

    wKioL1kehR-Ab982AAAMD9ASuoA401.png-wh_50

  2. select x.ksppinm name,y.ksppstvl value,x.ksppdesc descbtion from x$ksppi x,x$ksppcv y where x.inst_id=userenv('Instance') and y.inst_id=userenv('Instance') and x.indx=y.indx and x.ksppinm like '%_ksmg_granule%';

    查看ksmg_granule_size大小。當SGA足夠大時,我們可以手動設置 _ksmg_granule_size=32MB;

    alter system set "_ksmg_granule_size"=33554432 scope=spfile;

    wKioL1kehPCjqBapAAAceMbS5zo288.png-wh_50

  3. 再根據自己的需求修process大小

      alter system set sessions=10000 scope=spfile;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章