NATS
NATS的作用不多讲,直接实例。
新建项目
新建项目时选择Maven,可以选择右侧的quickstart,快速新建一个maven项目。
项目一
在test项目中,首先加入nats的依赖。
然后根据nats文档,写publish功能。
// maven pom.xml中
<dependency>
<groupId>io.nats</groupId>
<artifactId>jnats</artifactId>
<version>2.2.0</version>
</dependency>
// main函数中
public class App {
public static void main(String[] args) throws IOException, InterruptedException {
Connection nc = Nats.connect("nats://127.0.0.1:4222");
for(int i=0; i<=30; i++){
nc.publish("subject", ("hello world" + i).getBytes(StandardCharsets.UTF_8));
}
System.out.println("Hello World!");
}
}
项目二
在test2项目中,首先加入nats的依赖。
然后根据nats文档,写listen功能。
// maven pom.xml中
<dependency>
<groupId>io.nats</groupId>
<artifactId>jnats</artifactId>
<version>2.2.0</version>
</dependency>
// main函数中 收到消息即退出
public class App {
public static void main(String[] args) throws IOException, InterruptedException {
Connection nc = Nats.connect("nats://127.0.0.1:4222");
Subscription sub = nc.subscribe("subject");
Message msg = sub.nextMessage(Duration.ofMinutes(20));
String response = new String(msg.getData(), StandardCharsets.UTF_8);
System.out.println(response);
}
}
// main函数中 持续监听
public class App {
public static void main(String[] args) throws IOException, InterruptedException {
Connection nc = Nats.connect("nats://127.0.0.1:4222");
Dispatcher d = nc.createDispatcher((msg) -> {
String response = new String(msg.getData(), StandardCharsets.UTF_8);
System.out.println(response);
});
d.subscribe("subject");
}
}
参考网址
java-nats: https://github.com/nats-io/java-nats