DBWR进程
--查询dbwr进程号
select pname,spid from v$process where pname like 'DBW%';
PNAME SPID
----- ------------------------
DBW0 9776 ---查询的是操作系统的进程号
--linux 系统查询的进程号
[oracle@yang admin]$ ps -ef|grep ora_dbw |grep -v grep
UID PID PPID C STIME TTY TIME CMD
oracle 9776 1 0 Oct29 ? 00:00:02 ora_dbw0_yang
UID: 程序的用户所有者
PID : 程序的ID号
PPID:则是其上级父程序的ID
C : cpu的使用百分比
linux命令: ps ( process status进程状态的缩写)
参数a 显示所有程序(比-a更详细)-a显示同一个终端的所有程序
-A 显示所有进程 = -e 两者相同
-f 显示所有进程之间的关系
|grep ora_ --过滤查询显示ora_开头的文件, -v 查询的结果过滤(除去) grep 的字段
应用: ps -ef|grep ora_ =》查询linux下,所有Oracle正在使用的进程
[oracle@yang ~]$ ps -l
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD
4 S 1001 13677 13676 0 80 0 - 16518 wait pts/5 00:00:00 bash
0 R 1001 14133 13677 0 80 0 - 15878 - pts/5 00:00:00 ps
F- 4 代表进程权限root: 1 表示只能查询
S- S可以唤醒使用,R正在运行,D不能使用,T停止状态,Z僵尸进程
UID/PID/PPID 代表进程的拥有者老板,进程的身份证,进程的父亲管理者
C CPU使用率,百分比;
PRI/NI 进程被CPU执行的顺序优先级,小高;
ADDR/SZ/WCHAN: 运行显示-,使用多少内存,-表示工作中
TIME:使用CPU时间,实际花费CPU时间
CMD,启用进程时间
uix: ps uix --查询
--知道进程号的作用,linux系统操作强制关闭数据库:
Kill -9 dbw0_pid --杀死了进程
--查询dbwr进程的描述:
select paddr,name,description from v$bgprocess where name like 'DBW%';
PADDR NAME DESCRIPTION
---------------- ----- ------------------------------
00000000B5510FB0 DBW0 db writer process 0 (数据写进程)
00 DBW1 db writer process 1
---
00 DBW9 db writer process 9
00 DBWa db writer process 10 (a)
--
00 DBWy db writer process 34 (y)
00 DBWz db writer process 35 (z)
36 rows selected. 11.2.0.4版本,dbwr进程最多36个进程;此时只使用了一个dbw0
SQL> show parameter writer --查询数据库写进程数量,与上分对比发现,未启用的DBWN进程PADDR=‘00’
NAME TYPE VALUE
-----------------------------------
db_writer_processes integer 1
SQL> show parameter count --查询CPU个数
cpu_count integer 1
SQL> alter system set db_writer_processes=5 scope=spfile;
SQL> startup force
SQL> show parameter writer
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_writer_processes integer 5
SQL> select paddr,name,description from v$bgprocess where name like 'DBW%' and paddr not in '00';
--只有四条记录:
DBWN进程,数量收到CPU个数的限制,本次操作虽然参数改为5个,但是实际启用的进程数量为4;
一个CPU支持4个dbwn写进程
DBWR-是什么,是数据写进程,写什么? 将实例中的,buffer_cache中的脏块,写入database中的数据文件中,干活的是DBWR进程;
那么DBWR什么时候触发,什么时候写呢?
1.当数据库触发完全检查点的时候:
SQL> show parameter alert
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_checkpoints_to_alert boolean FALSE
SQL> alter system set log_checkpoints_to_alert=true; 修改参数后,生成的检查点会写入告警日志
System altered.
--触发检查点
alter system checkpoint;
show parameter dump=> tail -200f *.log
ALTER SYSTEM SET log_checkpoints_to_alert=TRUE SCOPE=BOTH;
Sun Oct 29 17:30:42 2017
Beginning global checkpoint up to RBA [0x33.c38.10], SCN: 1568364
Completed checkpoint up to RBA [0x33.c38.10], SCN: 1568364
疑问有个增量检查点,是什么呢?
SQL> alter system checkpoint;
Beginning global checkpoint up to RBA [0x33.c38.10], SCN: 1568364
Completed checkpoint up to RBA [0x33.c38.10], SCN: 1568364
SQL> alter system switch logfile;
Beginning log switch checkpoint up to RBA [0x34.2.10], SCN: 1568383
Thread 1 advanced to log sequence 52 (LGWR switch)
什么是实例恢复:从最近的一个完全检查点作为启始点,前滚走到数据库崩溃的最后一个日志记录的SCN;
然后回滚利用UNDO删除未提交的事务;
如果完全检查点半年触发,半年后数据库崩了,实例恢复,前滚应用半年日志吗?
是不是很傻,整理了一个增量检查点的概念,为啥要增量检查点,减少实例恢复的时间;
增量和完全的区别在哪? 完全检查点一致性,Buffer_cache中的所有脏块,立刻马上全部写入磁盘,对磁盘IO压力山大;
而增量检查点的触发条件是,切换日志组,可能几个小时就切换一次;
增量的检查点做了哪些操作,第一,找到现在的SCN号,做一条红线,将SCN小的所有脏块,记录一下,放到Buffer_cache的脏块列表中(已数据对象为间隔的脏列表中,所以移动整理消耗不会太大),每隔3S时间,就去检查一下是不是有脏块写入数据文件了,写入了打个勾,红线越来越退后,直到没有这个红线,工作完成,只是记录,不主动触发写进程,实例崩溃也会找最近的增量检查点没有必要找完全检查点了;
2.buffer_cache空间不够,新的查询数据块在Buffer_cache中寻找空闲的数据块少,不够,触发写进程,空出内存;
3.脏块太多,溢出,空闲块太少
SQL> select kvittag,kvitval,kvitdsc from x$kvit where kvittag in('kcbldq','kcbfsp');
KVITTAG KVITVAL KVITDSC
---------- ------- ------------------------------------------------------------
kcbldq 25 large dirty queue if kcbclw reaches this ---如果脏块数量的百分比达到了25%,就会触发DBWN写进程
kcbfsp 40 Max percentage of LRU list foreground can scan for free---SERVER PROCESS进程拿着物理块,扫描了百分之40的LRU链还是没找到足够的空闲块,DBWR触发
4.dbwr规定内的间隔时间 3S
5.RAC节点释放空间
6.表空间OFFLINE.READ ONLY,热备份begin backup;
7表的DROP,TRUNCATE的操作都会触发DBWN进程,脏块写入数据文件
DBWR进程的更多相关文章
- 【Oracle】-【体系结构】-【DBWR】-DBWR进程相关理解
对DBWR的一些理解 首先从名称上,DBWR全称是Database Writer Process,属于Oracle后台进程的一种,有的地方也叫DBWn,我想这里是出于DBWR进程个数的原因,DBWR进 ...
- Oracle 后台进程(二)DBWR进程
一.DBWR进程介绍 DBWR进程执行将数据块缓冲区写入数据文件的工作,是负责缓冲存储管理的一个Oracle后台进程.在修改DB Cache中的某个缓冲区时,会将它标志为“DIRTY”,DBWR的主要 ...
- Oracle DBWR,LGWR,CKPT,ARCH 触发条件 总结
一. DBWR写磁盘数据触发条件 1. 当进程在辅助LRU链表和主LRU链表上扫描以查找可以覆盖的buffer header[空闲缓冲区]时,如果已经扫描的buffer header的数量到达一定的 ...
- oracle进程
http://blog.csdn.net/leshami/article/details/5529239 Oracle实例和Oracle数据库(Oracle体系结构) 几类进程:用户进程,服务进程,后 ...
- 修改dbwr后台进程数量
批量执行脚本时,批量数据写回到数据库:从EM中查看到有较多的dbwr的IO请求 查看后台dbwr的进程数量 select * from v$bgprocess 在查询结果中paddr的字段为非'0 ...
- Oracle CheckPoint进程
在实例经过分配内存结构,加载控制文件后,然后要打开数据库的时候,需要做到控制文件,数据文件,联机重做日志保持相互状态一致性,数据库才可以打开.当数据库发生实例不正常关闭时(比如系统掉电或者Shutdo ...
- ORA-00471: DBWR process terminated with error案例
每年年底,系统管理员都要组织一次容灾方案的测试.演练.会在一个与生产环境网络隔离的DR环境中,启动各个"生产环境服务器",然后让各路人员参与其中测试.演练容灾方案是否可靠.这次演练 ...
- Oracle体系结构之Oracle10gR2体系结构-内存、进程
oracle体系结构图1 oracle体系结构图2 用户进程(访问oracle的客户端的总称) 工具的使用:sqlplus.pl/sql developer 如何访问数据库: 本机直接通过sock方式 ...
- Oracle 常见进程
1 服务器进程 专用服务器连接:数据连接跟服务器上的一个进程之间存在1:1的映射 共享服务器连接:多个会话共享一个服务器进程池,由一个调度程序分配 1.1 专用服务器连接 专用服务器连接模式下,客户连 ...
随机推荐
- python 获取指定文件夹的大小
def getdirsize(dirpath): size = for root, dirs, files in os.walk(dirpath): size += sum([getsize(join ...
- 安装gcc4.8.5
安装gcc4.8.51. g++ --version, 4.4.7不支持c++112. 升级gcc-c++, 下载gcc https://gcc.gnu.org/ 官网,镜像下载地址https: ...
- Codeforces 912E - Prime Gift
912E - Prime Gift 思路: 折半枚举+二分check 将素数分成两个集合(最好按奇偶位置来,保证两集合个数相近),这样每个集合枚举出来的小于1e18的积个数小于1e6. 然后二分答案, ...
- js如何创建JSON对象
js如何创建JSON对象 一.总结 一句话总结:直接创建js数组和js对象即可,然后JSON.stringify就可以获取json字符串,js中的一切都是对象,而且js中的对象都是json对象 js ...
- Myeclipse2016安装Aptana
Myeclipse2016安装Aptana 想装个Aptana,装了半天,网上说的什么links方式啊,在线方式啊,都是什么的浮云. 所以自己来写个安装教程. 一.Aptana简要介绍 Aptana有 ...
- Java基础八--构造函数
Java基础八--构造函数 一.子父类中构造函数的特点 1.1 为什么在子类构造对象时,发现,访问子类构造函数时,父类也运行了呢? 原因是:在子类的构造函数中第一行有一个默认的隐式语句. super( ...
- WPF 元素的查找
预设置元素名字 WPF有两种方式设置元素的Name <StackPanel x:Name="panel"> <Label Name="name1&quo ...
- 20170624xlVBA正则分割分类汇总
Sub RegExpSubtotal() '声明变量 Dim Regex As Object '正则对象 Dim Dic As Object '字典对象 Dim Key As String '关键字 ...
- 关于"架构"
杨光辉说,在构架系统的早期可能不会更多地考虑架构,主要是在做技术选型,首先是编程语言的选择.对于编程语言选择,当前主流编程语言有很多,有面向对象语言.传统式语言等.做这个选择主要根据人员知识储备,包括 ...
- Python在七牛云平台的应用(二)图片瘦身
(一)七牛云平台的图片瘦身功能简介:(引用自官网) 针对jpeg.png格式图片 瘦身后分辨率不变,格式不变. 肉眼画质不变. 图片体积大幅减少,节省 CDN 流量 官网给的图片压缩率很高,官网给的「 ...