Android फ़्रेमवर्क, टाइम सिंक करने के लिए अलग-अलग टाइम सोर्स का इस्तेमाल करता है. यह पेज, नेटवर्क टाइम प्रोटोकॉल (एनटीपी) और Network Identity और टाइम ज़ोन (NITZ) के लिए, अपने-आप टाइम सोर्स का पता लगाने की सुविधा. Android 12 या इसके बाद के वर्शन में, डिफ़ॉल्ट रूप से फ़्रेमवर्क समय स्रोत के तौर पर NITZ को प्राथमिकता देता है, क्योंकि NTP NITZ की तुलना में ज़्यादा सटीक और भरोसेमंद है. ऐसे मामलों में जहां एनटीपी उपलब्ध नहीं होता, फ़्रेमवर्क एनआईटीज़ेड पर वापस चला जाता है. यह पहले के वर्शन की डिफ़ॉल्ट प्राथमिकता का उलटा है, जो प्लैटफ़ॉर्म. डिफ़ॉल्ट रूप से, Android 11 और इससे पहले के वर्शन में फ़्रेमवर्क, NITZ को प्राथमिकता देता है .
इस बदलाव के बारे में ज़्यादा जानकारी के लिए, ये एओएसपी पैच देखें: 1563678, 1513323.
समय के सोर्स की प्राथमिकता कॉन्फ़िगर करें
यह कॉन्फ़िगर करने के लिए कि किसी खास Android के लिए, समय के किस स्रोत को डिफ़ॉल्ट रूप से प्राथमिकता दी जाती है
वर्शन है, तो उसे कॉन्फ़िगर करें
config_autoTimeSourcesPriority
बिल्ड के समय frameworks/base/core/res/res/values/config.xml
की कुंजी. समय
सूची में सबसे ऊपर मौजूद टाइम सोर्स के सुझावों को प्राथमिकता दी जाती है
जो सूची में नीचे हैं.
Android टाइम सोर्स कॉन्फ़िगर किए जा सकते हैं
TimeDetectorStrategy.java
.
यहां दिए गए सोर्स, डिफ़ॉल्ट रूप से इस्तेमाल के लिए कॉन्फ़िगर किए जाते हैं:
- टेलीफ़ोनी (NITZ)
- नेटवर्क (NTP)
टेस्ट करना
यह पुष्टि करने के लिए कि एनटीपी उपलब्ध न होने पर डिवाइस, एनआईटीज़ेड का इस्तेमाल करता है (मोबाइल डेटा और वाई-फ़ाई बंद होने पर), ये काम करें:
- पक्का करें कि DUT में काम करने वाला सिम मौजूद हो
- मोबाइल डेटा और वाई-फ़ाई बंद करें
- यह पक्का करने के लिए कि सेल रेडियो बंद है, डिवाइस को हवाई जहाज़ मोड में रखें
- समय का अपने-आप पता लगाने की सुविधा को बंद करना
- घड़ी को भविष्य के लिए गलत समय मान पर मैन्युअल रूप से सेट करें
- डिवाइस को फिर से चालू करें
- समय का अपने-आप पता लगाने की सुविधा चालू करें
- डिवाइस को हवाई जहाज़ मोड से बाहर निकालें
ये चरण, एनआईटीZ होते ही सिस्टम की घड़ी में बदलाव ट्रिगर करते हैं सिग्नल मिल जाता है. डिवाइस का समय सेट करने का तरीका देखने के लिए, नीचे दिए गए निर्देशों का पालन करें आदेश:
adb shell dumpsys time_detector
यह पुष्टि करने के लिए कि सिस्टम की घड़ी, NITZ का इस्तेमाल करती है, कमांड में इसकी पुष्टि करें आउटपुट:
mEnvironment.isAutoTimeDetectionEnabled()
true
है.mEnvironment.autoOriginPriorities()
में समय स्रोतों की एक सूची शामिल है ऐसे सोर्स जो सूची में सबसे ऊपर हैं उन्हें प्राथमिकता दी जाती है, जबकि नीचे दिए गए सूची.Time change log
सेक्शन में बताया गया है कि सिस्टम की घड़ी टेलीफ़ोनी का सुझाव.Telephony suggestion history
सेक्शन में, समय के सुझाव होते हैं.Network suggestion history
सेक्शन खाली है.
Telephony suggestion history
और
Network suggestion history
सेक्शन को सबसे अहम माना जाता है
समय. अगर डिवाइस इंटरनेट से कनेक्ट है और उसमें सिम कार्ड है, तो
NTP (नेटवर्क) और NITZ (टेलीफ़ोनी) दोनों का इस्तेमाल करके जनरेट किया जाता है. इस टेस्ट केस में,
केवल Telephony suggestion history
अनुभाग में सुझाव हैं क्योंकि
एनटीपी बंद है.
Time change log
सेक्शन, डिवाइस की सेटिंग में किए गए बदलावों को रिकॉर्ड करता है
और इस्तेमाल किए गए सुझाव को दिखाता है. सिस्टम की घड़ी
में प्राथमिकता सूची में समय स्रोतों का क्रम
config_autoTimeSourcesPriority
कुंजी. हालांकि,
अगर सुझाव बहुत पुराना या अमान्य है, तो ज़्यादा प्राथमिकता वाले सोर्स को अनदेखा किया जा सकता है.
साथ ही, अगर सबसे ज़्यादा प्राथमिकता वाला मान्य सुझाव, डिवाइस के मौजूदा सुझाव से मेल खाता है
सिस्टम की घड़ी का समय कुछ सेकंड में बदल जाएगा, लेकिन समय नहीं बदलेगा.
इस परीक्षण मामले में, जब तक सुझाव पुराने नहीं हो जाते, सिस्टम घड़ी
Telephony suggestion history
के सुझावों में से किसी एक का इस्तेमाल करके सेट किया गया है.
नीचे एक ऐसे आउटपुट का उदाहरण दिया गया है जिसमें डिवाइस, लंबे समय तक चलने वाले NTP उपलब्ध न होने पर NITZ.
TimeDetectorStrategy:
mLastAutoSystemClockTimeSet=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}
mEnvironment.isAutoTimeDetectionEnabled()=true
mEnvironment.elapsedRealtimeMillis()=73059
mEnvironment.systemClockMillis()=1614186767818
mEnvironment.systemClockUpdateThresholdMillis()=2000
mEnvironment.autoTimeLowerBound()=2021-02-24T15:44:15Z(1614181455000)
mEnvironment.autoOriginPriorities()=[network,telephony]
Time change log:
66261 / 2021-02-24T17:12:41.020Z - Set system clock using time=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000} cause=Found good telephony suggestion., bestTelephonySuggestion=TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]}, detectionReason=New telephony time suggested. timeSuggestion=TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]} elapsedRealtimeMillis=66259 newSystemClockMillis=1614186761019
Telephony suggestion history:
key idx: 0=0
val idx: 0=TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]}
Historic values=[
0@PT1M6.258S: TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]}
]
Network suggestion history:
{Empty}
Gnss suggestion history:
{Empty}
External suggestion history:
{Empty}
जांच की स्थिति में, आउटपुट से तुलना के लिए नीचे एक सामान्य आउटपुट का उदाहरण दिया गया है, जिसमें डिवाइस NTP और NITZ दोनों समय स्रोतों से समय के सुझाव प्राप्त करता है.
TimeDetectorStrategy:
mLastAutoSystemClockTimeSet=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}
mEnvironment.isAutoTimeDetectionEnabled()=true
mEnvironment.elapsedRealtimeMillis()=302926
mEnvironment.systemClockMillis()=1614186997685
mEnvironment.systemClockUpdateThresholdMillis()=2000
mEnvironment.autoTimeLowerBound()=2021-02-24T15:44:15Z(1614181455000)
mEnvironment.autoOriginPriorities()=[network,telephony]
Time change log:
66261 / 2021-02-24T17:12:41.020Z - Set system clock using time=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000} cause=Found good telephony suggestion., bestTelephonySuggestion=TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]}, detectionReason=New telephony time suggested. timeSuggestion=TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]} elapsedRealtimeMillis=66259 newSystemClockMillis=1614186761019
Telephony suggestion history:
key idx: 0=0
val idx: 0=TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]}
Historic values=[
0@PT1M6.258S: TelephonyTimeSuggestion{mSlotIndex='0', mUtcTime=TimestampedValue{mReferenceTimeMillis=66240, mValue=1614186761000}, mDebugInfo=[Sending new time suggestion nitzSignal=TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}}, reason=handleNitzReceived(TimestampedValue{mReferenceTimeMillis=66240, mValue=NitzData{mOriginalString=21/02/24,17:12:41+00,00, mZoneOffset=0, mDstOffset=0, mCurrentTimeMillis=1614186761000, mEmulatorHostTimeZone=null}})]}
]
Network suggestion history:
0@PT4M4.04S: NetworkTimeSuggestion{mUtcTime=TimestampedValue{mReferenceTimeMillis=244038, mValue=1614186939242}, mDebugInfo=[Origin: NetworkTimeUpdateService. event=3]}
Gnss suggestion history:
{Empty}
External suggestion history:
{Empty}