当前位置: 首页 > news >正文

SpringBoot集成Netty的方案以及Demo示列

文章目录

  • SpringBoot集成Netty的方案和demo示例
    • 一、集成方案
      • 1. 添加依赖
      • 2. 配置 Netty 服务器
      • 3. 创建 Netty 服务器处理器
      • 4. 创建 Spring Boot 启动类
    • 二、示例说明
      • 1. 服务器端
      • 2. 客户端
    • 三、总结

SpringBoot集成Netty的方案和demo示例

一、集成方案

1. 添加依赖

在项目的 pom.xml 文件中,添加 Spring Boot 和 Netty 的依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
    <groupId>io.netty</groupId>
    <artifactId>netty-all</artifactId>
    <version>4.1.68.Final</version>
</dependency>

2. 配置 Netty 服务器

创建一个配置类 NettyConfig.java,用于配置 Netty 服务器:

import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.*;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioServerSocketChannel;
import io.netty.handler.codec.string.StringDecoder;
import io.netty.handler.codec.string.StringEncoder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class NettyConfig {

    @Bean
    public NioEventLoopGroup bossGroup() {
        return new NioEventLoopGroup(1);
    }

    @Bean
    public NioEventLoopGroup workerGroup() {
        return new NioEventLoopGroup();
    }

    @Bean
    public ServerBootstrap serverBootstrap(NioEventLoopGroup bossGroup, NioEventLoopGroup workerGroup) {
        ServerBootstrap bootstrap = new ServerBootstrap();
        bootstrap.group(bossGroup, workerGroup)
                .channel(NioServerSocketChannel.class)
                .childHandler(new ChannelInitializer<SocketChannel>() {
                    @Override
                    protected void initChannel(SocketChannel ch) throws Exception {
                        ch.pipeline().addLast(new StringDecoder());
                        ch.pipeline().addLast(new StringEncoder());
                        ch.pipeline().addLast(new NettyServerHandler());
                    }
                })
                .option(ChannelOption.SO_BACKLOG, 128)
                .childOption(ChannelOption.SO_KEEPALIVE, true);
        return bootstrap;
    }

    @Bean
    public ChannelFuture bind(ServerBootstrap serverBootstrap) throws InterruptedException {
        int port = 8081; // 设置 Netty 服务器监听的端口
        ChannelFuture future = serverBootstrap.bind(port).sync();
        future.channel().closeFuture().sync();
        return future;
    }
}

3. 创建 Netty 服务器处理器

创建一个处理器类 NettyServerHandler.java,用于处理客户端请求:

import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.SimpleChannelInboundHandler;

public class NettyServerHandler extends SimpleChannelInboundHandler<String> {

    @Override
    protected void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception {
        System.out.println("Received message: " + msg);
        ctx.writeAndFlush("Message received: " + msg);
    }

    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
        cause.printStackTrace();
        ctx.close();
    }
}

4. 创建 Spring Boot 启动类

创建一个启动类 Application.java,用于启动 Spring Boot 应用:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

二、示例说明

1. 服务器端

上述配置创建了一个 Netty 服务器,监听端口 8081。当客户端发送消息时,服务器会接收消息并返回响应。

2. 客户端

可以使用以下代码创建一个简单的 Netty 客户端,向服务器发送消息:

import io.netty.bootstrap.Bootstrap;
import io.netty.channel.*;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioSocketChannel;
import io.netty.handler.codec.string.StringDecoder;
import io.netty.handler.codec.string.StringEncoder;

public class NettyClient {
    public static void main(String[] args) throws InterruptedException {
        String host = "localhost";
        int port = 8081;

        EventLoopGroup workerGroup = new NioEventLoopGroup();

        try {
            Bootstrap bootstrap = new Bootstrap();
            bootstrap.group(workerGroup);
            bootstrap.channel(NioSocketChannel.class);
            bootstrap.option(ChannelOption.SO_KEEPALIVE, true);
            bootstrap.handler(new ChannelInitializer<SocketChannel>() {
                @Override
                protected void initChannel(SocketChannel ch) throws Exception {
                    ch.pipeline().addLast(new StringEncoder());
                    ch.pipeline().addLast(new StringDecoder());
                    ch.pipeline().addLast(new NettyClientHandler());
                }
            });

            ChannelFuture future = bootstrap.connect(host, port).sync();
            future.channel().closeFuture().sync();
        } finally {
            workerGroup.shutdownGracefully();
        }
    }
}

class NettyClientHandler extends SimpleChannelInboundHandler<String> {

    @Override
    protected void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception {
        System.out.println("Server response: " + msg);
    }

    @Override
    public void channelActive(ChannelHandlerContext ctx) throws Exception {
        ctx.writeAndFlush("Hello, Netty Server!");
    }

    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
        cause.printStackTrace();
        ctx.close();
    }
}

三、总结

通过上述步骤,我们成功地在 Spring Boot 中集成了 Netty,实现了一个简单的服务器和客户端通信示例。Netty 提供了高性能的网络通信能力,适用于需要处理大量并发连接和实时通信的场景。在实际应用中,可以根据业务需求进一步扩展和优化 Netty 的配置和处理器逻辑。

相关文章:

  • SAP HANA on AWS Amazon Web Services
  • Git 面试问题,解决冲突
  • k8s常用操作 (一) ---根据上一篇文章用到写的 不全
  • __call__
  • fastpdf应用程序错误0xc0000142
  • 反汇编学习
  • 基于YOLOv8与SKU110K数据集实现超市货架物品目标检测与计算
  • Matlab 单球机器人动力学与LQR控制研究
  • P11229 [CSP-J 2024] 小木棍
  • 跳转到视图文件夹
  • 如何展示一个类的所有方法
  • ArcGIS Pro中加载在线地图的详细指南
  • 利用AI让数据可视化
  • Python中的“泛型”和“多重继承”
  • uniapp报错 Right-hand side of ‘instanceof‘ is not an object
  • rust笔记14:mod和use的使用区别
  • 学习笔记 ASP.NET Core Web API 8.0部署到iis
  • PAT甲级(Advanced Level) Practice 1022 Digital Library
  • browser_use 自动化浏览器agent使用案例
  • 使用BLSTM自动评估句子级构音障碍的可理解性
  • 因港而兴,“长江黄金水道”上的宜宾故事
  • 今年前4个月上海对拉美国家进出口总值增长2%
  • 日本航空自卫队一架练习机在爱知县坠毁
  • 外交部:中方对美芬太尼反制仍然有效
  • 专访|导演刘江:给谍战题材注入现实主义的魂
  • 图讯丨习近平出席中国-拉美和加勒比国家共同体论坛第四届部长级会议开幕式