- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
最近,我在为处理时间戳的 Java Spark 应用程序创建可靠的单元测试时遇到了很多麻烦。
具体来说,我很难说服自己,无论运行系统的时区如何,我正在测试的代码都会产生相同的结果。
以以下虚拟测试为起点:
public class TimestampsTest {
@Test
public void timestampsTest() {
SparkSession spark = SparkSessionBuilder.getTestSparkSession();
Timestamp timestamp1 = Timestamp.valueOf("2019-01-01 01:00:00");
println("Timestamp 1:");
println(timestamp1.toString());
println("Instant 1:");
println(timestamp1.toInstant().toString());
Timestamp timestamp2 = Timestamp.valueOf("2019-01-01 02:00:00");
println("Timestamp 2:");
println(timestamp2.toString());
println("Instant 2:");
println(timestamp2.toInstant().toString());
List<Row> rows = Arrays.asList(
RowFactory.create(timestamp1),
RowFactory.create(timestamp2)
);
StructType schema = DataTypes.createStructType(
Collections.singletonList(DataTypes.createStructField("timestamp", DataTypes.TimestampType, false))
);
println("Spark dataframe:");
Dataset<Row> df = spark.createDataFrame(rows, schema);
df.show();
}
}
输出如下:
Spark version:
2.4.3
Timestamp 1:
2019-01-01 01:00:00.0
Instant 1:
2019-01-01T06:00:00Z
Timestamp 2:
2019-01-01 02:00:00.0
Instant 2:
2019-01-01T07:00:00Z
Spark dataframe:
+-------------------+
| timestamp|
+-------------------+
|2019-01-01 01:00:00|
|2019-01-01 02:00:00|
+-------------------+
数据帧中的时间戳与我用来创建原始 Java 时间戳的文本输入相匹配,但底层时刻则不然。 (我在 EST5EDT 中运行它,因此 Timestamp 对象表示 EST5EDT 中的时间,而 Instant 对象在转换为字符串时以 UTC 表示。这完全是预期的。)
我的问题是这样的:
Spark 是使用时间戳对象的运行时 Java 表示来构建数据帧,还是使用 UTC 时刻,然后当我在数据帧上调用 show() 时简单地将它们显示在 EST5EDT 中?换句话说:java中时间戳的字符串表示形式与数据帧的内容之间是否存在确定性关系 或者 UTC时间轴上的时刻与数据帧的内容之间是否存在确定性关系?我知道,无论运行此代码的时区如何,df.show() 的输出都将是相同的,因为上述两种情况都会导致 show() 产生相同的输出。但是,如果我将数据帧的内容保存到 parquet,无论我的代码在哪个时区运行,我最终都会得到相同的结果吗?换句话说,如果我将此数据帧保存到 parquet,然后在具有不同本地时区的另一个环境中将其读入 Spark,数据帧是否相同?或者底层 UTC 时间将是相同的,这意味着本地表示将取决于我运行的本地时区?
最佳答案
我决定通过运行一些测试来回答我自己的问题。
如果将 Spark 数据帧中的时间戳读入不同时区的计算机上的数据帧,则写入 parquet 的时间戳将不同。换句话说,spark 似乎将 UTC 时间轴上的基础时刻的值保存到 parquet,然后在读取它的系统上处于 Activity 状态的任何本地时区中显示它。下面的测试证明了这一点:
我们需要的几个辅助函数:
void printStats(SparkSession spark, Timestamp timestamp1, Timestamp timestamp2, Dataset<Row> df) {
println("Spark version:");
println(spark.version());
println("");
println("Timezone:");
println(System.getProperty("user.timezone"));
println("Timestamp 1:");
println(timestamp1.toString());
println("Instant 1:");
println(timestamp1.toInstant().toString());
println("");
println("Timestamp 2:");
println(timestamp2.toString());
println("Instant 2:");
println(timestamp2.toInstant().toString());
println("");
println("Spark dataframe:");
df.show();
println("");
}
Dataset<Row> createDataframe(SparkSession spark, Timestamp timestamp1, Timestamp timestamp2) {
List<Row> rows = Arrays.asList(
RowFactory.create(timestamp1),
RowFactory.create(timestamp2)
);
StructType schema = DataTypes.createStructType(
Collections.singletonList(DataTypes.createStructField("timestamp", DataTypes.TimestampType, false))
);
return spark.createDataFrame(rows, schema);
}
首先在 EST 中写入一些时间戳以与机器进行 Parquet :
SparkSession spark = SparkSessionBuilder.getTestSparkSession();
Timestamp timestamp1 = Timestamp.valueOf("2019-01-01 01:00:00");
Timestamp timestamp2 = Timestamp.valueOf("2019-01-01 02:00:00");
Dataset<Row> df = createDataframe(spark, timestamp1, timestamp2);
printStats(spark, timestamp1, timestamp2, df);
String tempPath = "/temp/timestamps_test";
df.write().parquet(tempPath);
控制台输出:
Timezone:
America/New_York
Timestamp 1:
2019-01-01 01:00:00.0
Instant 1:
2019-01-01T06:00:00Z
Timestamp 2:
2019-01-01 02:00:00.0
Instant 2:
2019-01-01T07:00:00Z
Spark dataframe:
+-------------------+
| timestamp|
+-------------------+
|2019-01-01 01:00:00|
|2019-01-01 02:00:00|
+-------------------+
现在,我们将机器切换到 UTC 并将时间戳读回到新的数据帧中:
SparkSession spark = SparkSessionBuilder.getTestSparkSession();
String tempPath = "/temp/timestamps_test";
Dataset<Row> readDf = spark.read().parquet(tempPath);
Timestamp retrieved1 = (Timestamp) readDf.collectAsList().stream().map(r -> r.getTimestamp(0)).toArray()[0];
Timestamp retrieved2 = (Timestamp) readDf.collectAsList().stream().map(r -> r.getTimestamp(0)).toArray()[1];
printStats(spark, retrieved1, retrieved2, readDf);
输出:
Timezone:
UTC
Timestamp 1:
2019-01-01 06:00:00.0
Instant 1:
2019-01-01T06:00:00Z
Timestamp 2:
2019-01-01 07:00:00.0
Instant 2:
2019-01-01T07:00:00Z
Spark dataframe:
+-------------------+
| timestamp|
+-------------------+
|2019-01-01 06:00:00|
|2019-01-01 07:00:00|
+-------------------+
请注意,无论时区如何,时刻都是相同的,这表明 parquet 中存储的是 UTC 时刻,而不是本地时间戳。
关于java - 由 java 时间戳构造并写入 parquet 的 Spark 数据帧的内容是否会根据系统的本地时区而有所不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59274810/
我正在为我的按钮使用 onClick 功能。我的按钮代码如下所示: Button 1 Button 2 我的 JS 函数如下所示: function fadeNext(selectedId, spee
首先,我想提一下,我理解每个人在不提供至少一些试验或错误的情况下提出问题的感受,但这纯粹是一种知识需求,话虽如此,我会去提前问。 我一直无法弄清楚如何将保存在 MySQL 表中的 600-1000 个
我想做的事情有点令人困惑,而且我英语不太好,所以我先把代码贴在这里,这样你就可以很容易地理解: 以下是表单内容: Testing for Stackoverflow Option1
我学习 SDL 二维编程已有一段时间了,现在我想创建一个结合使用 SDL 和 OpenGL 的程序。我是这样设置的: SDL_Init(SDL_INIT_VIDEO); window = SDL_Cr
我创建了 2 个 data-* 标签。数据类别和数据标签。单击 href 标签后,我想复制该数据类别和数据标签以形成输入。我的代码是:
我想用 CSS 换行。我正在使用内容。 td:before { content: "Test\A Test2"; } 它不工作。如何正确
这个问题已经有答案了: Java Class that implements Map and keeps insertion order? (8 个回答) 已关闭 6 年前。 我有一个 HashMap
我正在尝试使用 JMeter 执行端到端测试。测试涉及写入SFTP文件夹并从另一个SFTP文件夹读取写入操作生成的文件。 我能够使用 JMeter SSH SFTP 插件连接到 SFTP 文件夹,并能
您好,我有带有标准服务器端 Servlet 的 GWT 客户端。 我可以从 GWT 客户端上传文件并在服务器端读取其内容 我可以将其作为字符串发送回客户端 但是 我有 GWT FormPanel与操作
我在 Plone 4.3.9 中创建了一个自定义类型的灵巧性,称为 PersonalPage,必须只允许在特定文件夹中使用 成员文件夹/用户文件夹 . 在他的 FTI 中,默认情况下 False .
在新(更新)版本的应用程序中更改小部件布局的最佳做法是什么?当新版本提供更新、更好的小部件时,如何处理现有小部件? 最佳答案 我认为您必须向用户显示一个弹出窗口,说明“此版本中的新功能”并要求他们重新
在我的应用程序中,我使用支持 View 寻呼机和 PagerTabStrip。进入查看寻呼机我有一些 fragment ,进入其中一个我正在使用支持卡片 View 。运行应用程序后,所有卡片 View
我有以下布局文件。基本上我有谷歌地图,在左上角我有一个 TextView,我需要在其中每 15 秒保持一次计数器以刷新 map 。布局很好。
我使用如下结构: HashMap > > OverallMap 如果我这样做: OverallMap . clear ( ) clear() 丢弃的所有内容(HashMap 对象、Integer 对
我在数据库中有 1000 张图像。在页面加载时,我随机显示 60 张图片,当用户滚动时,我通过 AJAX 请求添加 20 张图片。 第一种方法 我所做的是将所有图像加载到一个容器中,然后隐藏所有图像并
我正在使用 woocommerce 创建一个网上商店。 我想在每个产品上添加一个包含产品信息的表格,例如颜色、交货时间等等。 但是当我添加这张表时。本产品消失后的所有内容。 我的表的代码: td {
This question already has an answer here: What does an empty value for the CSS property content do?
因此,我正在与我的 friend 一起为 Google Chrome 开发一个扩展程序,对于大多数功能(即日历、设置等),我们打开一个模式,这样我们就不必重定向到另一个页面。当您在内容之外单击时,我们
我将可变高度的 CSS 框设置为在更大的 div 中向左浮动。现在我想添加一个标题,其中文本在框的左侧垂直显示(旋转 90 度),如下面的链接所示(抱歉还不能发布图片)。 http://imagesh
相关页面位于 www.codykrauskopf.com/circus 如果您查看我页面的右侧,在半透明容器和浏览器窗口边缘之间有一个间隙。我看了看,出于某种原因,wrap、main、content
我是一名优秀的程序员,十分优秀!