undertow服务配置多端口监听

项目中,需要配置服务对外提供多个不同的端口,以保证访问不同的服务,进行不同业务的处理。使用的是Springboot+Undertow服务容器的方式。

1. undertow依赖的pom文件

 <dependency>
   <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
        </exclusion>
    </exclusions>
</dependency>

 <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-undertow</artifactId>
</dependency>

2. 多端口配置

首先需要在配置文件中,增加一个多端口配置的字段,用于配置除过原有server.port之外的端口。我这里配的是additional-ports字段:

server:
  port: 8010
  ## 支持的多端口监听,中间用,隔开,连续端口使用-进行链接
  additional-ports: 8888,8889-8892

其次需要新增config类, 将配置的端口加入启动时的端口监听中。我这里创建的类名为MultiplePortListerConfig,代码如下:

import cn.hutool.core.util.StrUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.undertow.UndertowServletWebServerFactory;
import org.springframework.boot.web.servlet.server.ServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author: 
 * @date: 2022-12-16 18:14
 * @description: 配置undertow监听多端口
 */
@Configuration
public class MultiplePortListerConfig {
    /**
     * 额外端口监听
     */
    @Value("${server.additional-ports}")
    private String additionalPorts;

    @Bean
    public ServletWebServerFactory undertowFactory() {
        UndertowServletWebServerFactory undertowFactory = new UndertowServletWebServerFactory();
        undertowFactory.addBuilderCustomizers(builder -> {
            if (StrUtil.isBlank(additionalPorts)) {
                return;
            }
            String[] ports = additionalPorts.split(",");
           for (String port : ports) {
                if (port.contains("-")){
                    String[] portArr = port.split("-");
                    int start = Integer.parseInt(StrUtil.trim(portArr[0]));
                    int end = Integer.parseInt(StrUtil.trim(portArr[1]));
                    for (int i = start; i<=end; i++){
                        builder.addHttpListener(i, "0.0.0.0");
                    }
                }else {
                    builder.addHttpListener(Integer.parseInt(StrUtil.trim(port)), "0.0.0.0");
                }
            }
        });
        return undertowFactory;
    }
}

启动后,可以看见控制台出现同时监听8010,8888,8889,8890,8891,8892的信息:
在这里插入图片描述

调用不同端口访问服务均可访问成功,证明配置成功。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是使用Undertow创建WebSocket服务的简要步骤: 1. 添加Undertow依赖项:在您的Maven或Gradle项目中,添加Undertow服务器和WebSocket依赖项。 2. 创建WebSocket端点:定义一个类来实现WebSocket协议和事件处理程序,例如: ``` @ServerEndpoint("/example") public class ExampleWebSocketEndpoint { @OnOpen public void onOpen(Session session) { System.out.println("WebSocket opened: " + session.getId()); } @OnMessage public void onMessage(Session session, String message) { System.out.println("WebSocket message received: " + message); } @OnClose public void onClose(Session session) { System.out.println("WebSocket closed: " + session.getId()); } @OnError public void onError(Session session, Throwable throwable) { System.out.println("WebSocket error: " + throwable.getMessage()); } } ``` 在这个示例中,`@ServerEndpoint`注释指定了WebSocket端点的URL,即`/example`。`@OnOpen`、`@OnMessage`、`@OnClose`和`@OnError`注释分别指定了WebSocket事件的处理方法。 3. 配置Undertow服务器:创建一个Undertow服务器实例,并将WebSocket端点添加到部署描述符中,例如: ``` Undertow server = Undertow.builder() .addHttpListener(8080, "localhost") .setHandler(path() .addPrefixPath("/websocket", websocket(new WebSocketDeploymentInfo() .addEndpoint(ExampleWebSocketEndpoint.class)))) .build(); server.start(); ``` 在这个示例中,使用`Undertow.builder()`创建了一个Undertow服务器实例,并使用`addHttpListener()`方法指定了服务监听端口和主机名。`setHandler()`方法定义了一个处理程序,它使用`path()`方法创建了一个路径处理程序,并使用`addPrefixPath()`方法将WebSocket端点的URL路径`/websocket`与WebSocket处理程序关联。然后,使用`websocket()`方法将WebSocketDeploymentInfo对象添加到处理程序中,该对象包含了WebSocket端点的配置信息,例如端点的类和URL路径。 4. 测试WebSocket服务:使用任何WebSocket客户端(例如JavaScript、Python或Java)连接到WebSocket服务并发送消息,例如: ``` const websocket = new WebSocket("ws://localhost:8080/websocket/example"); websocket.onopen = () => { console.log("WebSocket opened"); websocket.send("Hello, WebSocket!"); }; websocket.onmessage = (event) => { console.log("WebSocket message received: " + event.data); }; websocket.onclose = () => { console.log("WebSocket closed"); }; websocket.onerror = (event) => { console.log("WebSocket error: " + event.message); }; ``` 在这个示例中,使用JavaScript创建了一个WebSocket实例,并在连接到WebSocket服务后发送了一条消息。在收到消息后,WebSocket实例将其打印到控制台。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值