-
Notifications
You must be signed in to change notification settings - Fork 154
/
ContextExample.java
76 lines (62 loc) · 3.54 KB
/
ContextExample.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// Copyright 2023 The NATS Authors
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at:
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package io.nats.examples.jetstream.simple;
import io.nats.client.*;
import io.nats.client.api.ConsumerConfiguration;
import java.io.IOException;
import static io.nats.examples.jetstream.NatsJsUtils.createOrReplaceStream;
/**
* This example will demonstrate simplified contexts
*/
public class ContextExample {
private static final String STREAM = "context-stream";
private static final String SUBJECT = "context-subject";
private static final String CONSUMER_NAME = "context-consumer";
public static String SERVER = "nats://localhost:4222";
public static void main(String[] args) {
Options options = Options.builder().server(SERVER).build();
try (Connection nc = Nats.connect(options)) {
JetStream js = nc.jetStream();
createOrReplaceStream(nc.jetStreamManagement(), STREAM, SUBJECT);
// get a stream context from the connection
StreamContext streamContext = nc.getStreamContext(STREAM);
System.out.println("S1. " + streamContext.getStreamInfo());
// get a stream context from the connection, supplying custom JetStreamOptions
streamContext = nc.getStreamContext(STREAM, JetStreamOptions.builder().build());
System.out.println("S2. " + streamContext.getStreamInfo());
// get a stream context from the JetStream context
streamContext = js.getStreamContext(STREAM);
System.out.println("S3. " + streamContext.getStreamInfo());
// when you create a consumer from the stream context you get a ConsumerContext in return
ConsumerContext consumerContext = streamContext.createOrUpdateConsumer(ConsumerConfiguration.builder().durable(CONSUMER_NAME).build());
System.out.println("C1. " + consumerContext.getCachedConsumerInfo());
// get a ConsumerContext from the connection for a pre-existing consumer
consumerContext = nc.getConsumerContext(STREAM, CONSUMER_NAME);
System.out.println("C2. " + consumerContext.getCachedConsumerInfo());
// get a ConsumerContext from the connection for a pre-existing consumer, supplying custom JetStreamOptions
consumerContext = nc.getConsumerContext(STREAM, CONSUMER_NAME, JetStreamOptions.builder().build());
System.out.println("C3. " + consumerContext.getCachedConsumerInfo());
// get a ConsumerContext from the stream context for a pre-existing consumer
consumerContext = streamContext.getConsumerContext(CONSUMER_NAME);
System.out.println("C4. " + consumerContext.getCachedConsumerInfo());
}
catch (JetStreamApiException | IOException | InterruptedException ioe) {
// JetStreamApiException:
// the stream or consumer did not exist
// IOException:
// problem making the connection
// InterruptedException:
// thread interruption in the body of the example
}
}
}