Oracle11g修改MEMORY_TARGET

Hoegh發表於2015-07-20

    預設情況下,Oracle 11g是使用AMM(Automatic Memory Management,自動記憶體管理)的。我們在安裝資料庫過程中,指定Oracle使用記憶體的百分比,這個取值就作為MEMORY_TARGET和MEMORY_MAX_TARGET的初始取值使用。如果這兩個引數設定為非零取值,那麼Oracle就是採用AMM管理策略的。
    下面演示一下如何修改MEMORY_TARGET的值。

1.測試環境
我們在Oracle11g中進行操作。


點選(此處)摺疊或開啟

  1. SQL>
  2. SQL> select * from v$version;

  3. BANNER
  4. --------------------------------------------------------------------------------

  5. Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - Production
  6. PL/SQL Release 11.2.0.3.0 - Production
  7. CORE 11.2.0.3.0 Production
  8. TNS for Linux: Version 11.2.0.3.0 - Production
  9. NLSRTL Version 11.2.0.3.0 - Production

  10. SQL>


2.檢視MEMORY_TARGET和相關引數值

我們通過show parameter來檢視初始化引數值,其他相關的引數包括MEMORY_MAX_TARGET、sga_max_size、sga_target、pga_aggregate_target等。

點選(此處)摺疊或開啟

  1. SQL>
  2. SQL> show parameter memory
  3.     
  4. NAME TYPE VALUE
  5. ------------------------------------ ----------- ------------------------------

  6. hi_shared_memory_address integer 0
  7. memory_max_target big integer 500M
  8. memory_target big integer 400M
  9. shared_memory_address integer 0
  10. SQL>
  11. SQL> show parameter sga

  12. NAME TYPE VALUE
  13. ------------------------------------ ----------- ------------------------------

  14. lock_sga boolean FALSE
  15. pre_page_sga boolean FALSE
  16. sga_max_size big integer 500M
  17. sga_target big integer 0
  18. SQL>
  19. SQL> show parameter pga

  20. NAME TYPE VALUE
  21. ------------------------------------ ----------- ------------------------------

  22. pga_aggregate_target big integer 0
  23. SQL>
    我們看到,資料庫的MEMORY_MAX_TARGET為500M,MEMORY_TARGET為400M。

3.修改MEMORY_TARGET

    我們通過alter system語句來修改MEMORY_TARGET,需要注意的是,MEMORY_TARGET是個動態引數,而MEMORY_MAX_TARGET是個靜態引數。
    這樣一來,當修改值<=MEMORY_MAX_TARGET時,我們可以隨意修改MEMORY_TARGET值;但是,當修改值>MEMORY_MAX_TARGET時,我們必須首先修改MEMORY_MAX_TARGET引數值,重啟資料庫使靜態引數生效後再去修改MEMORY_TARGET值,否則,資料庫會報錯。


3.1修改值<=MEMORY_MAX_TARGET
嘗試MEMORY_TARGET引數值由400M修改為500M

點選(此處)摺疊或開啟

  1. SQL>
  2. SQL> alter system set memory_target=500m;

  3. System altered.

  4. SQL>
  5. SQL>
  6. SQL> show parameter memory

  7. NAME TYPE VALUE
  8. ------------------------------------ ----------- ------------------------------

  9. hi_shared_memory_address integer 0
  10. memory_max_target big integer 500M
  11. memory_target big integer 500M
  12. shared_memory_address integer 0
  13. SQL>

3.2修改值>MEMORY_MAX_TARGET
   
我們嘗試將MEMORY_TARGET引數值由500M修改為700M。由於修改值>MEMORY_MAX_TARGET,資料庫會報錯;我們必須首先修改MEMORY_MAX_TARGET引數值,重啟資料庫使靜態引數生效後再去修改MEMORY_TARGET值。

點選(此處)摺疊或開啟

  1. SQL>
  2. SQL> alter system set memory_target=600m;
  3. alter system set memory_target=600m
  4. *
  5. ERROR at line 1:
  6. ORA-02097: parameter cannot be modified because specified value is invalid
  7. ORA-00837: Specified value of MEMORY_TARGET greater than MEMORY_MAX_TARGET


  8. SQL>
  9. SQL> alter system set memory_max_target=800m scope=spfile;

  10. System altered.

  11. SQL> shu immediate
  12. Database closed.
  13. Database dismounted.
  14. ORACLE instance shut down.
  15. SQL>
  16. SQL> startup
  17. ORACLE instance started.

  18. Total System Global Area 732352512 bytes
  19. Fixed Size 1347456 bytes
  20. Variable Size 603979904 bytes
  21. Database Buffers 121634816 bytes
  22. Redo Buffers 5390336 bytes
  23. Database mounted.
  24. Database opened.
  25. SQL>
  26. SQL> show parameter memory

  27. NAME TYPE VALUE
  28. ------------------------------------ ----------- ------------------------------

  29. hi_shared_memory_address integer 0
  30. memory_max_target big integer 700M
  31. memory_target big integer 500M
  32. shared_memory_address integer 0
  33. SQL>
  34. SQL> alter system set memory_target=600m;

  35. System altered.

  36. SQL> show parameter memory

  37. NAME TYPE VALUE
  38. ------------------------------------ ----------- ------------------------------

  39. hi_shared_memory_address integer 0
  40. memory_max_target big integer 700M
  41. memory_target big integer 600M
  42. shared_memory_address integer 0
  43. SQL>
  44. SQL>

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30162081/viewspace-1742293/,如需轉載,請註明出處,否則將追究法律責任。

相關文章