Oracle Stream Replication¼¼Êõ
Stream ÊÇOracle µÄÏûÏ¢¶ÓÁÐ(Ò²½ÐOracle Advanced Queue)¼¼ÊõµÄÒ»ÖÖÀ©Õ¹Ó¦ÓᣠOracle µÄÏûÏ¢¶ÓÁÐÊÇͨ¹ý·¢²¼/¶©Ôĵķ½Ê½À´½â¾öʼþ¹ÜÀí¡£Á÷¸´ÖÆ(Stream replication)Ö»ÊÇ»ùÓÚËüµÄÒ»¸öÊý¾Ý¹²Ïí¼¼Êõ£¬Ò²¿ÉÒÔ±»ÓÃ×÷Ò»¸ö¿ÉÁé»î¶¨ÖƵĸ߿ÉÓÃÐÔ·½°¸¡£ Ëü¿ÉÒÔʵÏÖÁ½¸öÊý¾Ý¿âÖ®¼äÊý¾Ý¿â¼¶£¬schema¼¶£¬Table¼¶µÄÊý¾Ýͬ²½£¬²¢ÇÒÕâÖÖͬ²½¿ÉÒÔÊÇË«ÏòµÄ¡£ Oracle StreamÒ²ÊÇͨ¹ýÊý¾ÝÈßÓàÀ´Ìá¸ß¿ÉÓÃÐÔ£¬ÕâÒ»µãºÍData Guard ÀàÐÍ¡£
Oracle ¸ß¼¶¸´ÖÆ(Oracle advanced Replication) ºÍÁ÷¸´ÖÆ(Stream Replication) ÊÇ´ÓÃû³ÆºÍ¹¦ÄÜÉ϶¼ÏàËÆµÄÁ½ÖÖ¼¼Êõ¡£ µ«Ç°ÕßÊÇ»ùÓÚ´¥·¢Æ÷µÄ£¬ºóÕßÊÇ»ùÓÚÈÕÖ¾ÍÚ¾ò(Logminer)¼¼Êõ¡£
1. Stream µÄ¹¤×÷ÔÀí
Stream ÊÇOracle Advanced Queue¼¼ÊõµÄÒ»ÖÖÀ©Õ¹Ó¦Ó㬠ÕâÖÖ¼¼Êõ×î»ù±¾µÄÔÀí¾ÍÊÇÊÕ¼¯Ê¼þ£¬°Ñʱ¼ä±£´æÔÚ¶ÓÁÐÖУ¬È»ºó°ÑÕâЩʼþ·¢²¼¸ø²»Í¬µÄ¶©ÔÄÕß¡£ ´ÓDBAµÄ½Ç¶ÈÀ´Ëµ£¬ ¾ÍÊǰѲ¶»ñOracleÊý¾Ý¿â²úÉúµÄRedoÈÕÖ¾£¬È»ºó°ÑÕâЩÈÕ־ͨ¹ýÍøÂç´«²¥µ½¶à¸öÊý¾Ý¿â£¬ÆäËûÊý¾Ý¿âͨ¹ýÓ¦ÓÃÕâЩÈÕÖ¾£¬´ïµ½¸´ÖƱ仯µÄ×÷Óá£
ÔÚStream »·¾³Ï£¬ ¸´ÖÆµÄÆðµãÊý¾Ý¿â½Ð×÷Source Database£¬ ¸´ÖƵÄÖÕµãÊý¾Ý¿â½Ð×÷Target Database¡£ ÔÚÕâÁ½¸öÊý¾Ý¿âÉ϶¼Òª´´½¨Ò»¸ö¶ÓÁУ¬ÆäÖеÄSource DatabaseÉϵÄÊÇ·¢ËͶÓÁУ¬¶øTarget DatabaseÉϵÄÊǽÓÊÕ¶ÓÁС£
Êý¾Ý¿âµÄËùÓвÙ×÷¶¼»á±»¼Ç¼ÔÚÈÕÖ¾ÖС£ ÅäºÃStream»·¾³ºó£¬ ÔÚSource DatabaseÉÏ»áÓÐÒ»¸ö²¶»ñ½ø³Ì(Capture Process), ¸Ã½ø³ÌÀûÓÃLogminer¼¼Êõ´ÓÈÕÖ¾ÖÐÌáÈ¡DDL,DMLÓï¾ä£¬ÕâЩÓï¾äÓÃÒ»ÖÖÌØÊâµÄ¸ñʽ±í´ï£¬½Ð×÷Âß¼±ä¸ü¼Ç¼(Logical Change Record, LCR). Ò»¸öLCR¶ÔÓ¦Ò»¸öÔ×ÓµÄÐбä¸ü£¬Òò´ËÔ´Êý¾Ý¿âÉϵÄÒ»¸öDMLÓï¾ä£¬¿ÉÄܶÔÓ¦Èô¸É¸öLCR¼Ç¼¡£ ÕâЩLCR»á±£´æµ½Sourece DatabaseµÄ±¾µØ·¢ËͶÓÁÐÖС£È»ºó´«²¥½ø³Ì(Propagation Process)°ÑÕâЩ¼Ç¼ͨ¹ýÍøÂç·¢Ë͵½Target DatabaseµÄ½ÓÊÕ¶ÓÁС£ ÔÚTarget DatabaseÉÏ»áÓÐÒ»¸öÓ¦Óýø³Ì(Apply Process)£¬ Õâ¸ö½ø³Ì´Ó±¾µØµÄ½ÓÊÕ¶ÓÁÐÖÐÈ¡³öLCR¼Ç¼£¬È»ºóÔÚ±¾µØÓ¦Óã¬ÊµÏÖÊý¾Ýͬ²½
2. Data Guard ºÍStream Çø±ð
Date GuardÓÐÁ½ÖÖÀàÐÍ£ºphysical sta
Ïà¹ØÎĵµ£º
oracle±í¿Õ¼ä²Ù×÷Ïê½â
1
2
3×÷Õߣº À´Ô´£º ¸üÐÂÈÕÆÚ£º2006-01-04
5
6
7½¨Á¢±í¿Õ¼ä
8
9CREATE TABLESPACE data01
10DATAFILE '/ora ......
ÓÃdateÐÍ×ֶνøÐÐÊý¾Ý¼ìË÷ʱÐèҪעÒ⣺Êý¾Ý¸ñʽ»¯£¡
´ËÊý¾Ý¸ñʽ»¯²»Í¬ÓÚÓÃSimpleDateFormat("yyyy-MM-dd")¶ÔÏó½øÐиñʽ»¯£¬¶øÊÇÓÃOracleµÄÄÚÖú¯Êýto_date()
»ò±êʶ·ûdateÀ´¸ñʽ»¯¡£
ÀýÈ磺
Óиö×Ö¶ÎÊÇdateÊý¾Ý£¬ÎÒÏë²éѯijijÄê¶ÈµÄÊý¾Ý¡£
´íÎóд·¨£ºs ......
ÓÐÁ½ÖÖº¬ÒåµÄ±í´óС¡£Ò»ÖÖÊÇ·ÖÅä¸øÒ»¸ö±íµÄÎïÀí¿Õ¼äÊýÁ¿£¬¶ø²»¹Ü¿Õ¼äÊÇ·ñ±»Ê¹Ó᣿ÉÒÔÕâÑù²éѯ»ñµÃ×Ö½ÚÊý£º
select segment_name, bytes
from user_segments
where segment_type = 'TABLE';
»òÕß
Select Segment_Name,Sum(bytes)/1024/1024 from User_Extents Group By Segment_Name
ÁíÒ»ÖÖ±íÊ ......
--»ñÈ¡Á½Ê±¼äµÄÏà²îºÀÃëÊý
select ceil((To_date('2008-05-02 00:00:00' , 'yyyy-mm-dd hh24-mi-ss') - To_date('2008-04-30 23:59:59' , 'yyyy-mm-dd hh24-mi-ss')) * 24 * 60 * 60 * 1000) Ïà²îºÀÃëÊý from DUAL;
/*
Ïà²îºÀÃëÊý
----------
86401000
1 row selected
*/
--»ñÈ¡Á½Ê±¼äµÄÏà²îÃëÊý
select ce ......