Zygote, Android ऑपरेटिंग सिस्टम में मौजूद एक प्रोसेस है. यह एक ही ऐप्लिकेशन बाइनरी इंटरफ़ेस (एबीआई) वाली सभी सिस्टम और ऐप्लिकेशन प्रोसेस के रूट के तौर पर काम करती है.
Pixel 7 और उसके बाद के वर्शन वाले मॉडर्न डिवाइसों पर, 64-बिट Zygote प्रोसेस होती है. इसके अलावा, मुख्य एबीआई के लिए वेबव्यू ज़ाइगोट है, जो कि एक खास Zygote है. इसमें वेबव्यू चलाने वाली प्रोसेस के लिए लाइब्रेरी और संसाधन शामिल हैं.
ज़ाइगोट ये काम करता है:
Android OS के शुरू होने पर, init डेमन, Zygote प्रोसेस को शुरू करता है. कुछ ड्यूअल आर्किटेक्चर सिस्टम पर, दो Zygote प्रोसेस (64-बिट और 32-बिट) शुरू की जाती हैं. इस पेज पर सिर्फ़ सिंगल आर्किटेक्चर सिस्टम के बारे में बताया गया है.
Zygote, ऐप्लिकेशन के लिए खास तौर पर बनी प्रोसेस (यूएसएपी) नाम की प्रोसेस को तुरंत शुरू कर सकता है. इसके अलावा, ऐप्लिकेशन के हिसाब से प्रोसेस शुरू करने का इंतज़ार भी कर सकता है. पहले विकल्प को सिस्टम प्रॉपर्टी या Android डीबग ब्रिज कमांड की मदद से चालू किया जाना चाहिए. प्रोसेस को तुरंत शुरू करने के लिए, Zygote को कॉन्फ़िगर करने के बारे में ज़्यादा जानने के लिए, ऐप्लिकेशन की सामान्य प्रोसेस पूल को चालू करना लेख पढ़ें.
अगर आपके डिवाइस पर USAP पूल चालू है, तो:
- सिस्टम सर्वर, पूल से उपलब्ध यूएसएपी से कनेक्ट करने के लिए, यूनिक्स डोमेन सॉकेट का इस्तेमाल करता है. सिस्टम सर्वर, प्रोसेस के आईडी (पीआईडी), सीजी ग्रुप, और अन्य जानकारी में बदलाव करके, ऐप्लिकेशन के इस्तेमाल के लिए यूएसएपी को पहले से कॉन्फ़िगर करने का अनुरोध करता है.
- जब USAP कॉन्फ़िगरेशन पूरा कर लेता है, तब यह सिस्टम सर्वर को पीआईडी के साथ जवाब देता है.
- जब कोई ऐप्लिकेशन इनमें से किसी यूएसएपी को हासिल कर लेता है, तो वह यूएसएपी पूल का हिस्सा नहीं रह जाता. जब पूल में एक या उससे कम यूएसएपी हो जाते हैं, तो Zygote पूल में नए यूएसएपी जोड़ देता है.
अगर आपका Zygote, लेज़ी इवैल्यूएशन का इस्तेमाल करके प्रोसेस शुरू करता है, तो:
- सिस्टम सर्वर को एक निर्देश मिलता है कि किसी ऐप्लिकेशन को प्रोसेस करने की ज़रूरत है.
- सिस्टम सर्वर, सही Zygote को निर्देश भेजने के लिए Unix डोमेन सॉकेट का इस्तेमाल करता है.
- Zygote प्रोसेस को बांट देता है और पीआईडी, सीग्रुप, और दूसरी जानकारी को बदल देता है.
- प्रोसेस पूरी होने पर, यह PID को Zygote में वापस भेजता है. इसके बाद, Zygote इसे सिस्टम सर्वर पर भेजता है.
USAP पूल चालू करना
USAP पूल का इस्तेमाल करने के लिए, इनमें से कोई एक काम करें:
/build/make/target/product/runtime_libart.mk
में,dalvik.vm.usap_pool_enabled
की सिस्टम प्रॉपर्टी कोtrue
पर सेट करें.नीचे दिया गया निर्देश चलाएं:
adb shell am broadcast -a \"com.google.android.gms.phenotype.FLAG_OVERRIDE\" --es package \"com.google.android.platform.runtime_native\" --es user \"\*\" --esa flags \"usap_pool_enabled\" --esa values \"true\" --esa types \"string\" com.google.android.gms
इस सुविधा के चालू होने पर, हर Zygote में फ़ॉर्क की गई प्रोसेस का एक पूल होता है. यह प्रोसेस, ऐप्लिकेशन के शुरू होने की प्रोसेस के उन हिस्सों को पूरा करती है जो ऐप्लिकेशन पर निर्भर नहीं होते.
Zygote से जुड़ी समस्याएं हल करना
इस सेक्शन में, Zygote से जुड़ी समस्याओं को हल करने के तरीके बताए गए हैं.
Zygote क्रैश हो रहा है
अगर आपका डिवाइस ठीक से रीबूट नहीं होता और आपके लॉग या क्रैश रिपोर्ट में Zygote से जुड़ी समस्याएं दिखती हैं, तो हो सकता है कि आपने हाल ही में कोई ऐसा बदलाव किया हो जिसकी वजह से initd या सिस्टम सर्वर क्रैश हो गया हो. कोड को ठीक करने से समस्या ठीक हो जानी चाहिए.
SELinux से अनुमति न मिलना या आईओ से जुड़ी गड़बड़ियां
Zygote, प्रोसेस की सीमाओं के बीच फ़ाइल डिस्क्रिप्टर की साफ़-सफ़ाई के बारे में खास तौर पर ध्यान रखता है. जब फ़ाइल डिस्क्रिप्टर, फ़ॉर्क के समय मौजूद होते हैं, लेकिन अनुमति वाली सूची में नहीं होते, तो हम dup
से /dev/null
के लिए सिस्टम कॉल का इस्तेमाल करते हैं. इससे, कैश मेमोरी में सेव किए गए फ़ाइल डिस्क्रिप्टर का इस्तेमाल, अनजाने में नई फ़ाइलों को ऐक्सेस करने के लिए नहीं किया जा सकता.
अगर फ़्रेमवर्क में बदलाव किए जा रहे हैं और उनमें Zygote में संसाधन लोड करने की कोशिश की जा रही है, तो आपको SELinux से अनुमति न मिलने या आईओ के काम न करने की गड़बड़ियां दिख सकती हैं. ऐसे में:
बिना नाम वाले फ़ाइल डिस्क्रिप्टर के लिए,
Restat
को कॉल करते समय, फ़ाइल डिस्क्रिप्टर कोfds_to_ignore
वेक्टर में शामिल करें.नाम वाले फ़ाइल डिस्क्रिप्टर के लिए:
WORKING_DIRECTORY/frameworks/base/core/jni/fd_utils.cpp
में बदलाव करें.- अनुमति वाली सूची में, खोली जा सकने वाली फ़ाइलों का पाथ जोड़ें.