这是我的简单代码,它从pubsub订阅中读取,并使用当前时间戳将邮件正文保存到Cassandra表中。
消息已从订阅中使用,但是没有记录插入到表中,也没有错误消息。
但是,如果我在TestTable类中将Date类型的“ Timestamp”更改为Long,则此代码有效,并将记录插入到表中。
这是创建表的脚本。
DROP TABLE IF EXISTS test_table;
CREATE TABLE IF NOT EXISTS test_table(
post_index int,
ingestion_time TIMESTAMP,
body text,
PRIMARY KEY ((post_index))
);
@Table(keyspace = "{keyspace_name}", name = "{table_name}",
readConsistency = "LOCAL_QUORUM",
writeConsistency = "LOCAL_QUORUM",
caseSensitiveKeyspace = false,
caseSensitiveTable = false)
class TestTable implements Serializable {
@PartitionKey
@Column(name="post_index")
Integer postIndex;
@Column(name="ingestion_time")
Timestamp ingestionTime;
@Column(name = "body")
String body;
public Integer getPostIndex() {
return postIndex;
}
public void setPostIndex(Integer postIndex) {
this.postIndex = postIndex;
}
public Timestamp getIngestionTime() {
return ingestionTime;
}
public void setIngestionTime(Timestamp ingestionTime) {
this.ingestionTime = ingestionTime;
}
public String getBody() {
return body;
}
public void setBody(String body) {
this.body = body;
}
public TestTable(Integer postIndex, Timestamp ingestionTime, String body) {
this.body = body;
this.ingestionTime = ingestionTime;
this.postIndex = postIndex;
}
public TestTable() {
this.body = "";
this.ingestionTime = Timestamp.from(Instant.now());
this.postIndex = 0;
}
}
public class TestCassandraJobJava {
public static void main(String[] args) {
Pipeline pipeline = Pipeline.create(PipelineOptionsFactory.fromArgs(args).create());
PCollection<String> data = pipeline.apply("ReadStrinsFromPubsub",
PubsubIO.readStrings().fromSubscription("projects/{project_id}/subscriptions/{subscription_name}"))
.apply("window", Window.into(FixedWindows.of(Duration.standardSeconds(5))))
.apply("CreateMutation", ParDo.of(new DoFn<String, TestTable>() {
@ProcessElement
public void processElement(@Element String word, OutputReceiver<TestTable> out) {
TestTable t = new TestTable(new Random().nextInt(), java.sql.Timestamp.from(Instant.now()), word);
out.output(t);
}
})).apply(CassandraIO.<TestTable>write()
.withHosts(Arrays.asList("127.0.0.1"))
.withPort(9042)
.withKeyspace("{keyspace}")
.withLocalDc("Cassandra")
.withEntity(TestTable.class)
);
pipeline.run().waitUntilFinish();
}
}
答案 0 :(得分:0)
要使其正常工作,您需要在Cassandra的timestamp
和java.sql.Timestamp
之间建立一个编解码器。默认情况下,在Java驱动程序3.x中,timestamp
被转换为java.util.Date
(请参阅mapping),尽管您也可以通过{使用Joda Time或Java 8.x time API {3}}。在Java驱动程序4.x中,Instant
用于表示时间戳。
java.sql.Timestamp
没有内置编解码器,但是要实现自己的编解码器并不难-extra codecs详细描述了自定义编解码器的创建和使用过程。