Kylin增量cube build的restAPI的时间不准确的BUG

Kylin1.6增量cube build的restAPI的时间不准确的bug:
描述:使用restAPI:curl -X PUT -u "ADMIN:KYLIN" -H "Content-Type:application/json;charset=utf-8" -d '{"startTime":1508601600000,"endTime":1508688000000,"buildType":"BUILD"}' http://172.17.60.45:7070/kylin/api/cubes/bi_dispatch_waiting_service_cube/rebuild
增量构建时间设置【2017-10-22~2017-10-23 】,但是实际时间cube的构建抽取数据时间确比设置时间提前1天(实际上是提前8小时)【2017-10-21 ~2017-10-22 】,但是使用kylinUI构建却没有问题,实际查看kylin源码发现,是由于kylin在server端源码使用的timezone固定为GMT而非配置的GMT+8,而前端UI会根据配置的timezone对页面添加的时间进行转换变GMT+8的时间,然后后端将GMT+8时间在转化为GMT的时间,所以kylinUI的cube构建时间不会出现错误,而使用restAPI构建cube时间不进行timezone转化就是出现时间不准确差8个小时的问题。
解决方案
1. 调用rest API时手动进行时区转换
2.对kylin代码进行修改动态获取配置的timezone,但是修改code这个范围很大,前端UI和server端code都需要修改时间
KYLIN代码分析:
1. cube segment 的命名硬编码为使用时区GMT

2.前端UI会获取时区配置进行转换:

3.cube构建时间的传递的时间戳startTime和endtime都是使用DateFormat按照GMT时区转化对应的时间格式:

我在查看KYLIN文档时,没有看到对该问题的描述,在考虑KYLIN这种设计是想在server屏蔽timezone复杂度,使用同一的gmt时区处理时间,采用前端UI来处理传参的时间问题,但是忽略restAPI用户不会出里这种问题,应该在文档提前说明该问题,否则困扰使用restAPI的用户,以上皆为本人使用过程中遇到问题,如果错误请多谢支持,及时改正。


转自 https://blog.csdn.net/xiaolinzi007/article/details/78293061

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值