خب ممکنه برای شما این سوال پیش بیاد که اگه Data Guard شما روش gap بیوفته یا اینکه سرور primary شما با سرور standby شما ارتباطش دچار اختلال بشه و نتونن همدیگه رو ping کنن در این حالت چه اتفاقی برای دیتاهای شما رخ میده؟
در اصل میخوایم ببینیم که سناریوی Data Guard و Active Data Guard برای این حالت چه راهحلی ارائه میده؟
خب مفاهیم LNS و RFS رو در پستهای قبل توضیح دادیم.
به تصویر بالا اگر دقت کنید در حقیقت یک حالت عادی رو در آن مشاهده میکنید که LNS میاد و از Redo Buffer روی RFS مینویسه و اونم روی Standby Redo Logها مینویسه منتها اگر gap به وجود بیاد شما باید به حالت زیر دقت کنید:
در این حالت تا زمانی که sync در حالت عادی اتفاق نیافتاده است یعین LNS نتونه از روی Redo Buffer بخونه Active Data Guard در حقیقت میاد کنترل میکنه از روی کنترل فایلهای سرور standby میاد میبینه که در حقیقت ما چقدر لگ داریم اگر لگ ما به اندازهای بود که اطلاعات روی redo ها یا روی redo buffer ها وجود نداشته باشه میاد سراغ Archive Redo Log فایلهای سرور اصلی و از روی این آرشیوها پروسس RFS میاد روی Archive Redo Logهای سرور standby شما اون دیتا رو مینویسه (به شکل بالا دقت کنید)
و به این ترتیب دیتاها apply میشه روی خود سرور standby
نکته: این اتفاق تا زمانی که اطلاعات شما دیگه توی Archiveهای سرور اصلی نباشه و روی redo buffer یا همون online redo Logها باشه و این دقیقاً بستگی داره به وضعیت Sync یا Async شما
اگر دقت کرده باشید زمانی که وضعیت standby را syncکنید یک tranport lag داریم و یک apply lag که Transport Lag مربوط به انتقال لاگ فایل هست و Apply Lag مربوط به apply شدن تغییرات روی سرور standby برای مفهومی بهتر در شکل زیر این ۲ مفهوم را در این سناریو مشخص کردهام: