成为MySQL DBA后,再看ORACLE数据库(八、进程、连接与会话)
不同于MySQL的单进程多线程架构,ORACLE是多进程架构。一个ORACLE实例主要有以下三类进程:1.后台进程,这些进程随数据库启动而启动,用于完成数据库的各种后台任务;2.服务器进程(server process),这些进程一般由客户端的请求产生,根据客户端的请求完成工作;3.从属进程,这些进程类似后台进程,它们代表后台进程或服务器进程执行一些额外的工作。
一、后台进程
在操作系统上ps -ef | grep ora可以看到ORACLE的很多后台进程比如ora_pmon_orcl、ora_dbw0_orcl等,这些都是Oracle的后台进程,一般常见的后台进程有以下几个:
ARCn 归档进程,用于将redolog写到归档日志。
CJQ0 作业队列协调程序进程。
CKPT 检查点进程,将检查点信息写入控制文件和数据文件头。
DBRM 数据库资源管理器进程,设置资源计划以及执行其它资源管理器任务。
DBWn 数据写进程,将缓冲区高速缓存中的数据写入数据文件。
DIA0 诊断进程,负责检测挂起和解决死锁,触发DIAG以执行诊断任务。
DIAG 诊断捕获进程。
FBDA 闪回数据归档进程。
LGWR 日志写进程,将日志缓冲区写出到重做日志中。
MMAN 内存管理器进程。
PMON 进程监视器进程,并恢复失败的进程资源。
SMON 系统监视器进程
Pnnn 并行查询从属进程,负责并行查询操作
ASMB ASM后台进程
GMON ASM磁盘组监视器进程
RMSn RAC管理进程
DMON dataguard代理监视器进程
在ORACLE中可以通过v$bgprocess视图查询关于后台进程的信息。其中PADDR列代表进程的内存地址,没有启动的后台进程PADDR列为00。
二、服务器进程
服务器进程是指当用户连接到Oracle服务器时,在Oracle服务器上会启动一个与用户进程对应的进程来为用户进程服务。执行命令ps -ef | grep oracleorcl可以看到当前有2个服务器进程,LOCAL为yes或no代表了是否为本地连接。
在ORACLE中,一般通过v$process视图查询进程信息,当然这个视图也包括了后台进程。v$process的查询输出中,spid列代表的就是操作系统上的进程号,通过spid可以将进程从操作系统到数据库关联起来。addr字段代表的是进程的地址,进程的状态等信息在内存中记录,这个addr记录的正是这样的内存地址信息。在v$session视图中记录的paddr对应的就是v$process.addr,通过两者关联,可以向数据库进一步深入。background列标识是否为后台进程,系统后台进程为1,非后台进程为null。
三、连接与会话
在ORACLE中,连接并不完全等价于会话,下图说明了ORACLE中连接与会话的关系:
在ORACLE中,通过v$session视图查询会话信息,其中sid为会话的id号,serial#为会话的序列号,和sid一起来标识唯一一个会话。status代表会话的状态,状态为active表示当前正在执行sql语句,为inactive表示等待执行的状态,为killed表示终止。
以下是常用会话管理的sql语句,其中杀会话一般要加上immediate参数,这样才能够立即释放会话所持有的资源。此外,也可以找到对应操作系统的spid,kill对应的进程,kill前需要谨慎确认。
#查询当前用户连接信息
select s.osuser os_user_name, p.program oracle_process, status session_status,s.terminal terminal, s.program program,
s.username user_name, s.fixed_table_sequence activity_meter, s.sid, s.serial# serial_num from v$session s, v$process p
where s.paddr=p.addr and s.type = 'USER' order by s.username, s.osuser;
#查询会话对应的OS进程号
select b.sid, b.serial#, c.spid from v$session b, v$process c where b.paddr = c.addr;
#杀会话
alter system kill session 'sid,serial#' immediate;
在ORACLE中对连接数限制的参数主要由processes和sessions完成,其中processes参数限制了能够连接到SGA的操作系统进程数,包括所有的后台进程与服务器进程。而sessions参数限制了一个实例中允许的会话数,即能同时登录到数据库的并发用户数。sessions的值是根据processes的值计算得到的,所以一般情况下只需要设置processes的值即可:sessions = (1.5 * processes) + 22。sessions这种参数在ORACLE中也称为推导参数,通常不需要修改,如果强制修改,那么修改值会覆盖推导值。