Oracle ora-12518錯誤

原因是:團隊成員增多,原有數據庫設置不夠用,導致連接plsql和啓動tomcat時經常拋出“無法分發客戶端連接”的異常。

解決方案:
第一步:調整process和session值
1. 檢查process和session是否夠用。
a)使用plsql連接到oracle,查看process進程數:
select count(*) from v$process; --取得數據庫目前的進程數。
select value from v$parameter where name = 'processes';     --取得進程數的上限。
b)查看session會話數:
select count(*) from v$session; --取得數據庫目前的會話數。
select value from v$parameter where name = 'sessions'; --取得會話數的上限。
查看當前process和sessions是否接近上限值。若接近,可以將其增大。
2. 調整這兩個參數值大小。
系統進程數process和系統會話數session之間存在一個關係:
process數=session數*1.1+5
我們在配置時參考該規律進行設定。
a)  修改process值
alter system set processes=1000 scope=spfile;   --將process值改爲1000
b)  修改session值
alter system set sessions=1105 scope=spfile;    --將sessions值改爲1105
3. 備份pfile,重啓oracle
a) 修改完成後,備份pfile
create pfile from spfile;           --從spfile(運行時配置)創建pfile(系統配置)
c)  重啓oracle
重啓的方法有很多種,可以重啓oracle服務,或者重啓數據庫。Windows下可以直接重啓服務。
第二步:修改dispatchers個數
如果第一步解決不了問題。可以進行第二步的操作。
查看當前dispatchers個數,和dispatchers使用率
select name,busy,status,accept,idle from v$dispatcher;  --查看當前dispatchers個數和部分信息。一般默認安裝的庫只有一個。
select name,(busy/(busy+idle))*100 "busy rate%" from v$dispatcher; --查看dispatchers使用率
如果使用率大於50%,則要考慮增加dispatchers個數。
調整dispatchers個數
alter system set dispatchers='(protocol=tcp)(dispatchers=3)(service=youroracleservicenameXDB)';
--修改dispatchers個數爲3.
3. 重啓oracle。
常見問題處理辦法:
在配置時,有時我們會誤操作。導致數據無法正常啓動。這時可以從之前備份過的pfile來恢復oracle系統設置。
sqlplus /nolog   --連接到數據庫
出現連接提示光標
SQL> conn / as sysdba    --以windows用戶以sysdba身份登錄,便於操作數據庫
SQL> create spfile from pfile= 'D:\pfile.ora'    --從D:\pfile.ora(之前備份出來的pfile文件)創建系統配置信息。
將提示創建文件成功。
這時,啓動數據庫即可
SQL> startup

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