इस पेज पर, कैश हिट रेट की जांच करने का तरीका बताया गया है. साथ ही, रिमोट एक्ज़ीक्यूशन के संदर्भ में कैश मिस की जांच करने का तरीका बताया गया है.
इस पेज पर यह माना गया है कि आपके पास ऐसा बिल्ड और/या टेस्ट है जो रिमोट एक्ज़ीक्यूशन का इस्तेमाल करता है. साथ ही, आपको यह पक्का करना है कि रिमोट कैश का इस्तेमाल सही तरीके से किया जा रहा हो.
कैश हिट रेट की जांच करना
Bazel रन के स्टैंडर्ड आउटपुट में, INFO लाइन देखें. इसमें प्रोसेस की सूची दी गई होती है. ये प्रोसेस, Bazel की कार्रवाइयों से मिलती-जुलती होती हैं. इस लाइन में, यह जानकारी दी गई है कि कार्रवाई कहां की गई थी. remote लेबल देखें. इससे पता चलता है कि कोई कार्रवाई रिमोट तरीके से की गई है. linux-sandbox लेबल से पता चलता है कि कोई कार्रवाई लोकल सैंडबॉक्स में की गई है. साथ ही, अन्य वैल्यू से पता चलता है कि कार्रवाई करने की अन्य रणनीतियां इस्तेमाल की गई हैं. जिस कार्रवाई का नतीजा रिमोट कैश से मिला है उसे remote cache hit के तौर पर दिखाया जाता है.
उदाहरण के लिए:
INFO: 11 processes: 6 remote cache hit, 3 internal, 2 remote.
इस उदाहरण में, छह रिमोट कैश हिट थे. साथ ही, दो कार्रवाइयों में कैश हिट नहीं थे और उन्हें रिमोट तरीके से लागू किया गया था. तीसरे इंटरनल पार्ट को अनदेखा किया जा सकता है.
आम तौर पर, ये छोटी-छोटी कार्रवाइयां होती हैं. जैसे, सिंबॉलिक लिंक बनाना. इस खास जानकारी में, लोकल कैश मेमोरी से मिले जवाबों को शामिल नहीं किया गया है. अगर आपको 0 प्रोसेस दिख रही हैं या उम्मीद से कम प्रोसेस दिख रही हैं, तो bazel clean चलाएं. इसके बाद, अपनी बिल्ड/टेस्ट कमांड चलाएं.
कैश हिट से जुड़ी समस्याओं को हल करना
अगर आपको उम्मीद के मुताबिक कैश हिट रेट नहीं मिल रहा है, तो यह तरीका अपनाएं:
पक्का करें कि एक ही बिल्ड/टेस्ट कमांड को फिर से चलाने पर, कैश मेमोरी में मौजूद डेटा का इस्तेमाल हो
उन बिल्ड और/या टेस्ट को चलाएं जिनसे आपको कैश मेमोरी में डेटा भरने की उम्मीद है. किसी स्टैक पर पहली बार नई बिल्ड चलाने पर, आपको रिमोट कैश हिट नहीं मिलेंगे. रिमोट एक्ज़ीक्यूशन के तहत, कार्रवाई के नतीजे कैश मेमोरी में सेव किए जाते हैं. इसके बाद, उन्हें अगले रन में इस्तेमाल किया जाना चाहिए.
bazel cleanरन करें. इस कमांड से आपकी लोकल कैश मेमोरी मिट जाती है. इससे आपको रिमोट कैश मेमोरी के हिट की जांच करने में मदद मिलती है. ऐसा इसलिए, क्योंकि लोकल कैश मेमोरी के हिट से नतीजे मास्क नहीं होते.जिन बिल्ड और टेस्ट की जांच की जा रही है उन्हें उसी मशीन पर फिर से चलाएं.
कैश हिट रेट के लिए,
INFOलाइन देखें. अगर आपकोremote cache hitऔरinternalके अलावा कोई अन्य प्रोसेस नहीं दिखती है, तो इसका मतलब है कि आपकी कैश मेमोरी में सही तरीके से डेटा भरा जा रहा है और उसे ऐक्सेस किया जा रहा है. ऐसे में, अगले सेक्शन पर जाएं.गड़बड़ी की वजह यह हो सकती है कि बिल्ड में कुछ ऐसा है जो हर्मेटिक नहीं है. इसकी वजह से, दोनों रन में कार्रवाइयों को अलग-अलग ऐक्शन कुंजियां मिलती हैं. उन कार्रवाइयों को ढूंढने के लिए, यह तरीका अपनाएं:
a. एक्ज़ीक्यूशन लॉग पाने के लिए, समस्या वाली बिल्ड या जांच को फिर से चलाएं:
bazel cleanbazel --optional-flags build //your:target --execution_log_binary_file=/tmp/exec1.logb. दोनों रन के बीच एक्ज़ीक्यूशन लॉग की तुलना करें. पक्का करें कि दोनों लॉग फ़ाइलों में कार्रवाइयां एक जैसी हों. अंतर से, रन के बीच हुए बदलावों के बारे में जानकारी मिलती है. इन अंतरों को हटाने के लिए, अपना बिल्ड अपडेट करें.
अगर आपने कैश मेमोरी से जुड़ी समस्याओं को हल कर लिया है और अब बार-बार अनुरोध करने पर सभी कैश हिट मिलते हैं, तो अगले सेक्शन पर जाएं.
अगर आपके ऐक्शन आईडी एक जैसे हैं, लेकिन कोई कैश हिट नहीं है, तो इसका मतलब है कि आपके कॉन्फ़िगरेशन में कोई समस्या है. इसकी वजह से, कैश मेमोरी में सेव नहीं किया जा रहा है. सामान्य समस्याओं की जांच करने के लिए, इस सेक्शन को पढ़ना जारी रखें.
अगर आपको एक्ज़ीक्यूशन लॉग की तुलना करने की ज़रूरत नहीं है, तो इसके बजाय,
--execution_log_json_fileफ़्लैग का इस्तेमाल किया जा सकता है. इसका इस्तेमाल, स्टेबल डिफ़िंग के लिए नहीं किया जा सकता. ऐसा इसलिए, क्योंकि इसमें एक्ज़ीक्यूशन टाइम शामिल होता है और यह क्रम की गारंटी नहीं देता.देखें कि एक्ज़ीक्यूशन लॉग में मौजूद सभी कार्रवाइयों के लिए,
cacheableकी वैल्यू true पर सेट हो. अगर किसी कार्रवाई के लिए, एक्ज़ीक्यूशन लॉग मेंcacheableनहीं दिखता है, तो इसका मतलब है किBUILDफ़ाइल में, उससे जुड़े नियम की परिभाषा मेंno-cacheटैग मौजूद हो सकता है. ऑटोमेशन लागू होने के लॉग में,progress_messageफ़ील्ड को देखें. इससे यह पता लगाने में मदद मिलेगी कि कार्रवाई कहां से हो रही है.अगर कार्रवाइयां एक जैसी हैं और
cacheableलेकिन कोई कैश हिट नहीं है, तो ऐसा हो सकता है कि आपकी कमांड लाइन में--noremote_accept_cachedशामिल हो. इससे किसी बिल्ड के लिए कैश लुकअप बंद हो जाएंगे.अगर आपको असल कमांड लाइन का पता लगाने में मुश्किल हो रही है, तो Build Event Protocol से कैननिकल कमांड लाइन का इस्तेमाल करें. इसके लिए, यहां दिया गया तरीका अपनाएं:
a. लॉग का टेक्स्ट वर्शन पाने के लिए, अपनी Bazel कमांड में
--build_event_text_file=/tmp/bep.txtजोड़ें.b. लॉग का टेक्स्ट वर्शन खोलें और
structured_command_lineमैसेज मेंcommand_line_label: "canonical"खोजें. एक्सपैंड करने के बाद, इसमें सभी विकल्प दिखेंगे.c.
remote_accept_cachedखोजें और देखें कि यहfalseपर सेट है या नहीं.d. अगर
remote_accept_cachedकी वैल्यूfalseहै, तो पता लगाएं कि इसेfalseपर कहां सेट किया जा रहा है: कमांड लाइन पर या bazelrc फ़ाइल में.
सभी मशीन पर कैश मेमोरी की सुविधा चालू करना
जब एक ही मशीन पर कैश मेमोरी हिट होने लगे, तब उसी बिल्ड/टेस्ट को किसी दूसरी मशीन पर चलाएं. अगर आपको लगता है कि सभी मशीनों पर कैश मेमोरी काम नहीं कर रही है, तो यह तरीका अपनाएं:
अपनी बिल्ड में थोड़ा बदलाव करें, ताकि मौजूदा कैश मेमोरी का इस्तेमाल न हो.
पहले मशीन पर बिल्ड चलाएं:
bazel cleanbazel ... build ... --execution_log_binary_file=/tmp/exec1.logदूसरे मशीन पर बिल्ड चलाएं. साथ ही, यह पक्का करें कि पहले चरण में किया गया बदलाव शामिल हो:
bazel cleanbazel ... build ... --execution_log_binary_file=/tmp/exec2.logदोनों रन के लिए, एक्ज़ीक्यूशन लॉग की तुलना करें. अगर लॉग एक जैसे नहीं हैं, तो अपनी बिल्ड कॉन्फ़िगरेशन की जांच करें. इससे आपको गड़बड़ियों के साथ-साथ, होस्ट एनवायरमेंट की प्रॉपर्टी के बारे में भी पता चलेगा. ये प्रॉपर्टी, दोनों में से किसी एक बिल्ड में लीक हो रही हैं.
ऑटोमेशन लागू होने के लॉग की तुलना करना
एक्ज़ीक्यूशन लॉग में, बिल्ड के दौरान की गई सभी कार्रवाइयों के रिकॉर्ड होते हैं. हर कार्रवाई के लिए, SpawnExec एलिमेंट होता है. इसमें कार्रवाई की कुंजी की पूरी जानकारी होती है. इसलिए, अगर लॉग एक जैसे हैं, तो ऐक्शन कैश की कुंजियां भी एक जैसी होंगी.
अगर दो बिल्ड के लॉग में, कैश हिट को उम्मीद के मुताबिक शेयर नहीं किया जा रहा है, तो उनकी तुलना करने के लिए, यह तरीका अपनाएं:
हर बिल्ड से एक्ज़ीक्यूशन लॉग पाएं और उन्हें
/tmp/exec1.logऔर/tmp/exec2.logके तौर पर सेव करें.Bazel के सोर्स कोड को डाउनलोड करें. इसके बाद, यहां दिए गए निर्देश का इस्तेमाल करके, Bazel फ़ोल्डर पर जाएं. execlog parser की मदद से, आपको एक्ज़ीक्यूशन लॉग पार्स करने के लिए सोर्स कोड की ज़रूरत होती है.
git clone https://github.com/bazelbuild/bazel.git cd bazelलॉग को टेक्स्ट में बदलने के लिए, एक्ज़ीक्यूशन लॉग पार्सर का इस्तेमाल करें. नीचे दिए गए इनवोकेशन से, दूसरे लॉग में मौजूद कार्रवाइयों को भी क्रम से लगाया जाता है, ताकि उनकी तुलना पहले लॉग में मौजूद कार्रवाइयों के क्रम से की जा सके.
bazel build src/tools/execlog:parser bazel-bin/src/tools/execlog/parser \ --log_path=/tmp/exec1.log \ --log_path=/tmp/exec2.log \ --output_path=/tmp/exec1.log.txt \ --output_path=/tmp/exec2.log.txt/tmp/exec1.log.txtऔर/tmp/exec2.log.txtमें अंतर देखने के लिए, अपने पसंदीदा टेक्स्ट डिफ़र का इस्तेमाल करें.