重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
在UNIX或者LINUX中可以比較方便的管理ORACLE運行的進程,但在WINDOWS中ORACLE的每個會話是采用線程的機制進行管理,所以通過普通的任務管理器不能查看到具體的ORACLE用戶線程。
創新互聯10多年成都企業網站建設服務;為您提供網站建設,網站制作,網頁設計及高端網站定制服務,成都企業網站建設及推廣,對除甲醛等多個領域擁有豐富的網站運維經驗的網站建設公司。
當然,通過專用的線程管理工具是可以看到的,如WINDOWS附加工具箱中的Qslice(線程分析器)就可以。
查看ORACLE最大進程數:
SQL select count(*) from v$session #連接數
SQL Select count(*) from v$session where status='ACTIVE' #并發連接數
SQL show parameter processes #最大連接
SQL alter system set processes = value scope = spfile;重啟數據庫 #修改連接
unix 1個用戶session 對應一個操作系統 process
而 windows體現在線程
------------------------------------------------------------------------------
修改ORACLE最大進程數:
使用sys,以sysdba權限登錄:
SQL show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 150
SQL alter system set processes=300 scope = spfile;
系統已更改。
SQL show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 150
SQL create pfile from spfile;
文件已創建。
重啟數據庫,
SQL show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 300
查詢數據庫當前進程的連接數
select count(*) from v$process;
查看數據庫當前會話的連接數
elect count(*) from v$session;
查看數據庫的并發連接數
select count(*) from v$session where status= ACTIVE ;
查看當前數據庫建立的會話情況
select sid serial# username program machine status from v$session;
查詢數據庫允許的最大連接數
select value from v$parameter where name = processes ;
或者命令 show parameter processes;
修改數據庫允許的最大連接數
alter system set processes = scope = spfile;
(需要重啟數據庫才能實現連接數的修改)
重啟數據庫
SQLshutdown immediate;
SQLstartup;
查看當前有哪些用戶正在使用數據
SQLselect osuser a username cpu_time/executions/ || s sql_fulltext machine
SQLfrom v$session a v$sqlarea b
SQLwhere a sql_address = b address
SQLorder by cpu_time/executions desc;
備注 UNIX 個用戶session對應一個操作系統process 而Windows體現在線程
啟動oracle
su oracle
SQLsqlplus system/pwd as sysdba???? //進入sql
SQLstartup????????????????????????????????????? //啟動數據庫
SQLlsnrctl start?????????????????????????????? //啟動監聽
sqlplus /as sysdba
SQLshutdown immediate;? //關閉數據庫
SQLstartup mount;
lishixinzhi/Article/program/Oracle/201311/18867
1. 先通過top命令查看產用資源較多的spid號
2.查詢當前耗時的會話ID,用戶名,sqlID等:
select sid,serial#,machine,username,program,sql_hash_value,sql_id,
? to_char(logon_time,'yyyy/mm/dd hh24:mi:ss') as login_time from v$session
where paddr in (select addr from v$process where spid in ('5648612','256523'));
3. 如果上一步sql_id或者 hash_value不為空,則可用v$sqlarea查出當前正在使用的sql
select sql_text
from v$sqltext_with_newlines
where hash_value = hash_value
order by piece;
也可直接使用:
select a.*,b.SQL_TEXT from (
select sid,serial#,machine,username,program,sql_hash_value,sql_id,
? to_char(logon_time,'yyyy/mm/dd hh24:mi:ss') as login_time from v$session
where paddr in (select addr from v$process where spid in ('23226'))
) a,v$sql b
where a.sql_id? = b.SQL_ID(+)
4.kill占用大資源的session
Alter system kill session 'SID,SERIAL#'
解鎖:
1.查詢哪些對象被鎖:
select object_name,machine,s.sid,s.serial#
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;
2.下面的語句用來殺死一個進程:
alter system kill session '524,1095'; (其中24,111分別是上面查詢出的sid,serial#)
3.再一次查詢目前鎖定的對象,若發現以上方法不能解除鎖定的表,則用以下方法:
3.1 執行下面的語句獲得進程(線程)號:
select spid, osuser, s.program
from v$session s,v$process p
where s.paddr=p.addr and s.sid=524 (524是上面的sid)
windows里所有oracle事務統一由一個oracle.exe進程管理,pmon、smon等表現為oracle.exe內的線程。
linux系統里pmon、smon都是獨立的進程。
線程是進程的組成部分,進程中的資源由多個線程共享。你可以把它們想象成:
進程是老大,手上有的是鈔票、棍棒;
線程是他的小弟們,身無分文;
老大提供棍棒給小弟們出去辦事,辦事需要錢的時候由老大分配,小弟們搶來的鈔票歸老大統一支配。
1、連接上相應的linux主機,進入到等待輸入shell指令的linux命令行狀態下。
2、在命令行下輸入shell指令:whereis oracle。
3、最后,按下回車鍵執行shell指令,此時會看到數據庫oracle的具體位置被打印了出來。