हर्मिटिटी

इस पेज पर, हर्मेटिकिटी, हर्मेटिक बिल्ड इस्तेमाल करने के फ़ायदों, और अपने बिल्ड में नॉन-हर्मेटिक व्यवहार की पहचान करने की रणनीतियों के बारे में बताया गया है.

खास जानकारी

एक हर्मेटिक बिल्ड सिस्टम, एक ही इनपुट सोर्स कोड और प्रॉडक्ट कॉन्फ़िगरेशन दिए जाने पर हमेशा एक जैसा आउटपुट देता है. ऐसा इसलिए, क्योंकि यह बिल्ड को होस्ट सिस्टम में किए गए बदलावों से अलग रखता है.

बिल्ड को अलग करने के लिए, हर्मेटिक बिल्ड, लाइब्रेरी और स्थानीय या रिमोट होस्ट मशीन पर इंस्टॉल किए गए अन्य सॉफ़्टवेयर के लिए संवेदनशील नहीं होते हैं. ये कंपाइलर जैसे बिल्ड टूल के खास वर्शन और लाइब्रेरी जैसी डिपेंडेंसी पर निर्भर होते हैं. इससे बिल्ड प्रोसेस अपने-आप पूरी हो जाती है, क्योंकि यह बिल्ड एनवायरमेंट से बाहर की सेवाओं पर निर्भर नहीं होती.

हर्मेटिकिटी के दो अहम पहलू ये हैं:

  • आइसोलेशन: हर्मेटिक बिल्ड सिस्टम, टूल को सोर्स कोड के तौर पर इस्तेमाल करते हैं. वे टूल की कॉपी डाउनलोड करते हैं. साथ ही, मैनेज किए गए फ़ाइल ट्री में अपने स्टोरेज और इस्तेमाल को मैनेज करते हैं. इससे होस्ट मशीन और स्थानीय उपयोगकर्ता के बीच आइसोलेशन बन जाता है. इसमें भाषाओं के इंस्टॉल किए गए वर्शन भी शामिल हैं.
  • सोर्स आइडेंटिटी: हर्मेटिक बिल्ड सिस्टम, इनपुट के एक जैसे होने की पुष्टि करते हैं. Git जैसी कोड रिपॉज़िटरी, कोड में हुए बदलावों के सेट की पहचान एक यूनीक हैश कोड से करती हैं. हर्मेटिक बिल्ड सिस्टम, इस हैश का इस्तेमाल करके बिल्ड के इनपुट में हुए बदलावों की पहचान करते हैं.

फ़ायदे

हर्मेटिक बिल्ड के मुख्य फ़ायदे ये हैं:

  • स्पीड: किसी कार्रवाई के आउटपुट को कैश मेमोरी में सेव किया जा सकता है. साथ ही, इनपुट में बदलाव होने पर ही कार्रवाई को फिर से चलाने की ज़रूरत होती है.
  • पैरलल एक्ज़ीक्यूशन: दिए गए इनपुट और आउटपुट के लिए, बिल्ड सिस्टम सभी कार्रवाइयों का ग्राफ़ बना सकता है, ताकि असरदार और पैरलल एक्ज़ीक्यूशन का हिसाब लगाया जा सके. बिल्ड सिस्टम, नियमों को लोड करता है. साथ ही, कैश मेमोरी में खोजने के लिए, ऐक्शन ग्राफ़ और हैश इनपुट का हिसाब लगाता है.
  • एक से ज़्यादा बिल्ड: एक ही मशीन पर कई हर्मेटिक बिल्ड बनाए जा सकते हैं. हर बिल्ड में अलग-अलग टूल और वर्शन का इस्तेमाल किया जाता है.
  • दोहराने की क्षमता: हर्मेटिक बिल्ड, समस्या हल करने के लिए बेहतर होते हैं. ऐसा इसलिए, क्योंकि आपको उन शर्तों के बारे में सटीक जानकारी होती है जिनकी वजह से बिल्ड तैयार हुआ है.

नॉन-हर्मेटिसिटी की पहचान करना

अगर आपको Bazel पर स्विच करना है, तो पहले से मौजूद बिल्ड की हर्मेटिसिटी को बेहतर बनाएं. इससे माइग्रेट करना आसान हो जाएगा. बिल्ड में गैर-हर्मेटिक होने की कुछ सामान्य वजहें ये हैं:

  • .mk फ़ाइलों में मनमुताबिक प्रोसेसिंग
  • ऐसी कार्रवाइयां या टूल जो फ़ाइलों को नॉन-डिटरमिनिस्टिक तरीके से बनाते हैं. इनमें आम तौर पर, बिल्ड आईडी या टाइमस्टैंप शामिल होते हैं
  • सिस्टम बाइनरी, जो अलग-अलग होस्ट में अलग-अलग होती हैं. जैसे, /usr/bin बाइनरी, ऐब्सलूट पाथ, और बिल्ट-इन C++ नियमों के लिए सिस्टम C++ कंपाइलर ऑटोकॉन्फ़िगरेशन
  • बिल्ड के दौरान सोर्स ट्री में लिखना. इससे एक ही सोर्स ट्री को किसी दूसरे टारगेट के लिए इस्तेमाल करने से रोका जा सकता है. पहला बिल्ड, सोर्स ट्री में लिखता है. इससे टारगेट A के लिए सोर्स ट्री ठीक हो जाता है. इसलिए, टारगेट B को बनाने की कोशिश करने पर, हो सकता है कि वह न बन पाए.

नॉन-हर्मेटिक बिल्ड से जुड़ी समस्याओं को हल करना

स्थानीय तौर पर एक्ज़ीक्यूट करने से शुरू होने वाली, स्थानीय कैश हिट पर असर डालने वाली समस्याएं, गैर-हर्मेटिक कार्रवाइयों के बारे में बताती हैं.

  • पक्का करें कि कोई भी टारगेट दोबारा न बनाया गया हो: अगर आपने make चलाया है और आपको एक सफल बिल्ड मिला है, तो बिल्ड को फिर से चलाने पर कोई भी टारगेट दोबारा नहीं बनाया जाना चाहिए. अगर हर बिल्ड चरण को दो बार या अलग-अलग सिस्टम पर चलाया जाता है, तो फ़ाइल के कॉन्टेंट के हैश की तुलना करें. अगर आपको अलग-अलग नतीजे मिलते हैं, तो इसका मतलब है कि बिल्ड को फिर से नहीं बनाया जा सकता.
  • अलग-अलग क्लाइंट मशीन पर, स्थानीय कैश मेमोरी में मौजूद डेटा के इस्तेमाल से जुड़ी गड़बड़ियों को ठीक करने के लिए, ये चरण पूरे करें. इससे यह पक्का किया जा सकेगा कि क्लाइंट एनवायरमेंट से जुड़ी कोई भी जानकारी, कार्रवाइयों में शामिल न हो.
  • डॉकर कंटेनर में एक बिल्ड को एक्ज़ीक्यूट करें. इस कंटेनर में, चेक-आउट किया गया सोर्स ट्री और होस्ट टूल की सूची के अलावा कुछ और नहीं होना चाहिए. बिल्ड ब्रेक और गड़बड़ी के मैसेज से, सिस्टम की छिपी हुई डिपेंडेंसी का पता चलेगा.
  • रिमोट एक्ज़ीक्यूशन के नियमों का इस्तेमाल करके, हर्मेटिकिटी से जुड़ी समस्याओं का पता लगाना और उन्हें ठीक करना.
  • हर कार्रवाई के लेवल पर, स्ट्रिक्ट सैंडबॉक्सिंग चालू करें. ऐसा इसलिए, क्योंकि बिल्ड में कार्रवाइयां स्टेटफ़ुल हो सकती हैं और बिल्ड या आउटपुट पर असर डाल सकती हैं.
  • वर्कस्पेस के नियमों की मदद से डेवलपर, बाहरी वर्कस्पेस में डिपेंडेंसी जोड़ सकते हैं. हालांकि, ये नियम इतने बेहतर होते हैं कि प्रोसेस में किसी भी तरह की प्रोसेसिंग की जा सकती है. Bazel वर्कस्पेस के नियमों में, कुछ ऐसी कार्रवाइयों का लॉग पाया जा सकता है जो हर्मेटिक नहीं हैं. इसके लिए, आपको Bazel कमांड में --experimental_workspace_rules_log_file=PATH फ़्लैग जोड़ना होगा.

Bazel के साथ हरमैटिसिटी

इस बारे में ज़्यादा जानने के लिए कि अन्य प्रोजेक्ट में Bazel के साथ हर्मेटिक बिल्ड का इस्तेमाल करके कैसे सफलता हासिल की गई, BazelCon की ये बातचीत देखें: