ARCHIVER ERROR ORA-00354: CORRUPT REDO LOG BLOCK HEADER

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:
Problem Description: ORA-16038: log 2 sequence# 13831 cannot be archived ORA-00354: corrupt redo log block header ORA-00312: online log 2 thread 1: '/oradata/3/TOOLS/stdby_redo/srl1.log'
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
LOG FILE
---------------
Filename = alert_TOOLS5_from_1021.log
See ...
 
...
Wed Oct 28 11:41:59 2009
Primary  database  is  in  MAXIMUM AVAILABILITY mode
Standby controlfile consistent  with  primary
RFS[1]: Successfully opened standby log 1:  '/oradata/3/TOOLS/stdby_redo/srl0.log'
Wed Oct 28 11:42:00 2009
ARC0: Log corruption near block 604525 change 10551037679542  time  ?
Wed Oct 28 11:42:00 2009
Errors  in  file /tools/oracle/admin/TOOLS/bdump/tools_arc0_2143.trc:
ORA-00354: corrupt redo log block header
ORA-00353: log corruption near block 604525 change 10551037679542  time  10/28/2009 11:29:50
ORA-00312: online log 2 thread 1:  '/oradata/3/TOOLS/stdby_redo/srl1.log'
ARC0:  All  Archive destinations made inactive due  to  error 354
Wed Oct 28 11:42:00 2009
ARC0: Closing  local  archive destination LOG_ARCHIVE_DEST_2:  '/oradata/3/TOOLS/archive/dgarc/1_13831_635534096.arc'  (error 354)
(TOOLS)
Committing creation  of  archivelog  '/oradata/3/TOOLS/archive/dgarc/1_13831_635534096.arc'  (error 354)
ARCH: Archival stopped, error occurred. Will  continue  retrying
Wed Oct 28 11:42:05 2009
ORACLE Instance TOOLS - Archival Error
Wed Oct 28 11:42:05 2009
ORA-16038: log 2  sequence # 13831 cannot be archived
ORA-00354: corrupt redo log block header
ORA-00312: online log 2 thread 1:  '/oradata/3/TOOLS/stdby_redo/srl1.log'
Wed Oct 28 11:42:05 2009
Errors  in  file /tools/oracle/admin/TOOLS/bdump/tools_arc0_2143.trc:
ORA-16038: log 2  sequence # 13831 cannot be archived
ORA-00354: corrupt redo log block header
ORA-00312: online log 2 thread 1:  '/oradata/3/TOOLS/stdby_redo/srl1.log'
Wed Oct 28 11:43:04 2009
ARCH: Archival stopped, error occurred. Will  continue  retrying
Wed Oct 28 11:43:04 2009
ORACLE Instance TOOLS - Archival Error
Wed Oct 28 11:43:04 2009
Primary  database  is  in  MAXIMUM AVAILABILITY mode
Changing standby controlfile  to  RESYNCHRONIZATION  level
Wed Oct 28 11:43:04 2009
ORA-16014: log 1  sequence # 13832  not  archived,  no  available destinations
ORA-00312: online log 1 thread 1:  '/oradata/3/TOOLS/stdby_redo/srl0.log'
Wed Oct 28 11:43:04 2009
Errors  in  file /tools/oracle/admin/TOOLS/bdump/tools_arc1_2145.trc:
ORA-16014: log 1  sequence # 13832  not  archived,  no  available destinations
ORA-00312: online log 1 thread 1:  '/oradata/3/TOOLS/stdby_redo/srl0.log'
RFS[1]: Successfully opened standby log 2:  '/oradata/3/TOOLS/stdby_redo/srl1.log'
Wed Oct 28 11:43:13 2009
RFS[3]: Archived Log:  '/oradata/3/TOOLS/archive/dgarc/1_13831_635534096.arc'
Wed Oct 28 11:43:14 2009
RFS LogMiner: Registered logfile [/oradata/3/TOOLS/archive/dgarc/1_13831_635534096.arc]  to  LogMiner session id [4]
Wed Oct 28 11:43:15 2009
LOGMINER:  Begin  mining logfile  for  session 4 thread 1  sequence  13831, /oradata/3/TOOLS/archive/dgarc/1_13831_635534096.arc
Wed Oct 28 11:44:03 2009
RFS[3]: Archived Log:  '/oradata/3/TOOLS/archive/dgarc/1_13832_635534096.arc'
...
LOG FILE
---------------
Filename = alert_TOOLS6_from_1021.log
See ...
 
...
Wed Oct 28 11:16:01 2009
Thread 1 advanced  to  log  sequence  13830 (LGWR switch)
Current  log# 8 seq# 13830 mem# 0: /oradata/1/redo/TOOLS/redo1a.log
Current  log# 8 seq# 13830 mem# 1: /oradata/2/redo/TOOLS/redo1b.log
Current  log# 8 seq# 13830 mem# 2: /oradata/3/redo/TOOLS/redo1c.log
Wed Oct 28 11:29:50 2009
LGWR: Standby redo logfile selected  to  archive thread 1  sequence  13831
LGWR: Standby redo logfile selected  for  thread 1  sequence  13831  for  destination LOG_ARCHIVE_DEST_2
Wed Oct 28 11:29:50 2009
Thread 1 advanced  to  log  sequence  13831 (LGWR switch)
Current  log# 9 seq# 13831 mem# 0: /oradata/1/redo/TOOLS/redo2a.log
Current  log# 9 seq# 13831 mem# 1: /oradata/2/redo/TOOLS/redo2b.log
Current  log# 9 seq# 13831 mem# 2: /oradata/3/redo/TOOLS/redo2c.log
Wed Oct 28 11:41:59 2009
LGWR: Standby redo logfile selected  to  archive thread 1  sequence  13832
LGWR: Standby redo logfile selected  for  thread 1  sequence  13832  for  destination LOG_ARCHIVE_DEST_2
Wed Oct 28 11:41:59 2009
Thread 1 advanced  to  log  sequence  13832 (LGWR switch)
Current  log# 10 seq# 13832 mem# 0: /oradata/1/redo/TOOLS/redo3a.log
Current  log# 10 seq# 13832 mem# 1: /oradata/2/redo/TOOLS/redo3b.log
Current  log# 10 seq# 13832 mem# 2: /oradata/3/redo/TOOLS/redo3c.log
Wed Oct 28 11:43:04 2009
Destination LOG_ARCHIVE_DEST_2  is  UNSYNCHRONIZED
LGWR: Standby redo logfile selected  to  archive thread 1  sequence  13833
LGWR: Standby redo logfile selected  for  thread 1  sequence  13833  for  destination LOG_ARCHIVE_DEST_2
Wed Oct 28 11:43:04 2009
Thread 1 advanced  to  log  sequence  13833 (LGWR switch)
Current  log# 11 seq# 13833 mem# 0: /oradata/1/redo/TOOLS/redo4a.log
Current  log# 11 seq# 13833 mem# 1: /oradata/2/redo/TOOLS/redo4b.log
Current  log# 11 seq# 13833 mem# 2: /oradata/3/redo/TOOLS/redo4c.log
Wed Oct 28 11:45:04 2009
Destination LOG_ARCHIVE_DEST_2  is  SYNCHRONIZED
LGWR: Standby redo logfile selected  to  archive thread 1  sequence  13834
LGWR: Standby redo logfile selected  for  thread 1  sequence  13834  for  destination LOG_ARCHIVE_DEST_2
Wed Oct 28 11:45:05 2009
Thread 1 advanced  to  log  sequence  13834 (LGWR switch)
Current  log# 8 seq# 13834 mem# 0: /oradata/1/redo/TOOLS/redo1a.log
Current  log# 8 seq# 13834 mem# 1: /oradata/2/redo/TOOLS/redo1b.log
Current  log# 8 seq# 13834 mem# 2: /oradata/3/redo/TOOLS/redo1c.log
Wed Oct 28 11:46:03 2009
Thread 1 cannot allocate new log,  sequence  13835
Checkpoint  not  complete
Current  log# 8 seq# 13834 mem# 0: /oradata/1/redo/TOOLS/redo1a.log
Current  log# 8 seq# 13834 mem# 1: /oradata/2/redo/TOOLS/redo1b.log
Current  log# 8 seq# 13834 mem# 2: /oradata/3/redo/TOOLS/redo1c.log
Wed Oct 28 11:46:10 2009
Destination LOG_ARCHIVE_DEST_2  is  UNSYNCHRONIZED
LGWR: Standby redo logfile selected  to  archive thread 1  sequence  13835
LGWR: Standby redo logfile selected  for  thread 1  sequence  13835  for  destination LOG_ARCHIVE_DEST_2
Wed Oct 28 11:46:11 2009
Thread 1 advanced  to  log  sequence  13835 (LGWR switch)
Current  log# 9 seq# 13835 mem# 0: /oradata/1/redo/TOOLS/redo2a.log
Current  log# 9 seq# 13835 mem# 1: /oradata/2/redo/TOOLS/redo2b.log
Current  log# 9 seq# 13835 mem# 2: /oradata/3/redo/TOOLS/redo2c.log
Wed Oct 28 11:48:03 2009
Thread 1 cannot allocate new log,  sequence  13836
Checkpoint  not  complete
Current  log# 9 seq# 13835 mem# 0: /oradata/1/redo/TOOLS/redo2a.log
Current  log# 9 seq# 13835 mem# 1: /oradata/2/redo/TOOLS/redo2b.log
Current  log# 9 seq# 13835 mem# 2: /oradata/3/redo/TOOLS/redo2c.log
Wed Oct 28 11:48:06 2009
...
 
From  the standby,  as  at  2009-10-28, 11:42,  when  the archiver tried  to  archive the standby
redo logfile. it encountered this error:
 
ORA-00354: corrupt redo log block header
ORA-00353: log corruption near block 604525 change 10551037679542  time  10/28/2009 11:29:50
ORA-00312: online log 2 thread 1:  '/oradata/3/TOOLS/stdby_redo/srl1.log'
 
Errors  in  file /tools/oracle/admin/TOOLS/bdump/tools_arc0_2143.trc
The real logfile is retrieved from primary by the standby RFS process, then the log apply continue as usual. The fact that the standby redo logs are corrupted and identified as corrupt by the ARC process , makes it clear that there could be some sort of I/O errors which has caused. Reviewing the alert.log file it is clear that the RFS process fetched the new copy of the file which is corrupted and the issue has been resolved. This is more an issue to be concentrated from the system adminisration end to determine in case there are any issues at the I.O subsystem.   list some Script to Collect Data Guard Primary Site Diagnostic Information:
Overview -------- This script is intended to provide an easy method to provide information necessary to troubleshoot Data Guard issues. Script Notes ------------- This script is intended to be run via sqlplus as the SYS or Internal user. Script ------- - - - - - - - - - - - - - - - - Script begins here - - - - - - - - - - - - - - - - -- NAME: dg_prim_diag.sql (Run on PRIMARY with a LOGICAL or PHYSICAL STANDBY) -- ------------------------------------------------------------------------ -- Copyright 2002, Oracle Corporation -- LAST UPDATED: 2/23/04 -- -- Usage: @dg_prim_diag -- ------------------------------------------------------------------------ -- PURPOSE: -- This script is to be used to assist in collection information to help -- troubeshoot Data Guard issues with an emphasis on Logical Standby. -- ------------------------------------------------------------------------ -- DISCLAIMER: -- This script is provided for educational purposes only. It is NOT -- supported by Oracle World Wide Technical Support. -- The script has been tested and appears to work as intended. -- You should always run new scripts on a test instance initially. -- ------------------------------------------------------------------------ -- Script output is as follows: set echo off set feedback off column timecol new_value timestamp column spool_extension new_value suffix select to_char(sysdate,'Mondd_hhmi') timecol, '.out' spool_extension from sys.dual; column output new_value dbname select value || '_' output from v$parameter where name = 'db_name'; spool dg_prim_diag_&&dbname&&timestamp&&suffix set linesize 79 set pagesize 35 set trim on set trims on alter session set nls_date_format = 'MON-DD-YYYY HH24:MI:SS'; set feedback on select to_char(sysdate) time from dual; set echo on -- In the following the database_role should be primary as that is what -- this script is intended to be run on. If protection_level is different -- than protection_mode then for some reason the mode listed in -- protection_mode experienced a need to downgrade. Once the error -- condition has been corrected the protection_level should match the -- protection_mode after the next log switch. column role format a7 tru column name format a10 wrap select name,database_role role,log_mode, protection_mode,protection_level from v$database; -- ARCHIVER can be (STOPPED | STARTED | FAILED). FAILED means that the -- archiver failed to archive a log last time, but will try again within 5 -- minutes. LOG_SWITCH_WAIT The ARCHIVE LOG/CLEAR LOG/CHECKPOINT event log -- switching is waiting for. Note that if ALTER SYSTEM SWITCH LOGFILE is -- hung, but there is room in the current online redo log, then value is -- NULL column host_name format a20 tru column version format a9 tru select instance_name,host_name,version,archiver,log_switch_wait from v$instance; -- The following query give us information about catpatch. -- This way we can tell if the procedure doesn't match the image. select version, modified, status from dba_registry where comp_id = 'CATPROC'; -- Force logging is not mandatory but is recommended. Supplemental -- logging must be enabled if the standby associated with this primary is -- a logical standby. During normal operations it is acceptable for -- SWITCHOVER_STATUS to be SESSIONS ACTIVE or TO STANDBY. column force_logging format a13 tru column remote_archive format a14 tru column dataguard_broker format a16 tru select force_logging,remote_archive, supplemental_log_data_pk,supplemental_log_data_ui, switchover_status,dataguard_broker from v$database; -- This query produces a list of all archive destinations. It shows if -- they are enabled, what process is servicing that destination, if the -- destination is local or remote, and if remote what the current mount ID -- is. column destination format a35 wrap column process format a7 column archiver format a8 column ID format 99 column mid format 99 select dest_id "ID",destination,status,target, schedule,process,mountid mid from v$archive_dest order by dest_id; -- This select will give further detail on the destinations as to what -- options have been set. Register indicates whether or not the archived -- redo log is registered in the remote destination control file. set numwidth 8 column ID format 99 select dest_id "ID",archiver,transmit_mode,affirm,async_blocks async, net_timeout net_time,delay_mins delay,reopen_secs reopen, register,binding from v$archive_dest order by dest_id; -- The following select will show any errors that occured the last time -- an attempt to archive to the destination was attempted. If ERROR is -- blank and status is VALID then the archive completed correctly. column error format a55 wrap select dest_id,status,error from v$archive_dest; -- The query below will determine if any error conditions have been -- reached by querying the v$dataguard_status view (view only available in -- 9.2.0 and above): column message format a80 select message, timestamp from v$dataguard_status where severity in ('Error','Fatal') order by timestamp; -- The following query will determine the current sequence number -- and the last sequence archived. If you are remotely archiving -- using the LGWR process then the archived sequence should be one -- higher than the current sequence. If remotely archiving using the -- ARCH process then the archived sequence should be equal to the -- current sequence. The applied sequence information is updated at -- log switch time. select ads.dest_id,max(sequence#) "Current Sequence", max(log_sequence) "Last Archived" from v$archived_log al, v$archive_dest ad, v$archive_dest_status ads where ad.dest_id=al.dest_id and al.dest_id=ads.dest_id group by ads.dest_id; -- The following select will attempt to gather as much information as -- possible from the standby. SRLs are not supported with Logical Standby -- until Version 10.1. set numwidth 8 column ID format 99 column "SRLs" format 99 column Active format 99 select dest_id id,database_mode db_mode,recovery_mode, protection_mode,standby_logfile_count "SRLs", standby_logfile_active ACTIVE, archived_seq# from v$archive_dest_status; -- Query v$managed_standby to see the status of processes involved in -- the shipping redo on this system. Does not include processes needed to -- apply redo. select process,status,client_process,sequence# from v$managed_standby; -- The following query is run on the primary to see if SRL's have been -- created in preparation for switchover. select group#,sequence#,bytes from v$standby_log; -- The above SRL's should match in number and in size with the ORL's -- returned below: select group#,thread#,sequence#,bytes,archived,status from v$log; -- Non-default init parameters. set numwidth 5 column name format a30 tru column value format a48 wra select name, value from v$parameter where isdefault = 'FALSE'; spool off - - - - - - - - - - - - - - - - Script ends here - - - - - - - - - - - - - - - -
another one:

Overview -------- This script is intended to provide an easy method to provide information necessary to troubleshoot Data Guard issues. Script Notes ------------- This script is intended to be run via sqlplus as the SYS or Internal user. Script ------- - - - - - - - - - - - - - - - - Script begins here - - - - - - - - - - - - - - - - -- NAME: DG_phy_stby_diag.sql -- ------------------------------------------------------------------------ -- AUTHOR: -- Michael Smith - Oracle Support Services - DataServer Group -- Copyright 2002, Oracle Corporation -- ------------------------------------------------------------------------ -- PURPOSE: -- This script is to be used to assist in collection information to help -- troubeshoot Data Guard issues. -- ------------------------------------------------------------------------ -- DISCLAIMER: -- This script is provided for educational purposes only. It is NOT -- supported by Oracle World Wide Technical Support. -- The script has been tested and appears to work as intended. -- You should always run new scripts on a test instance initially. -- ------------------------------------------------------------------------ -- Script output is as follows: set echo off set feedback off column timecol new_value timestamp column spool_extension new_value suffix select to_char(sysdate,'Mondd_hhmi') timecol, '.out' spool_extension from sys.dual; column output new_value dbname select value || '_' output from v$parameter where name = 'db_name'; spool dgdiag_phystby_&&dbname&&timestamp&&suffix set lines 200 set pagesize 35 set trim on set trims on alter session set nls_date_format = 'MON-DD-YYYY HH24:MI:SS'; set feedback on select to_char(sysdate) time from dual; set echo on -- -- ARCHIVER can be (STOPPED | STARTED | FAILED) FAILED means that the archiver failed -- to archive a -- log last time, but will try again within 5 minutes. LOG_SWITCH_WAIT -- The ARCHIVE LOG/CLEAR LOG/CHECKPOINT event log switching is waiting for. Note that -- if ALTER SYSTEM SWITCH LOGFILE is hung, but there is room in the current online -- redo log, then value is NULL column host_name format a20 tru column version format a9 tru select instance_name,host_name,version,archiver,log_switch_wait from v$instance; -- The following select will give us the generic information about how this standby is -- setup. The database_role should be standby as that is what this script is intended -- to be ran on. If protection_level is different than protection_mode then for some -- reason the mode listed in protection_mode experienced a need to downgrade. Once the -- error condition has been corrected the protection_level should match the protection_mode -- after the next log switch. column ROLE format a7 tru select name,database_role,log_mode,controlfile_type,protection_mode,protection_level from v$database; -- Force logging is not mandatory but is recommended. Supplemental logging should be enabled -- on the standby if a logical standby is in the configuration. During normal -- operations it is acceptable for SWITCHOVER_STATUS to be SESSIONS ACTIVE or NOT ALLOWED. column force_logging format a13 tru column remote_archive format a14 tru column dataguard_broker format a16 tru select force_logging,remote_archive,supplemental_log_data_pk,supplemental_log_data_ui, switchover_status,dataguard_broker from v$database; -- This query produces a list of all archive destinations and shows if they are enabled, -- what process is servicing that destination, if the destination is local or remote, -- and if remote what the current mount ID is. For a physical standby we should have at -- least one remote destination that points the primary set but it should be deferred. COLUMN destination FORMAT A35 WRAP column process format a7 column archiver format a8 column ID format 99 select dest_id "ID",destination,status,target, archiver,schedule,process,mountid from v$archive_dest; -- If the protection mode of the standby is set to anything higher than max performance -- then we need to make sure the remote destination that points to the primary is set -- with the correct options else we will have issues during switchover. select dest_id,process,transmit_mode,async_blocks, net_timeout,delay_mins,reopen_secs,register,binding from v$archive_dest; -- The following select will show any errors that occured the last time an attempt to -- archive to the destination was attempted. If ERROR is blank and status is VALID then -- the archive completed correctly. column error format a55 tru select dest_id,status,error from v$archive_dest; -- Determine if any error conditions have been reached by querying thev$dataguard_status -- view (view only available in 9.2.0 and above): column message format a80 select message, timestamp from v$dataguard_status where severity in ('Error','Fatal') order by timestamp; -- The following query is ran to get the status of the SRL's on the standby. If the -- primary is archiving with the LGWR process and SRL's are present (in the correct -- number and size) then we should see a group# active. select group#,sequence#,bytes,used,archived,status from v$standby_log; -- The above SRL's should match in number and in size with the ORL's returned below: select group#,thread#,sequence#,bytes,archived,status from v$log; -- Query v$managed_standby to see the status of processes involved in the -- configuration. select process,status,client_process,sequence#,block#,active_agents,known_agents from v$managed_standby; -- Verify that the last sequence# received and the last sequence# applied to standby -- database. select al.thrd "Thread", almax "Last Seq Received", lhmax "Last Seq Applied" from (select thread# thrd, max(sequence#) almax from v$archived_log where resetlogs_change#=(select resetlogs_change# from v$database) group by thread#) al, (select thread# thrd, max(sequence#) lhmax from v$log_history where first_time=(select max(first_time) from v$log_history) group by thread#) lh where al.thrd = lh.thrd; -- The V$ARCHIVE_GAP fixed view on a physical standby database only returns the next -- gap that is currently blocking redo apply from continuing. After resolving the -- identified gap and starting redo apply, query the V$ARCHIVE_GAP fixed view again -- on the physical standby database to determine the next gap sequence, if there is -- one. select * from v$archive_gap; -- Non-default init parameters. set numwidth 5 column name format a30 tru column value format a50 wra select name, value from v$parameter where isdefault = 'FALSE'; spool off - - - - - - - - - - - - - - - - Script ends here - - - - - - - - - - - - - - - -


本文转自maclean_007 51CTO博客,原文链接:http://blog.51cto.com/maclean/1277589


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
23天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
56 3
|
3月前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1769 14
MySQL事务日志-Redo Log工作原理分析
|
3月前
|
SQL 存储 关系型数据库
美团面试:binlog、redo log、undo log的底层原理是什么?它们分别实现ACID的哪个特性?
老架构师尼恩在其读者交流群中分享了关于 MySQL 中 redo log、undo log 和 binlog 的面试题及其答案。这些问题涵盖了事务的 ACID 特性、日志的一致性问题、SQL 语句的执行流程等。尼恩详细解释了这些日志的作用、所在架构层级、日志形式、缓存机制以及写文件方式等内容。他还提供了多个面试题的详细解答,帮助读者系统化地掌握这些知识点,提升面试表现。此外,尼恩还推荐了《尼恩Java面试宝典PDF》和其他技术圣经系列PDF,帮助读者进一步巩固知识,实现“offer自由”。
美团面试:binlog、redo log、undo log的底层原理是什么?它们分别实现ACID的哪个特性?
|
3月前
|
存储 关系型数据库 MySQL
MySQL中的Redo Log、Undo Log和Binlog:深入解析
【10月更文挑战第21天】在数据库管理系统中,日志是保障数据一致性和完整性的关键机制。MySQL作为一种广泛使用的关系型数据库管理系统,提供了多种日志类型来满足不同的需求。本文将详细介绍MySQL中的Redo Log、Undo Log和Binlog,从背景、业务场景、功能、底层实现原理、使用措施等方面进行详细分析,并通过Java代码示例展示如何与这些日志进行交互。
370 0
|
4月前
|
存储 缓存 关系型数据库
redo log 原理解析
redo log 原理解析
66 0
redo log 原理解析
|
5月前
|
应用服务中间件 nginx
nginx error日志 client intended to send too large body: 1434541 bytes 如何处理?
【8月更文挑战第27天】nginx error日志 client intended to send too large body: 1434541 bytes 如何处理?
447 6
|
5月前
|
Kubernetes 数据安全/隐私保护 容器
【Azure APIM】APIM Self-Hosted网关中,添加网关日志以记录请求头信息(Request Header / Response Header)
【Azure APIM】APIM Self-Hosted网关中,添加网关日志以记录请求头信息(Request Header / Response Header)
|
5月前
|
Go 开发者
【应用服务 App Service】App Service发生错误请求时,如何查看IIS Freb日志,从中得知错误所发生的模块,请求中所携带的Header信息
【应用服务 App Service】App Service发生错误请求时,如何查看IIS Freb日志,从中得知错误所发生的模块,请求中所携带的Header信息
|
5月前
|
API C# 开发框架
WPF与Web服务集成大揭秘:手把手教你调用RESTful API,客户端与服务器端优劣对比全解析!
【8月更文挑战第31天】在现代软件开发中,WPF 和 Web 服务各具特色。WPF 以其出色的界面展示能力受到欢迎,而 Web 服务则凭借跨平台和易维护性在互联网应用中占有一席之地。本文探讨了 WPF 如何通过 HttpClient 类调用 RESTful API,并展示了基于 ASP.NET Core 的 Web 服务如何实现同样的功能。通过对比分析,揭示了两者各自的优缺点:WPF 客户端直接处理数据,减轻服务器负担,但需处理网络异常;Web 服务则能利用服务器端功能如缓存和权限验证,但可能增加服务器负载。希望本文能帮助开发者根据具体需求选择合适的技术方案。
253 0
|
5月前
【Azure 云服务】Azure Cloud Service 为 Web Role(IIS Host)增加自定义字段 (把HTTP Request Header中的User-Agent字段增加到IIS输出日志中)
【Azure 云服务】Azure Cloud Service 为 Web Role(IIS Host)增加自定义字段 (把HTTP Request Header中的User-Agent字段增加到IIS输出日志中)