Oracle安全:SCN可能最大值与耗尽问题

在2012年第一季度的CPU补丁中,包含了一个关于SCN修正的重要变更,这个补丁提示,在异常情况下,Oracle的SCN可能出现异常增长,使得数据库的一切事务停止,由于SCN不能后退,所以数据库必须重建,才能够重用。

        我曾经在以下链接中描述过这个问题:

  http://www.eygle.com/archives/2012/03/oracle_scn_bug_exhaused.html

  Oracle使用6 Bytes记录SCN,也就是48位,其最大值是:

 

  1.   SQL> col scn for 999,999,999,999,999,999  
  2.   SQL> select power(2,48) scn from dual;  
  3.   SCN  
  4.   ------------------------  
  5.   281,474,976,710,656 

 

  Oracle在内部控制每秒增减的SCN不超过 16K,按照这样计算,这个数值可以使用大约544年:

 

  1.   SQL> select power(2,48) / 16 / 1024 / 3600 / 24 / 365 from dual;  
  2.   POWER(2,48)/16/1024/3600/24/365  
  3.   -------------------------------  
  4.   544.770078 

 

  然而在出现异常时,尤其是当使用DB Link跨数据库查询时,SCN会被同步,在以下链接中,我曾经描述过此问题:

  http://www.eygle.com/archives/2006/11/db_link_checkpoint_scn.html

  一个数据库当前最大的可能SCN被称为”最大合理SCN”,该值可以通过如下方式计算:

  1.   col scn for 999,999,999,999,999,999  
  2.   select 
  3.   (  
  4.   (  
  5.  (  
  6.   (  
  7.   (  
  8.   (  
  9.   to_char(sysdate,'YYYY')-1988  
  10.   )*12+  
  11.   to_char(sysdate,'mm')-1  
  12.   )*31+to_char(sysdate,'dd')-1  
  13.   )*24+to_char(sysdate,'hh24')  
  14.   )*60+to_char(sysdate,'mi')  
  15.   )*60+to_char(sysdate,'ss')  
  16.   ) * to_number('ffff','XXXXXXXX')/4 scn  
  17.   from dual  
  18.   / 

  这个算法即SCN算法,以1988年1月1日 00点00时00分开始,每秒计算1个点数,最大SCN为16K。

  这个内容可以参考如下链接:

  http://www.eygle.com/archives/2006/01/how_big_scn_can_be.html

  在CPU补丁中,Oracle提供了一个脚本 scnhealthcheck.sql 用于检查数据库当前SCN的剩余情况。

  该脚本的算法和以上描述相同,最终将最大合理SCN 减去当前数据库SCN,计算得出一个指标:HeadRoom。也就是SCN尚余的顶部空间,这个顶部空间最后折合成天数:

以下是这个脚本的内容:

  1.   Rem  
  2.   Rem $Header: rdbms/admin/scnhealthcheck.sql st_server_tbhukya_bug-13498243/8 2012/01/17 03:37:18 tbhukya Exp $  
  3.   Rem  
  4.   Rem scnhealthcheck.sql  
  5.   Rem  
  6.   Rem Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.  
  7.   Rem  
  8.   Rem NAME 
  9.   Rem scnhealthcheck.sql - Scn Health check 
  10.   Rem  
  11.   Rem DESCRIPTION  
  12.   Rem Checks scn health of a DB  
  13.   Rem  
  14.   Rem NOTES  
  15.   Rem .  
  16.   Rem  
  17.   Rem MODIFIED (MM/DD/YY)  
  18.   Rem tbhukya 01/11/12 - Created  
  19.   Rem  
  20.   Rem  
  21.   define LOWTHRESHOLD=10  
  22.   define MIDTHRESHOLD=62  
  23.   define VERBOSE=FALSE 
  24.   set veri off;  
  25.   set feedback off;  
  26.   set serverout on 
  27.   DECLARE 
  28.   verbose boolean:=&&VERBOSE;  
  29.   BEGIN 
  30.   For C in (  
  31.   select 
  32.   version,  
  33.   date_time,  
  34.  dbms_flashback.get_system_change_number current_scn,  
  35.   indicator  
  36.   from 
  37.   (  
  38.   select 
  39.   version,  
  40.   to_char(SYSDATE,'YYYY/MM/DD HH24:MI:SS') DATE_TIME,  
  41.   ((((  
  42.   ((to_number(to_char(sysdate,'YYYY'))-1988)*12*31*24*60*60) +  
  43.   ((to_number(to_char(sysdate,'MM'))-1)*31*24*60*60) +  
  44.   (((to_number(to_char(sysdate,'DD'))-1))*24*60*60) +  
  45.   (to_number(to_char(sysdate,'HH24'))*60*60) +  
  46.   (to_number(to_char(sysdate,'MI'))*60) +  
  47.   (to_number(to_char(sysdate,'SS')))  
  48.   ) * (16*1024)) - dbms_flashback.get_system_change_number)  
  49.   / (16*1024*60*60*24)  
  50.   ) indicator  
  51.   from v$instance  
  52.   )  
  53.   ) LOOP  
  54.   dbms_output.put_line( '-----------------------------------------------------' 
  55.   || '---------' );  
  56.   dbms_output.put_line( 'ScnHealthCheck' );  
  57.   dbms_output.put_line( '-----------------------------------------------------' 
  58.   || '---------' );  
  59.   dbms_output.put_line( 'Current Date: '||C.date_time );  
  60.   dbms_output.put_line( 'Current SCN: '||C.current_scn );  
  61.   if (verbose) then 
  62.   dbms_output.put_line( 'SCN Headroom: '||round(C.indicator,2) );  
  63.   end if;  
  64.   dbms_output.put_line( 'Version: '||C.version );  
  65.   dbms_output.put_line( '-----------------------------------------------------' 
  66.   || '---------' );  
  67.   IF C.version > '10.2.0.5.0' and 
  68.   C.version NOT LIKE '9.2%' THEN 
  69.   IF C.indicator>&MIDTHRESHOLD THEN 
  70.   dbms_output.put_line('Result: A - SCN Headroom is good');  
  71.   dbms_output.put_line('Apply the latest recommended patches');  
  72.   dbms_output.put_line('based on your maintenance schedule');  
  73.   IF (C.version < '11.2.0.2'THEN 
  74.   dbms_output.put_line('AND set _external_scn_rejection_threshold_hours=' 
  75.   || '24 after apply.');  
  76.   END IF;  
  77.   ELSIF C.indicator<=&LOWTHRESHOLD THEN 
  78.   dbms_output.put_line('Result: C - SCN Headroom is low');  
  79.   dbms_output.put_line('If you have not already done so apply' );  
  80.   dbms_output.put_line('the latest recommended patches right now' );  
  81.   IF (C.version < '11.2.0.2'THEN 
  82.   dbms_output.put_line('set _external_scn_rejection_threshold_hours=24 ' 
  83.   || 'after apply');  
  84.   END IF;  
  85.   dbms_output.put_line('AND contact Oracle support immediately.' );  
  86.  ELSE 
  87.   dbms_output.put_line('Result: B - SCN Headroom is low');  
  88.   dbms_output.put_line('If you have not already done so apply' );  
  89.   dbms_output.put_line('the latest recommended patches right now');  
  90.   IF (C.version < '11.2.0.2'THEN 
  91.   dbms_output.put_line('AND set _external_scn_rejection_threshold_hours=' 
  92.   ||'24 after apply.');  
  93.   END IF;  
  94.   END IF;  
  95.   ELSE 
  96.   IF C.indicator<=&MIDTHRESHOLD THEN 
  97.   dbms_output.put_line('Result: C - SCN Headroom is low');  
  98.   dbms_output.put_line('If you have not already done so apply' );  
  99.   dbms_output.put_line('the latest recommended patches right now' );  
  100.   IF (C.version >= '10.1.0.5.0' and 
  101.   C.version <= '10.2.0.5.0' and 
  102.   C.version NOT LIKE '9.2%'THEN 
  103.   dbms_output.put_line(', set _external_scn_rejection_threshold_hours=24' 
  104.   || ' after apply');  
  105.   END IF;  
  106.   dbms_output.put_line('AND contact Oracle support immediately.' );  
  107.   ELSE 
  108.   dbms_output.put_line('Result: A - SCN Headroom is good');  
  109.   dbms_output.put_line('Apply the latest recommended patches');  
  110.   dbms_output.put_line('based on your maintenance schedule ');  
  111.   IF (C.version >= '10.1.0.5.0' and 
  112.   C.version <= '10.2.0.5.0' and 
  113.   C.version NOT LIKE '9.2%'THEN 
  114.   dbms_output.put_line('AND set _external_scn_rejection_threshold_hours=24' 
  115.   || ' after apply.');  
  116.   END IF;  
  117.   END IF;  
  118.   END IF;  
  119.   dbms_output.put_line(  
  120.   'For further information review MOS document id 1393363.1');  
  121.   dbms_output.put_line( '-----------------------------------------------------' 
  122.   || '---------' );  
  123.   END LOOP;  
  124.   end;  
  125.   / 

  在应用补丁之后,一个新的隐含参数 _external_scn_rejection_threshold_hours 引入,通常设置该参数为 24 小时:

  _external_scn_rejection_threshold_hours=24

  这个设置降低了SCN Headroom的顶部空间,以前缺省的设置容量至少为31天,降低为 24 小时,可以增大SCN允许增长的合理空间。

  但是如果不加控制,SCN仍然可能会超过最大的合理范围,导致数据库问题。

  这个问题的影响会极其严重,我们建议用户检验当前数据库的SCN使用情况,以下是检查脚本的输出范例:

  1.   --------------------------------------  
  2.   ScnHealthCheck  
  3.   --------------------------------------  
  4.   Current Date: 2012/01/15 14:17:49  
  5.  Current SCN: 13194140054241  
  6.   Version: 11.2.0.2.0  
  7.   --------------------------------------  
  8.   Result: C - SCN Headroom is low  
  9.   If you have not already done so apply  
  10.   the latest recommended patches right now  
  11.   AND contact Oracle support immediately.  
  12.   For further information review MOS document id 1393363.  
  13.   -------------------------------------- 

  这个问题已经出现在客户环境中,需要引起大家的足够重视。

【编辑推荐】

  1. 如何在Oracle中使用Java存储过程(详解)
  2. 任重道远迁移路之DB2到Oracle
  3. 11个重要的数据库设计规则
  4. 让数据库变快的10个建议
  5. 20个数据库设计最佳实践

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/294177.html<

(0)
运维的头像运维
上一篇2025-05-20 23:15
下一篇 2025-05-20 23:16

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注