springboot监听多个端口

server:
  port: 8088
  additionalPorts: 8089,8087

package com.demo;
 
import org.apache.catalina.connector.Connector;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Value;
 
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
 
import java.util.ArrayList;
import java.util.List;
 
@Configuration
public class TomcatUtil {
    @Value("${server.additionalPorts}")
    private String additionalPorts;
 
    @Bean
    public TomcatServletWebServerFactory servletContainer() {
        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory();
        Connector[] additionalConnectors = this.additionalConnector();
        if (additionalConnectors != null && additionalConnectors.length > 0) {
            tomcat.addAdditionalTomcatConnectors(additionalConnectors);
        }
        return tomcat;
    }
 
    private Connector[] additionalConnector() {
        if (StringUtils.isBlank(this.additionalPorts)) {
            return null;
        }
        String[] ports = this.additionalPorts.split(",");
        List<Connector> result = new ArrayList<>();
        for (String port : ports) {
            Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
            connector.setScheme("http");
            connector.setPort(Integer.valueOf(port));
            result.add(connector);
        }
        return result.toArray(new Connector[] {});
    }
}

要在Spring Boot中使用Netty监听多个UDP端口,可以按照以下步骤: 1. 导入Netty和Spring Boot的依赖 ```xml <dependency> <groupId>io.netty</groupId> <artifactId>netty-all</artifactId> <version>4.1.52.Final</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> ``` 2. 创建UDP服务器的配置类 ```java @Configuration public class UdpServerConfig { @Value("${udp.server.port}") private int port; @Value("${udp.server2.port}") private int port2; @Bean(name = "udpServer") public DatagramChannel udpServer() throws Exception { EventLoopGroup group = new NioEventLoopGroup(); DatagramChannel channel = DatagramChannel.open(); channel.bind(new InetSocketAddress(port)); channel.configureBlocking(false); channel.register(group, SelectionKey.OP_READ); return channel; } @Bean(name = "udpServer2") public DatagramChannel udpServer2() throws Exception { EventLoopGroup group = new NioEventLoopGroup(); DatagramChannel channel = DatagramChannel.open(); channel.bind(new InetSocketAddress(port2)); channel.configureBlocking(false); channel.register(group, SelectionKey.OP_READ); return channel; } @PreDestroy public void destroy() { udpServer().close(); udpServer2().close(); } } ``` 该配置类中创建了两个UDP服务器,分别监听不同的端口。其中,通过`@Value`注解注入了端口号,这里使用了`udp.server.port`和`udp.server2.port`两个属性。 3. 创建UDP服务器的处理类 ```java @Component public class UdpServerHandler implements ChannelInboundHandler { @Autowired @Qualifier("udpServer") private DatagramChannel udpServer; @Autowired @Qualifier("udpServer2") private DatagramChannel udpServer2; @Override public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { DatagramPacket packet = (DatagramPacket) msg; // TODO: 处理UDP消息 } @Override public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception { cause.printStackTrace(); ctx.close(); } } ``` 该类中注入了之前创建的两个UDP服务器,通过`channelRead`方法处理UDP消息。这里使用了`@Component`注解将该类交由Spring管理。 4. 配置Spring Boot应用的属性 在`application.properties`中配置UDP服务器的端口号: ```properties udp.server.port=8888 udp.server2.port=9999 ``` 5. 启动Spring Boot应用 在Spring Boot应用启动时,Netty将会自动创建两个UDP服务器,分别监听`8888`和`9999`端口。可以在`UdpServerHandler`类中编写UDP消息的处理逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值