Quarkus WebSocket 入门实践

前期准备&环境说明

  • JDK 21 (大于17就行)
  • Quarkus Cli 3.29.3
  • quarkus maven工程

安装最新的插件

bash 复制代码
quarkus ext add websockets-next

为什么不用 quarkus-websockets? quarkus.net.cn/guides/webs...

开发客户端

目标 : 连接到指定的ws服务器 流程步骤:

  • 定义客户端端点(@WebSocketClient) Quarkus 的 WebSocket Next 客户端接收消息需要一个 @WebSocketClient 注解的类。
java 复制代码
package org.acme;

import io.quarkus.websockets.next.OnTextMessage;
import io.quarkus.websockets.next.WebSocketClient;
import io.quarkus.websockets.next.WebSocketClientConnection;
import jakarta.inject.Inject;

@WebSocketClient(path = "/echo") // 远程 ws 的路径(示例)
public class MyWsClient {

    @Inject
    WebSocketClientConnection connection;

    @OnTextMessage
    void onMessage(String msg) {
        System.out.println(">>> 收到服务器消息: " + msg);
    }
}
markdown 复制代码
只要远程 ws 服务器在 `/echo` 路径上,这个端点就能接收消息。

    
  • 使用 WebSocketConnector 主动连接远程 ws 需要一个业务类主动调用 connector.connect()。
java 复制代码
package org.acme;

import io.quarkus.websockets.next.WebSocketConnector;
import io.quarkus.websockets.next.WebSocketClientConnection;
import jakarta.inject.Inject;
import jakarta.inject.Singleton;

import java.net.URI;

@Singleton
public class WsClientRunner {

    @Inject
    WebSocketConnector<MyWsClient> connector;

    public void connect() {
        URI uri = URI.create("ws://localhost:9000"); // 外部 ws 服务

        WebSocketClientConnection conn = connector
                .baseUri(uri)      // ws://localhost:9000
                .connectAndAwait(); // 阻塞直到连接成功

        System.out.println(">>> 已连接到外部 WebSocket 服务");

        // 主动发送一条消息
        conn.sendTextAndAwait("Hello WS Server!");
    }
}
  • 发送消息 / 接收消息 根据业务逻辑进行主动或自动连接到WS服务器
java 复制代码
import io.quarkus.runtime.StartupEvent;
import jakarta.enterprise.event.Observes;

@Singleton
public class Startup {

    @Inject
    WsClientRunner runner;

    void onStart(@Observes StartupEvent ev) {
        runner.connect();
    }
}

📌 重点说明

需求 对应用法
主动连接外部 ws 服务 WebSocketConnector
接收消息 @WebSocketClient 中写 @OnTextMessage
发送消息 connection.sendText() / sendTextAndAwait()
配路径参数 .pathParam("name", "abc")
连接多个 ws 使用 Instance<WebSocketConnector<T>>

Quarkus WebSockets Next 客户端本质上是全异步、自动管理生命周期的 WebSocket 客户端,比传统 Java WebSocket API 好用太多。

相关推荐
Jackson@ML22 分钟前
2026最新版Sublime Text 4安装使用指南
java·python·编辑器·sublime text
毕设源码-朱学姐22 分钟前
【开题答辩全过程】以 校园闲置物品交易平台的设计与实现为例,包含答辩的问题和答案
java·eclipse
古城小栈24 分钟前
Rust复合类型 四大军阀:数、元、切、串
开发语言·后端·rust
chilavert31827 分钟前
技术演进中的开发沉思-326 JVM:内存区域与溢出异常(上)
java·jvm
纪莫1 小时前
技术面:如何让你的系统抗住高并发的流量?
java·redis·java面试⑧股
spencer_tseng1 小时前
Unlikely argument type for equals(): JSONObject seems to be unrelated to String
java·equals
爱敲代码的小鱼1 小时前
事务核心概念与隔离级别解析
java·开发语言·数据库
小冷coding2 小时前
【Java】遇到微服务接口报错导致系统部分挂掉时,需要快速响应并恢复,应该怎么做呢?如果支付服务出现异常如何快速处理呢?
java·开发语言·微服务
+VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue酒店预订系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
一个处女座的程序猿O(∩_∩)O2 小时前
Nacos 中的 Namespace 深度解析:实现多租户隔离的关键机制
java