本文基于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覆盖做测试使用。保险起见,刷整机