建设网站建议,大连手机网站设计,陕西省建设厅八大员证,全国的做网站的公司一、NTP介绍
NTP#xff1a;网络时间协议#xff0c;英文名称#xff1a;Network Time Protocol#xff08;NTP#xff09;是用来使计算机时间同步化的一种协议#xff0c; 它可以使计算机对其服务器或时钟源#xff08;如石英钟#xff0c;GPS等等)做同步化#xff…一、NTP介绍
NTP网络时间协议英文名称Network Time ProtocolNTP是用来使计算机时间同步化的一种协议 它可以使计算机对其服务器或时钟源如石英钟GPS等等)做同步化它可以提供高精准度的时间校正LAN上与标准间差小于1毫秒WAN上几十毫秒 且可介由加密确认的方式来防止恶毒的协议攻击。NTP的目的是在无序的Internet环境中提供精确和健壮的时间服务。
二、NTP对时机制
Android系统使用NTP自动更新系统时间的触发机制 1、监听数据库字段AUTO_TIME也就是开关网络时间选项当这个字段发生变化的时候会立即触发一次时间同步 2、网络连接发生变化当网络接通会触发一次时间检查和同步 3、定时更新机制当预定的时间到了会触发一次时间检查和同步
public void handleMessage(Message msg) {switch (msg.what) {case EVENT_AUTO_TIME_CHANGED:case EVENT_POLL_NETWORK_TIME:case EVENT_NETWORK_CHANGED:onPollNetworkTime(msg.what);break;}
}
三、检查与同步
frameworks/base/services/core/java/com/android/server/NetworkTimeUpdateService.javamPollingIntervalMs mContext.getResources().getInteger(com.android.internal.R.integer.config_ntpPollingInterval); // 正常获取网络时间间隔默认86400000秒也就是24小时mPollingIntervalShorterMs mContext.getResources().getInteger( com.android.internal.R.integer.config_ntpPollingIntervalShorter); // 3次快速尝试获取网络时间目的是防止网络不好间隔时间 60000秒也就是一分钟mTryAgainTimesMax mContext.getResources().getInteger( com.android.internal.R.integer.config_ntpRetry); // 快速尝试获取网络时间次数默认三次mTimeErrorThresholdMs mContext.getResources().getInteger( com.android.internal.R.integer.config_ntpThreshold); // ntp服务器时间与系统时间差阈值如果大于5秒则更新
以上信息可以通过命令dumpsys network_time_update_service 查看例如
PollingIntervalMs: 1d0h0m0s0ms
PollingIntervalShorterMs: 1m0s0ms
TryAgainTimesMax: 3
TimeErrorThresholdMs: 5s0ms
TryAgainCounter: 1
LastNtpFetchTime: 1m28s223ms
private void onPollNetworkTimeUnderWakeLock(int event) {final long refTime SystemClock.elapsedRealtime();// If NITZ time was received less than mPollingIntervalMs time ago,// no need to sync to NTP.if (mNitzTimeSetTime ! NOT_SET refTime - mNitzTimeSetTime mPollingIntervalMs) { // 如果开启NITZ 默认使用nitz更新的时间resetAlarm(mPollingIntervalMs);return;}final long currentTime System.currentTimeMillis();if (DBG) Log.d(TAG, System time currentTime);// Get the NTP timeif (mLastNtpFetchTime NOT_SET || refTime mLastNtpFetchTime mPollingIntervalMs|| event EVENT_AUTO_TIME_CHANGED) {if (DBG) Log.d(TAG, Before Ntp fetch);// force refresh NTP cache when outdatedif (mTime.getCacheAge() mPollingIntervalMs) { // 开机没有获取到网络时间强制执行连接ntp服务器获取时间mTime.forceRefresh();}// only update when NTP time is freshif (mTime.getCacheAge() mPollingIntervalMs) { // 如果已经获取到网络时间计算时间差并设置系统时间final long ntp mTime.currentTimeMillis();mTryAgainCounter 0;// If the clock is more than N seconds off or this is the first time its been// fetched since boot, set the current time.if (Math.abs(ntp - currentTime) mTimeErrorThresholdMs // 时间差小于5秒 则更新时间|| mLastNtpFetchTime NOT_SET) {// Set the system timeif (DBG mLastNtpFetchTime NOT_SET Math.abs(ntp - currentTime) mTimeErrorThresholdMs) {Log.d(TAG, For initial setup, rtc currentTime);}if (DBG) Log.d(TAG, Ntp time to be set ntp);// Make sure we dont overflow, since its going to be converted to an intif (ntp / 1000 Integer.MAX_VALUE) {SystemClock.setCurrentTimeMillis(ntp); // 更新系统时间,LOG为AlarmManagerService: Setting time of day to sec1721811969查看时间是否更新}} else {if (DBG) Log.d(TAG, Ntp time is close enough ntp);}mLastNtpFetchTime SystemClock.elapsedRealtime();} else {// Try again shortlymTryAgainCounter;if (mTryAgainTimesMax 0 || mTryAgainCounter mTryAgainTimesMax) { // 如果没有获取到网络时间就间隔一分钟后重试resetAlarm(mPollingIntervalShorterMs);} else {// Try much later mTryAgainCounter 0;resetAlarm(mPollingIntervalMs); // 尝试三次 间隔一分钟获取一次还没有获取到时 则24小时后再尝试}return;}}resetAlarm(mPollingIntervalMs); // 时间已经设置成功24小时后再获取}frameworks/base/core/java/android/util/NtpTrustedTime.javafinal String defaultServer res.getString(com.android.internal.R.string.config_ntpServer); // 默认NTP服务器2.android.pool.ntp.orgfinal long defaultTimeout res.getInteger( com.android.internal.R.integer.config_ntpTimeout); // 连接NTP服务器超时时间默认5秒final String secureServer Settings.Global.getString( resolver, Settings.Global.NTP_SERVER); // 可以通过命令动态修改ntp服务器重启后生效 adb shell settings put global ntp_server ntp2.aliyun.comfinal long timeout Settings.Global.getLong( resolver, Settings.Global.NTP_TIMEOUT, defaultTimeout); // 可以通过命令动态修改ntp服务器超时时间重启后生效 adb shell settings put global ntp_timeout 50000final String server secureServer ! null ? secureServer : defaultServer;
sSingleton new NtpTrustedTime(server, timeout); // 动态配置npt服务器地址 与超时时间public boolean forceRefresh() {if (LOGD) Log.d(TAG, forceRefresh() from cache miss);final SntpClient client new SntpClient();if (client.requestTime(mServer, (int) mTimeout)) { // 获取网络时间mHasCache true;mCachedNtpTime client.getNtpTime();mCachedNtpElapsedRealtime client.getNtpTimeReference();mCachedNtpCertainty client.getRoundTripTime() / 2;return true;} else {return false;}}
四、调试
1、确认当前NTP服务器地址adb shell settings get global ntp_server 为空时 则需要查看代码中默认的服务器。
2、修改NTP服务器adb shell settings put global ntp_server ntp2.aliyun.com
3、logcat | grep -Ei NetworkTimeUpdateService|SntpClient|AlarmManagerService 查看服务及NTP服务器是否异常
4、dumpsys network_time_update_service 查看对时默认配置比如时间差快速重试时间快速重试次数等