delete删除数据造成归档日志增加,操作系统空间不足导致数据库hang住
业务需求,对日志表历史数据进行清理。历史表均很大,使用delete 操作删除90天前的数据。
第一部分:快速删除数据
SQL> alter table CC.F_LOG parallel ;
SQL>alter session enable parallel dml;
SQL> delete FROM CC.F_LOG S WHERE S.CREATE_DATE>(SYSDATE-);
执行计划确定并行
-----------------------------------------------
| Id  | Operation                            | 
-----------------------------------------------
|   0 | DELETE STATEMENT                     | 
|   1 |  PX COORDINATOR                      | 
|   2 |   PX SEND QC (RANDOM)                | 
|   3 |    INDEX MAINTENANCE                 | 
|   4 |     PX RECEIVE                       | 
|   5 |      PX SEND RANGE                   | 
|   6 |       DELETE                         | 
|   7 |        BUFFER SORT                   | 
|   8 |         PX RECEIVE                   | 
|   9 |          PX SEND HASH (BLOCK ADDRESS)| 
|* 10 |           INDEX RANGE SCAN           | 
-----------------------------------------------
SQL> select INST_ID,sid,serial#,USERNAME,STATUS,MACHINE,SQL_ID,EVENT,(sysdate-LOGON_TIME)*86400 as "s",LAST_CALL_ET
from gv$session where status='ACTIVE' and username is not null;
INST_ID    SID SERIAL# USERNAME STATUS     MACHINE         SQL_ID               EVENT                           s LAST_CALL_ET
------- ------ ------- ------------------- --------------- -------------------- ------------------------------ ------- ------------
      1     24   44857 SYS      ACTIVE     p01        6yn37jfu2y88k        PX Deq Credit: send blkd           190          189
      1    584  28067 SYS      ACTIVE     p01        2ymxxw3mapxd9        SQL*Net message from client        196            0
      1    884  40483 SYS      ACTIVE     p01        6yn37jfu2y88k        PX Deq: Table Q Normal             190          189
      1    888   8663 SYS      ACTIVE     p01        6yn37jfu2y88k        PX Deq: Execute Reply             3679          212
      1   1157    9679  SYS      ACTIVE     p01        6yn37jfu2y88k        PX Deq: Table Q Normal             190          189
      1   1162   10801 SYS      ACTIVE     p01        6yn37jfu2y88k        direct path write temp             190          189
      1   1437   22187 SYS      ACTIVE     p01        6yn37jfu2y88k        PX Deq Credit: send blkd           190          189
      1   1728   17227 SYS      ACTIVE     p01        6yn37jfu2y88k        PX Deq Credit: send blkd           190          189
      1   1740   25759 SYS      ACTIVE     p01        6yn37jfu2y88k        PX Deq: Table Q Normal             190          189
9 rows selected.
删除完毕还原并行1
SQL> alter table CC.F_LOG parallel 1;
第二部分:数据删除hang
删除数据后发现,数据库会话数量越来越多,且delete操作session event
log file switch (archiving needed) 等待啥?需要等待日志切换归档完成? 为啥等待日志切换归档这么长时间? 观察alert
SQL> select INST_ID,sid,serial#,USERNAME,STATUS,MACHINE,SQL_ID,EVENT,(sysdate-LOGON_TIME)* as "s",LAST_CALL_ET
from gv$session where status='ACTIVE' and username is not null; INST_ID SID SERIAL# USERNAME STATUS MACHINE SQL_ID EVENT
------- ------ ------- -------------- ---------- -------------------- -------------------- ------------------------------
CXPT ACTIVE future-app1 fmmd0cjd0ghpf buffer busy waits
ac ACTIVE pfmptom01.yutong.com 6d7v2nay5vm9n log file switch (archiving needed)
ac ACTIVE pfmptom02.yutong.com 3dn60pvzrqz0g buffer busy waits
CXPT ACTIVE future-app1 azakfbj8ss7f8 buffer busy waits
ac ACTIVE pfmptom01.yutong.com 7nbhsah5kw0q2 log file switch (archiving needed)
SYSTEM ACTIVE ZZYT\YT-P610764 1xz9mk73crhu8 log file switch (archiving needed)
ac ACTIVE pfmptom02.yutong.com 3dn60pvzrqz0g buffer busy waits
ac ACTIVE pfmptom01.yutong.com d8ats3n1vrm7t enq: US - contention
ac ACTIVE pfmptom01.yutong.com 0jg5553p23hup enq: SQ - contention
CXPT ACTIVE future-app2 azakfbj8ss7f8 enq: US - contention
ac ACTIVE pfmptom02.yutong.com 3dn60pvzrqz0g buffer busy waits
ac ACTIVE pfmptom01.yutong.com btgxyzwsc5sd1 enq: US - contention
ac ACTIVE pfmpbak01 94cs4sv2zua0u log file switch (archiving needed)
ac ACTIVE pfmptom02.yutong.com 3dn60pvzrqz0g buffer busy waits
rows selected. 观察ALERT日志,可以发现归档日志无法创建报错
Examine archive trace files for archiving errors
  Current log# 8 seq# 41282 mem# 0: /oracle/oradata/fmpdb/redo08.log
Tue Aug 13 19:41:12 2019
ARC1: Encountered disk I/O error 19502
ARC1: Closing local archive destination LOG_ARCHIVE_DEST_1: '/oracle/archivelog/fmpdb_1_41278_961338832.log' (error 19502) (fmpdb)
ARC1: I/O error 19502 archiving log 4 to '/oracle/archivelog/fmpdb_1_41278_961338832.log'
ARCH: Archival stopped, error occurred. Will continue retrying
ORACLE Instance fmpdb - Archival Error
ORA-16038: log 4 sequence# 41278 cannot be archived
ORA-19502: write error on file "", block number  (block size=)
ORA-00312: online log 4 thread 1: '/oracle/oradata/fmpdb/redo04.log'
Tue Aug 13 19:41:13 2019
ARCH: Archival stopped, error occurred. Will continue retrying
ORACLE Instance fmpdb - Archival Error
ORA-16014: log 4 sequence# 41278 not archived, no available destinations
ORA-00312: online log 4 thread 1: '/oracle/oradata/fmpdb/redo04.log'
Tue Aug 13 19:44:28 2019
minact-scn: useg scan erroring out with error e:12751
Tue Aug 13 19:46:14 2019
ARC1: Encountered disk I/O error 19502
ARC1: Closing local archive destination LOG_ARCHIVE_DEST_1: '/oracle/archivelog/fmpdb_1_41278_961338832.log' (error 19502) (fmpdb)
ARC1: I/O error 19502 archiving log 4 to '/oracle/archivelog/fmpdb_1_41278_961338832.log'
ARCH: Archival stopped, error occurred. Will continue retrying
ORACLE Instance fmpdb - Archival Error
ORA-16038: log 4 sequence# 41278 cannot be archived
ORA-19502: write error on file "", block number  (block size=)
ORA-00312: online log 4 thread 1: '/oracle/oradata/fmpdb/redo04.log'
Tue Aug 13 19:46:14 2019
ARCH: Archival stopped, error occurred. Will continue retrying
ORACLE Instance fmpdb - Archival Error
ORA-16014: log 4 sequence# 41278 not archived, no available destinations
ORA-00312: online log 4 thread 1: '/oracle/oradata/fmpdb/redo04.log'
Tue Aug 13 19:49:35 2019
minact-scn: useg scan erroring out with error e:12751
Tue Aug 13 19:51:15 2019
ARC1: Encountered disk I/O error 19502
ARC1: Closing local archive destination LOG_ARCHIVE_DEST_1: '/oracle/ARC1: I/O error 19502 archiving log 4 to
'/oracle/archivelog/fmpdb_1_41278_961338832.log'
ARCH: Archival stopped, error occurred. Will continue retrying
ORACLE Instance fmpdb - Archival Error
ORA-16038: log 4 sequence# 41278 cannot be archived
ORA-19502: write error on file "", block number  (block size=)
ORA-00312: online log 4 thread 1: '/oracle/oradata/fmpdb/redo04.log'
ARCH: Archival stopped, error occurred. Will continue retrying
ORACLE Instance fmpdb - Archival Error
ORA-16014: log 4 sequence# 41278 not archived, no available destinations
ORA-00312: online log 4 thread 1: '/oracle/oradata/fmpdb/redo04.log'
Tue Aug 13 19:56:16 2019
Archiver process freed from errors. No longer stopped
Tue Aug 13 19:56:18 2019
Archived Log entry 41273 added for thread 1 sequence 41278 ID 0x67cfc4e dest 1:
krse_arc_driver_core: Successful archiving of previously failed ORL
Tue Aug 13 19:56:18 2019
Thread 1 advanced to log sequence 41283 (LGWR switch)
  Current log# 4 seq# 41283 mem# 0: /oracle/oradata/fmpdb/redo04.log
Tue Aug 13 19:56:18 2019
Some DDE async actions failed or were cancelled
Tue Aug 13 19:56:23 2019
Archived Log entry 41274 added for thread 1 sequence 41281 ID 0x67cfc4e dest 1:
Archived Log entry 41275 added for thread 1 sequence 41279 ID 0x67cfc4e dest 1:
Archived Log entry 41276 added for thread 1 sequence 41280 ID 0x67cfc4e dest 1:
Archived Log entry 41277 added for thread 1 sequence 41282 ID 0x67cfc4e dest 1:
Tue Aug 13 19:56:43 2019
Thread 1 advanced to log sequence 41284 (LGWR switch)
  Current log# 5 seq# 41284 mem# 0: /oracle/oradata/fmpdb/redo05.log
Tue Aug 13 19:56:45 2019
Archived Log entry 41278 added for thread 1 sequence 41283 ID 0x67cfc4e dest 1:
Tue Aug 13 19:57:10 2019
Thread 1 cannot allocate new log, sequence 41285
操作手工删除归档日志后,快速执行脚本压缩备份归档日志删除已备份的归档日志释放空间。 delete操作恢复且执行完毕后,对数据库立即进行全备份。
[root@pfmpodb01 ~]# df -h
Filesystem                                    Size  Used Avail Use% Mounted on
/dev/mapper/VolGroup00-LogVol00               297G  297G   0G  100% /
清理归档日志
[root@pfmpodb01 ~]# df -h
Filesystem                                    Size  Used Avail Use% Mounted on
/dev/mapper/VolGroup00-LogVol00               297G  271G   12G  97% /
压缩备份归档日志后删除日志
backup format '/oracle/dbbak/archbak_%d_%s_%p_%T' archivelog all delete input;
[root@pfmpodb01 archivelog]# df -h
Filesystem                                    Size  Used Avail Use% Mounted on
/dev/mapper/VolGroup00-LogVol00               297G  230G   52G  82% /
Resolving Issues Where 'log file switch (archiving needed)' Waits Occur Because Log has not yet been Archived (文档 ID 1476444.1) Problem Confirmation:
The time spent actively in the local database is significant
Only certain sessions, queries or jobs are experiencing slowness (not throughout the database)
Waits for 'log file switch (archiving needed)' are a significant component of DB Time
Free space in archive destination is less than redolog file size
Waits for 'log file switch (archiving needed)'
This wait event occurs when waiting for a log switch because the log we will be switching into has not been archived yet. Reducing Waits
Check the alert file to make sure that archiving has not stopped due to a failed archive write.
To speed archiving, consider adding more archive processes or putting the archive files on striped disks.
Check the archive log destination for space and make sure it is not full. If it is full, free up space.
delete删除数据造成归档日志增加,操作系统空间不足导致数据库hang住的更多相关文章
- Windows平台使用RMAN命令自动删除Oracle过期归档日志的方法
		自动删除Oracle过期归档日志的思路如下: 1.编写自动执行的bat脚本文件: 2.Windows设置定期执行计划 OracleArchLogClear.bat D:/Oracle/product/ ... 
- 什么?还在用delete删除数据《死磕MySQL系列 九》
		系列文章 五.如何选择普通索引和唯一索引<死磕MySQL系列 五> 六.五分钟,让你明白MySQL是怎么选择索引<死磕MySQL系列 六> 七.字符串可以这样加索引,你知吗?& ... 
- SQL中CRUD C——create 添加数据 R——read 读取数据 U——update 修改数据 D——delete 删除数据
		在SQL server中对数据库的操作: 删除表:drop table 表名修改表:alter table 表名 添加列add 列名 列类型alter table 表名 drop column 列名 ... 
- MySQL不建议delete删除数据
		InnoDB存储架构 从这张图可以看到,InnoDB存储结构主要包括两部分:逻辑存储结构和物理存储结构. 逻辑上是由表空间tablespace -> 段segment或者inode -> ... 
- Oracle闪回查询恢复delete删除数据
		Flashback query(闪回查询)原理 Oracle根据undo信息,利用undo数据,类似一致性读取方法,可以把表置于一个删除前的时间点(或SCN),从而将数据找回. Flashback q ... 
- Influx Sql系列教程七:delete 删除数据
		前面介绍了使用insert实现新增和修改记录的使用姿势,接下来我们看一下另外一个简单的使用方式,如何删除数据 1. delete 语句 delete的官方语法如下 DELETE FROM <me ... 
- 通过DataWorks数据集成归档日志服务数据至MaxCompute进行离线分析
		通过DataWorks归档日志服务数据至MaxCompute 官方指导文档:https://help.aliyun.com/document_detail/68322.html但是会遇到大家在分区上或 ... 
- 配置闪回恢复区开启归档,未配置清理归档脚本,数据库hang住
		问题现象,测试环境执行SQL hang住 enmo:/home/oracle/worksh dg.sh SQL*Plus: Release Production on Mon May :: Copyr ... 
- Mysql常用sql语句(24)- delete 删除数据
		测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 delete 也属于DML语句(数据操纵语句) ... 
随机推荐
- thymeleaf 直接调用后台Service
			前端thymeleaf <select name="sex" class="form-control m-b" th:with="type=${ ... 
- Solr 集成ikanalyzer
			Solr 不能对中文进行分词,ikanalyzer可以. ikanalyzer下载链接 1.下载 jar形式 2.放到D:\soft\solr-8.1.0\server\solr-webapp\web ... 
- git补充(关于pull request)转自知乎
			当你想更正别人仓库里的错误时,要走一个流程: 1先 fork 别人的仓库,相当于拷贝一份,不会有人直接让你修改原仓库的 2.clone 到本地分支,做一些 bug fix 3.发起 pull requ ... 
- maven中的Exclusions详解
			依赖关系:Project-A>Project-B>Project-C,但是Project-A不依赖Project-C,在Project-A中的POM.xml应该进行如下配置: <de ... 
- Java并发包线程池之Executors、ExecutorCompletionService工具类
			前言 前面介绍了Java并发包提供的三种线程池,它们用处各不相同,接下来介绍一些工具类,对这三种线程池的使用. Executors Executors是JDK1.5就开始存在是一个线程池工具类,它定义 ... 
- removeEntry
			void VCGantt::removeEntry() { QModelIndexList selectedIndexes = ganttViewCommon->selectionModel() ... 
- PostgreSQL学习笔记——摘要
			因为PostgreSQL和MySQL.DB2等数据库均遵循SQL语法,所以这篇随笔仅记录一些PostgreSQL中和别的数据库有差别或之前学习中遗漏的地方,以及一些我觉得比较重点的地方. 通过psql ... 
- 【Leetcode_easy】704. Binary Search
			problem 704. Binary Search solution: class Solution { public: int search(vector<int>& nums ... 
- iOS-UIScrollView+UIPageControl简单实现
			#import "MJViewController.h"#import "RootViewController.h" @interface MJViewCont ... 
- iOS技术面试07:第三方框架
			1ios框架分为:cocoa Touch:UIKit.Foundation.附属框架 Media:OpenGL ES.EAGL.Quartz.Core Animation.Core Audio. ... 
