hstreamdb-java
This is the official Java client library for HStreamDB.
Please use the latest released version.
The latest release is v0.7.1, which requires hstream server v0.7.0 .
Content
Installation
The library artifact is published in Maven central, available at hstreamdb-java.
Maven
For Maven Users, the library can be included easily like this:
<dependencies>
<dependency>
<groupId>io.hstream</groupId>
<artifactId>hstreamdb-java</artifactId>
<version>0.7.1</version>
</dependency>
</dependencies>
Gradle
For Gradle Users, the library can be included easily like this:
implementation 'io.hstream:hstreamdb-java:0.7.1'
Example Usage
Connect to HStreamDB
import io.hstream.*;
public class ConnectExample {
public static void main(String[] args) throws Exception {
final String serviceUrl = "localhost:6570";
HStreamClient client = HStreamClient.builder().serviceUrl(serviceUrl).build();
System.out.println("Connected");
client.close();
}
}
Work with Streams
// get a list of streams
for(Stream stream: client.listStreams()) {
System.out.println(stream.getStreamName());
}
// create a new stream
client.createStream("test_stream");
// create a new stream with 5 replicas
client.createStream("test_stream", 5);
// delete a stream
client.deleteStream("test_stream");
Write Data to a Stream
Producer producer = client.newProducer().stream("test_stream").build();
// write raw records
Random random = new Random();
byte[] rawRecord = new byte[100];
random.nextBytes(rawRecord);
Record recordR = Record.newBuilder().rawRecord(rawRecord).build();
CompletableFuture<RecordId> future = producer.write(recordR);
// write hRecords
HRecord hRecord = HRecord.newBuilder()
.put("key1", 10)
.put("key2", "hello")
.put("key3", true)
.build();
Record recordH = Record.newBuilder().hRecord(hRecord).build();
CompletableFuture<RecordId> future = producer.write(recordH);
// buffered writes
BufferedProducer batchedProducer = client.newBufferedProducer()
.stream("test_stream")
// optional, default: 100, the value must be greater than 0
.recordCountLimit(100)
// optional, default: 100(ms), disabled if the value <= 0
.flushIntervalMs(100)
// optional, default: 4096(Bytes), disabled if the value <= 0
.maxBytesSize(4096)
.build();
for(int i = 0; i < 1000; ++i) {
random.nextBytes(rawRecord);
Record recordB = Record.newBuilder().rawRecord(rawRecord).build();
batchedProducer.write(recordB);
}
batchedProducer.close();
Please do not write both binary data and hrecord in one stream.
Consume Data from a Stream
// first, create a subscription for the stream
Subscription subscription =
Subscription
.newBuilder()
.subscription("my_subscription")
.stream("my_stream")
.ackTimeoutSeconds(600)
.build();
client.createSubscription(subscription);
// second, create a consumer attach to the subscription
Consumer consumer =
client
.newConsumer()
.subscription("my_subscription")
.rawRecordReceiver(
((receivedRawRecord, responder) -> {
System.out.println(receivedRawRecord.getRecordId());
responder.ack();
}))
.build();
// third, start the consumer
consumer.startAsync().awaitRunning();
Process Data in Stream with SQL
// first, create an observer for sql results
Observer<HRecord> observer =
new Observer<HRecord>() {
@Override
public void onNext(HRecord value) {
System.out.println(value);
}
@Override
public void onError(Throwable t) {
System.out.println("error happend!");
}
@Override
public void onCompleted() {}
};
// second, create a queryer to execute a sql
Queryer queryer =
client
.newQueryer()
.sql("select * from test_stream emit changes;")
.resultObserver(observer)
.build();
// third, start the queryer
queryer.startAsync().awaitRunning();