NATS发布与监听

NATS发布与监听

  • NATS
    • 新建项目
    • 项目一
    • 项目二
    • 参考网址

NATS

NATS的作用不多讲,直接实例。

新建项目

新建项目时选择Maven,可以选择右侧的quickstart,快速新建一个maven项目。
NATS发布与监听_第1张图片

项目一

在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

nats官网: https://nats.io/download/nats-io/jnats/

你可能感兴趣的:(NATS发布与监听)