Android系统时区库tzdata更新

本文基于android P,系统的时区库版本号为tzdata2018;

tzdata更新

如果某个城市时区的夏令时时间异常,或者是时区时间异常时,可以考虑是否是时区库里有错误?或者时区库是否而已更新成最新的?
主要涉及到的源码路径如下:
代码路径:system\timezone
数据库源路径:system\timezone\input_data\iana\ 里面有对应版本号的数据库压缩文件
执行脚本:update-tzdata.py(执行时先soure ,lunch ,make)
tzdata生成路径: system\timezone\output_data\iana\tzdata
机器里路径:system/usr/share/zoneinfo/tzdata

1, 修改系统时区库tzdata

参照了:https://blog.csdn.net/qq_37960503/article/details/132305338

修改方法:
以android p上自带的tzdata数据库tzdata2018e.tar.gz为例。在开发时,发现在设置Africa/Sao_Tome时区时,系统时间快了一个小时。官方查询到这个城市是0时区,也不支持夏令时,所以怀疑是tzdata数据库里这个城市的时区搞错了;

找到文件system/timezone/input_data/iana/tzdata2018c.tar.gz,需要将这个压缩包先解压缩,修改完以后再压缩回来;

1.1. 解压缩
解压缩后会生成一堆文件,类似于下面这些:

uluxy181@ubuntu16-010:~/workspace3/mtk/system/timezone/input_data/iana/0000$ tar -zxvf tzdata2018e.tar.gz
calendars
CONTRIBUTING
LICENSE
Makefile
NEWS
README
theory.html
version
africa
antarctica
asia
australasia
europe
northamerica
southamerica
etcetera
systemv
factory
backward
pacificnew
backzone
iso3166.tab
leap-seconds.list
leapseconds
yearistype.sh
zone1970.tab
zone.tab
checklinks.awk
checktab.awk
leapseconds.awk
ziguard.awk
zishrink.awk
zoneinfo2tdf.pl

上面这些文件中,就有每个大洲对应的文件,里面记录了城市的时区规则,夏令时规则等信息。因为Sao_Tome是非洲城市,所以我们可以打开非洲对应的文件查找对应的时区策略;

# From Steffen Thorsen (2018-01-08):
# Multiple sources tell that São Tomé changed from UTC to UTC+1 as
# they entered the year 2018.
# From Michael Deckers (2018-01-08):
# the switch is from 01:00 to 02:00 ... [Decree No. 25/2017]
# http://www.mnec.gov.st/index.php/publicacoes/documentos/file/90-decreto-lei-n-25-2017

Zone	Africa/Sao_Tome	 	0:26:56 	-	LMT	1884
							-0:36:45 	-	LMT	1912 Jan  1 00:00u # Lisbon MT
			 				0:00		-	GMT	2018 Jan  1 01:00
			 				1:00		-	WAT

1.2 修改时区信息
可以看到最新的时区规则上sao_tome不是在0时区,而是1时区,这里就是我们可以修改的点。我们可以把1修改成0,可以达到修改时区的目的;

Zone	Africa/Sao_Tome	 0:26:56 -	LMT	1884
			-0:36:45 -	LMT	1912 Jan  1 00:00u # Lisbon MT
			 0:00	-	GMT	2018 Jan  1 01:00
			 0:00	-	WAT  //直接修改这里

1.3 重新再压缩文件成tzdata2018c.tar.gz

1.4 执行update-tzdata.py重新生成tzdata库
先在根目录source build/envsetup.sh,然后lunch,make。接着执行./system/timezone/update-tzdata.py
这时候可以执行git status看一下当前的文件更新情况,会发现几个文件都有更新,主要就是system/timezone/output_data/iana/tzdata 文件。这时候可以get status看一下状态

uluxy181@ubuntu16-010:~/workspace3/mtk/system/timezone$ git status
Not currently on any branch.
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

	modified:   input_data/iana/tzdata2018e.tar.gz
	modified:   output_data/iana/tzdata
	modified:   output_data/icu_overlay/icu_tzdata.dat

no changes added to commit (use "git add" and/or "git commit -a")

在执行updata-tzdata.py时,正常情况应该是编译顺利完成。但如果最后出现这个的打印,不要慌,不是报错,这个已经编译好了tzdata,不信可以make -j12后,刷机验证;

WARNING: Please consider reporting this to the maintainers of com.google.protobuf.Utf8$UnsafeProcessor
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release
I: Issues:
[country=st, id=Africa/Sao_Tome, offset=1:00, shownInPicker=true]: Offset mismatch: You will want to confirm the ordering for st still makes sense. Raw offset for Africa/Sao_Tome is 02:00 and not 01:00 at July 2, 2019 at 12:00:00 PM UTC

Traceback (most recent call last):
  File "./update-tzdata.py", line 253, in <module>
    main()
  File "./update-tzdata.py", line 239, in main
    BuildTzlookup(iana_data_dir)
  File "./update-tzdata.py", line 182, in BuildTzlookup
    countryzones_source_file, zone_tab_file, tzlookup_dest_file])
  File "/usr/lib/python2.7/subprocess.py", line 541, in check_call
    raise CalledProcessError(retcode, cmd)
subprocess.CalledProcessError: Command '['java', '-jar', '/home/YFCO/uluxy181/workspace3/mtk/out/host/linux-x86/framework/tzlookup_generator.jar', '/home/YFCO/uluxy181/workspace3/mtk/system/timezone/input_data/android/countryzones.txt', '/tmp/tmpZp4S8y-tzdata/iana_data/zone.tab', '/home/YFCO/uluxy181/workspace3/mtk/system/timezone/output_data/android/tzlookup.xml']' returned non-zero exit status 1
uluxy181@ubuntu16-010:~/workspace3/mtk/system/timezone$

1.5 重新编译系统,然后刷机验证
可以单独将生成的output_data/iana/tzdata push到车机的system/usr/share/zoneinfo目录,重启验证是否有效。
保险起见,整编烧录验证。

2,更新系统世间库tzdata

如果系统里的tzdata数据库太老了,可以尝试更新整个数据库,基本的方法如下;
参照:https://blog.csdn.net/qq_44865086/article/details/97410226
2.1. 下载最新tzdata库
打开/system/timezone/input_data/iana/目录可以看到类似名字为tzdata2018e.tar.gz的压缩包和tzdata2018e.tar.gz.asc文件,不同的android版本这个tzdata的版本号可能不同,根据这个压缩包的版本信息到网站ftp://ftp.iana.org/tz/releases/下载对应版本的 tzdata*.tar.gz和tzdata×.tar.gz.asc,当前最新的是tzdata2023c。
网站打开这个样子,往下面翻,就能找到对应的tzdata;
在这里插入图片描述

2.2 替换库
将下载的文件tzdata2023c.tar.gz和tzdata2023c.tar.gz.asc放到system\timezone\input_data\iana目录下,之前的2018版本删除掉。

uluxy181@ubuntu16-010:~/workspace3/mtk/system/timezone/input_data/iana$ git status
Not currently on any branch.
Changes not staged for commit:
  (use "git add/rm <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

	deleted:    tzdata2018e.tar.gz
	deleted:    tzdata2018e.tar.gz.asc

Untracked files:
  (use "git add <file>..." to include in what will be committed)

	tzdata2023c.tar.gz
	tzdata2023c.tar.gz.asc

no changes added to commit (use "git add" and/or "git commit -a")
uluxy181@ubuntu16-010:~/workspace3/mtk/system/timezone/input_data/iana$

2.3 update tzdata
切换到编译环境中(执行source build/envsetup.sh与lunch),然后进入/system/timezone/目录,执行update-tzdata.py,执行方法: python update-tzdata.py。
但我在直接执行时报错:

...
gunzip -d < ./tzdata2023c.tar.gz | tar xf - --exclude=Makefile
touch tdatamarker
make: *** No rule to make target 'yearistype.sh', needed by 'yearistype'.  Stop.
make: Leaving directory '/tmp/tmp_B2D9d-tzdata/icu/tools/tzcode'
Traceback (most recent call last):
  File "update-tzdata.py", line 253, in <module>
    main()
  File "update-tzdata.py", line 231, in main
    BuildIcuData(iana_data_tar_file)
  File "update-tzdata.py", line 94, in BuildIcuData
    icuutil.MakeTzDataFiles(icu_build_dir, iana_data_tar_file)
  File "/home/YFCO/uluxy181/workspace3/mtk/external/icu/tools/icuutil.py", line 103, in MakeTzDataFiles
    subprocess.check_call(['make', '-C', tzcode_working_dir])
  File "/usr/lib/python2.7/subprocess.py", line 541, in check_call
    raise CalledProcessError(retcode, cmd)
subprocess.CalledProcessError: Command '['make', '-C', '/tmp/tmp_B2D9d-tzdata/icu/tools/tzcode']' returned non-zero exit status 2

原则上icu的库和tzdata库是独立的,可以分开升级,所以这里我选择注释掉对icu的编译

uluxy181@ubuntu16-010:~/workspace3/mtk/system/timezone$ git diff update-tzdata.py
diff --git a/update-tzdata.py b/update-tzdata.py
index 20986c7..7a8f7d9 100755
--- a/update-tzdata.py
+++ b/update-tzdata.py
@@ -228,7 +228,7 @@ def main():
   icu_dir = icuutil.icuDir()
   print 'Found icu in %s ...' % icu_dir
 
-  BuildIcuData(iana_data_tar_file)
+##  BuildIcuData(iana_data_tar_file)
 
   iana_tools_dir = '%s/iana' % timezone_input_tools_dir
   zic_binary_file = BuildZic(iana_tools_dir)

2.4、执行脚本完成后,会在system/timezone中生成:
output_data/iana/tzdata

2.5、重新编译整个工程即可。
如果只是测试,可以直接将output_data/iana/生成新的tzdata放到机器对应的system/usr/share/zoneinfo目录将之前的tzdata覆盖做测试使用。保险起见,刷整机

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果系统时区已经设置为Asia/Shanghai,但Java应用程序获取到的时区仍然不正确,可以尝试以下方法: 1. 确认Java应用程序使用的是正确的时区 可以通过在Java应用程序中添加以下代码来输出当前时区: ``` System.out.println(TimeZone.getDefault().getID()); ``` 如果输出的时区不是“Asia/Shanghai”,则说明Java应用程序可能使用了其他时区。可以尝试在Java应用程序中设置时区,例如: ``` TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai")); ``` 2. 确认Java版本和时区数据版本的兼容性 Java的时区信息是通过时区数据tzdata)来维护的,不同版本的Java可能需要使用不同版本的时区数据。如果Java版本和时区数据版本不兼容,可能会导致获取到的时区不正确。 可以通过以下命令来查看当前Java使用的时区数据版本: ``` java -jar tzupdater.jar -V ``` 其中“tzupdater.jar”是Java时区更新工具,可以从Oracle官网下载。如果当前Java使用的时区数据版本与系统时区不一致,可以尝试更新时区数据。 3. 确认系统时间同步服务是否正常 如果系统时间同步服务不正常,可能会导致系统时间和Java应用程序获取到的时间不一致。可以通过以下命令来检查系统时间同步服务是否正常: ``` sudo systemctl status systemd-timesyncd.service ``` 如果系统时间同步服务不正常,可以尝试重启服务或者使用其他时间同步服务。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值