2

使用 Logstash JDBC 输入插件获取数据时出现此异常:

error:
  26413962
  Sequel::InvalidValue
  TZInfo::AmbiguousTime: 2017-11-05T01:30:00+00:00 is an ambiguous local time.

这可能是因为我已经在我的 JDBC 插件中使用这个参数转换了我的时区:

   jdbc_default_timezone => "America/New_York"

因此,11 月 5 日凌晨 1:30 发生了两次,我怀疑 Logstash 不知道该做什么,它陷入了无限循环。

作为一种解决方法,我删除了 jdbc_default_timezone 参数,而是在 select 语句中将我的值转换为 UTC,如下所示:

 DATEADD(hh, DATEDIFF(hh, GETDATE(), GETUTCDATE()), th.[DueDate]) as DueDate 

但是这种解决方法很烦人,因为我需要修改所有的 logstash 输入日期列。

有没有办法强制它选择两个可能的时间中的任何一个,或者更优雅的方式?

4

1 回答 1

2

这似乎是 Logstash JDBC Input 插件中的一个已知错误,它被标记为 P2 增强。 https://github.com/logstash-plugins/logstash-input-jdbc/issues/121

同时,解决方法是将 SQL 查询中的所有日期和时间戳转换为 UTC,如上面问题(MS SQL 版本)中所述,或者对于 Oracle 版本是这样的:

select from_tz(cast(<column> as timestamp), 'CET') at time zone ('EST') "@timestamp"
    from <table>
    where ...

如果适用,我们还需要删除输入文件和过滤器中的 jdbc_default_timezone 参数。

于 2017-11-10T13:46:07.697 回答