आईएमएस डीबी - रिकवरी
डेटाबेस व्यवस्थापक को सिस्टम विफलताओं के मामले में डेटाबेस पुनर्प्राप्ति के लिए योजना बनाने की आवश्यकता होती है। विफलताएं कई प्रकार की हो सकती हैं जैसे कि एप्लिकेशन क्रैश, हार्डवेयर त्रुटियां, पावर विफलताएं आदि।
सरल दृष्टिकोण
डेटाबेस रिकवरी के कुछ सरल तरीके इस प्रकार हैं -
महत्वपूर्ण डेटासेट की आवधिक बैकअप प्रतियां बनाएं ताकि डेटासेट के विरुद्ध पोस्ट किए गए सभी लेनदेन बरकरार रहें।
यदि सिस्टम विफलता के कारण कोई डेटासेट खराब हो जाता है, तो बैकअप कॉपी को पुनर्स्थापित करके उस समस्या को ठीक किया जाता है। फिर संचित लेन-देन को बैकअप प्रति में पोस्ट किया जाता है ताकि उन्हें अद्यतित किया जा सके।
सरल दृष्टिकोण के नुकसान
डेटाबेस रिकवरी के लिए सरल दृष्टिकोण के नुकसान इस प्रकार हैं -
संचित लेनदेन को फिर से पोस्ट करने में बहुत समय लगता है।
वसूली समाप्त होने तक सभी अन्य अनुप्रयोगों को निष्पादन के लिए इंतजार करना होगा।
डेटाबेस रिकवरी फ़ाइल रिकवरी की तुलना में लंबा है, अगर तार्किक और माध्यमिक सूचकांक संबंध शामिल हैं।
असामान्य समाप्ति दिनचर्या
एक DL / I प्रोग्राम उस तरह से क्रैश होता है जो मानक प्रोग्राम क्रैश होने के तरीके से अलग होता है क्योंकि एक मानक प्रोग्राम सीधे ऑपरेटिंग सिस्टम द्वारा निष्पादित होता है, जबकि DL / I प्रोग्राम नहीं है। एक असामान्य समाप्ति दिनचर्या को नियोजित करके, सिस्टम हस्तक्षेप करता है ताकि पुनर्प्राप्ति ABnormal END (ABEND) के बाद की जा सके। असामान्य समाप्ति दिनचर्या निम्नलिखित क्रियाएं करती है -
- सभी डेटासेट बंद करता है
- कतार में सभी लंबित नौकरियों को रद्द करें
- ABEND का मूल कारण जानने के लिए एक संग्रहण डंप बनाता है
इस दिनचर्या की सीमा यह है कि यह सुनिश्चित नहीं करता है कि उपयोग में डेटा सही है या नहीं।
डीएल / आई लॉग
जब कोई एप्लिकेशन प्रोग्राम ABENDs करता है, तो एप्लिकेशन प्रोग्राम द्वारा किए गए परिवर्तनों को वापस करना, त्रुटि को ठीक करना और एप्लिकेशन प्रोग्राम को फिर से चलाना आवश्यक है। ऐसा करने के लिए, डीएल / आई लॉग होना आवश्यक है। यहाँ DL / I लॉगिंग के बारे में मुख्य बातें दी गई हैं -
एक DL / I एक फ़ाइल में एक एप्लिकेशन प्रोग्राम द्वारा किए गए सभी परिवर्तनों को रिकॉर्ड करता है जिसे लॉग फ़ाइल के रूप में जाना जाता है।
जब एप्लिकेशन प्रोग्राम एक खंड को बदलता है, तो छवि से पहले और बाद में चित्र DL / I द्वारा बनाए जाते हैं।
यदि एप्लिकेशन प्रोग्राम क्रैश हो जाता है, तो खंडों को पुनर्स्थापित करने के लिए इन खंड छवियों का उपयोग किया जा सकता है।
DL / I डेटाबेस परिवर्तन को रिकॉर्ड करने के लिए राइट-फॉरवर्ड लॉगिंग नामक तकनीक का उपयोग करता है। राइट-फॉरवर्ड लॉगिंग के साथ, डेटाबेस परिवर्तन वास्तविक डेटासेट के लिखे जाने से पहले लॉग डेटासेट में लिखा जाता है।
चूंकि लॉग हमेशा डेटाबेस से आगे होता है, रिकवरी यूटिलिटी किसी भी डेटाबेस परिवर्तन की स्थिति निर्धारित कर सकती है।
जब प्रोग्राम एक डेटाबेस सेगमेंट को बदलने के लिए कॉल निष्पादित करता है, तो DL / I इसके लॉगिंग भाग का ध्यान रखता है।
वसूली - आगे और पीछे
डेटाबेस रिकवरी के दो दृष्टिकोण हैं -
Forward Recovery - DL / I परिवर्तन डेटा को संग्रहीत करने के लिए लॉग फ़ाइल का उपयोग करता है। इस लॉग फ़ाइल का उपयोग करके संचित लेनदेन को फिर से पोस्ट किया जाता है।
Backward Recovery- बैकवर्ड रिकवरी को बैकआउट रिकवरी के रूप में भी जाना जाता है। कार्यक्रम के लॉग रिकॉर्ड्स को पीछे की ओर पढ़ा जाता है और उनके प्रभावों को डेटाबेस में उलट दिया जाता है। जब बैकआउट पूरा हो जाता है, तो डेटाबेस उसी स्थिति में होते हैं जब वे विफलता से पहले थे, यह मानते हुए कि इस बीच डेटाबेस में कोई अन्य एप्लिकेशन प्रोग्राम बदल नहीं गया है।
जांच की चौकी
एक चेकपॉइंट एक ऐसा चरण है जहां एप्लिकेशन प्रोग्राम द्वारा किए गए डेटाबेस परिवर्तन को पूर्ण और सटीक माना जाता है। नीचे सूचीबद्ध बिंदुओं पर एक चेकपॉइंट के बारे में ध्यान दिया गया है -
सबसे हाल ही में चौकी से पहले किए गए डेटाबेस परिवर्तन पिछड़े वसूली से उलट नहीं हैं।
सबसे हाल ही में चेकपॉइंट के बाद डेटाबेस परिवर्तन लॉग किए गए हैं जो फ़ॉरवर्ड रिकवरी के दौरान डेटाबेस की इमेज कॉपी पर लागू नहीं होते हैं।
चेकपॉइंट विधि का उपयोग करके, पुनर्प्राप्ति प्रक्रिया पूरी होने पर सबसे हाल ही में चेकपॉइंट पर डेटाबेस को उसकी स्थिति में पुनर्स्थापित किया जाता है।
बैच कार्यक्रमों के लिए डिफ़ॉल्ट यह है कि चेकपॉइंट प्रोग्राम की शुरुआत है।
एक चेकपॉइंट कॉल (CHKP) का उपयोग करके एक चेकपॉइंट स्थापित किया जा सकता है।
चेकपॉइंट कॉल के कारण DL / I लॉग पर एक चेकपॉइंट रिकॉर्ड लिखा जाता है।
नीचे दिखाया गया CHKP कॉल का सिंटैक्स है -
CALL 'CBLTDLI' USING DLI-CHKP
PCB-NAME
CHECKPOINT-ID
दो चौकी के तरीके हैं -
Basic Checkpointing - यह प्रोग्रामर को चेकपॉइंट कॉल जारी करने की अनुमति देता है कि रिकवरी प्रोसेसिंग के दौरान DL / I रिकवरी उपयोगिताओं का उपयोग करता है।
Symbolic Checkpointing- यह चेकपॉइंटिंग का एक उन्नत रूप है जो विस्तारित पुनरारंभ सुविधा के साथ संयोजन में उपयोग किया जाता है। प्रतीकात्मक चेकपॉइंटिंग और विस्तारित पुनरारंभ एक साथ, एप्लिकेशन प्रोग्रामर को प्रोग्राम्स को कोड करने दें ताकि वे चेकपॉइंट के बाद बिंदु पर प्रसंस्करण फिर से शुरू कर सकें।