Android बिल्ड परफ़ॉर्मेंस

समस्या की शिकायत करें सोर्स देखें

इस पेज पर खास तौर पर Android ऐप्लिकेशन के लिए, बिल्ड की परफ़ॉर्मेंस को ऑप्टिमाइज़ करने की जानकारी दी गई है. Basel की मदद से, बिल्ड की परफ़ॉर्मेंस को ऑप्टिमाइज़ करने के बारे में जानकारी पाने के लिए, परफ़ॉर्मेंस ऑप्टिमाइज़ करना देखें.

फ़्लैग bazelrc कॉन्फ़िगरेशन सिंटैक्स में होते हैं. इसलिए, उन्हें सीधे bazelrc फ़ाइल में चिपकाया जा सकता है. साथ ही, कमांड लाइन पर --config=<configuration_name> से शुरू किया जा सकता है.

परफ़ॉर्मेंस बेहतर करना

Baze, चैनल के आउटपुट बेस में डिफ़ॉल्ट रूप से command.profile.gz नाम की फ़ाइल के लिए, JSON ट्रेस प्रोफ़ाइल लिखता है. प्रोफ़ाइल को पढ़ने और उसके साथ इंटरैक्ट करने का तरीका जानने के लिए, JSON प्रोफ़ाइल का दस्तावेज़ देखें.

Android बिल्ड ऐक्शन के लिए स्थायी वर्कर.

Android बिल्ड ऐक्शन के एक सबसेट में लगातार काम करने वाले लोग काम कर सकते हैं.

याद रखने के इन तरीकों के बारे में यहां बताया गया है:

  • DexBuilder
  • जावैक
  • डिसुगर
  • AaptPackage
  • AndroidResourceParser
  • AndroidResourceValidator
  • AndroidResourceCompiler
  • RClassGenerator
  • AndroidResourceLink
  • AndroidAapt2
  • AndroidAssetMerger
  • AndroidResourceMerger
  • AndroidCompiledResourceMerger

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

कर्मचारियों को इन कार्रवाइयों के लिए चालू करने के लिए, कमांड लाइन पर --config=android_workers के साथ इन फ़्लैग को लागू करें:

build:android_workers --strategy=DexBuilder=worker
build:android_workers --strategy=Javac=worker
build:android_workers --strategy=Desugar=worker

# A wrapper flag for these resource processing actions:
# - AndroidResourceParser
# - AndroidResourceValidator
# - AndroidResourceCompiler
# - RClassGenerator
# - AndroidResourceLink
# - AndroidAapt2
# - AndroidAssetMerger
# - AndroidResourceMerger
# - AndroidCompiledResourceMerger
build:android_workers --persistent_android_resource_processor

हर कार्रवाई के हिसाब से लगातार काम करने वाले कर्मचारियों की डिफ़ॉल्ट संख्या 4 है. हमने बेहतर बिल्ड परफ़ॉर्मेंस को मापा है. इसके लिए, हर कार्रवाई के लिए इंस्टेंस की संख्या को 1 या 2 तक सीमित किया गया है. हालांकि, यह इस आधार पर अलग-अलग हो सकता है कि Bagel कौनसा सिस्टम इस्तेमाल कर रहा है और उसे कैसे बनाया जा रहा है.

किसी कार्रवाई के इंस्टेंस की संख्या सीमित करने के लिए, ये फ़्लैग लागू करें:

build:android_workers --worker_max_instances=DexBuilder=2
build:android_workers --worker_max_instances=Javac=2
build:android_workers --worker_max_instances=Desugar=2
build:android_workers --worker_max_instances=AaptPackage=2
# .. and so on for each action you're interested in.

AAPT2 का इस्तेमाल करना

aapt2 ने aapt की तुलना में बेहतर परफ़ॉर्मेंस दी है. साथ ही, इससे छोटे APK भी बनाए जाते हैं. aapt2 का इस्तेमाल करने के लिए, --android_aapt=aapt2 फ़्लैग का इस्तेमाल करें या android_binary और android_local_test पर, aapt_version पर aapt2 सेट करें.

एसएसडी ऑप्टिमाइज़ेशन

--experimental_multi_threaded_digest फ़्लैग, एसएसडी पर डाइजेस्ट कंप्यूटेशन को ऑप्टिमाइज़ करने में मदद करता है.