无法同时开启springboot和netty服务器端口的监听,和netty整合使用mybatis的问题 (后附完整的springboot整合netty代码)


目的

 解决springboot程序监听的端口和netty服务监听的端口无法同时开启的问题,以及netty无法较为便利地使用mybatis操作数据库的问题。


背景描述

 正在做的一个IM即时通讯项目,springboot服务器负责监听http的CRUD等请求,netty的websocket服务器负责即时聊天消息的签收和推送功能。常见的两种springboot整合netty的方法如下:

 1、单独写一个main方法,运行netty server,这样的话需要启动两次,分别启动springboot和netty server启动类,而且此时netty server没办法使用spring容器中的bean用mybatis进行CRUD,只能使用JDBC来操作数据库。

 2、在netty server的启动方法上面使用 @PostConstruct 的注解,在bean的依赖注入完成后会自动执行该注解标注的方法,同时netty server类和相关handler类上也需要标注 @component 和 handler类上的 @Sharable注解。


 但此时启动springboot,netty服务能正常启动并监听websocket端口,netty server也能正常注入spring容器中的bean,可是springboot监听的端口会被覆盖,无法访问。

@Component
public class WebSockerServer {
   
    
    @PostConstruct
    public void runNettyServer() {
   
        EventLoopGroup bossGroup = new NioEventLoopGroup();
        EventLoopGroup workerGroup = new NioEventLoopGroup();
        
        //......
        
    }
}

@Component
@Sharable
public class NettyChannelInitializer extends ChannelInitializer<SocketChannel> {
   

    @Autowired
    private ChatChannelHandler chatChannelHandler;

}


解决方法

 1、netty server类实现Runnable接口,重写run( ) 方法,在run( ) 方法内部启动netty server。

@Component("WebSocketServer")
public class WebSockerServer implements Runnable {
   

    @Autowired
    private NettyChannelInitializer nettyChannelInitializer;

    @Override
    public void run() {
   
        EventLoopGroup bossGroup = new NioEventLoopGroup();
    
    	......
                
    }
}

  2、在springboot启动类中从spring容器中获取netty server的bean,创建线程池然后执行execute( )方法开启netty server线程。

@EnableOpenApi
@SpringBootApplication
@MapperScan("com.duke.chatapp.dao")
public 
  • 13
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Net 是一款高性能的网络通信框架,MyBatis-Plus 是 MyBatis 的增强工具,在实现数据访问时提供了更加便捷的 API。将它们整合起来可以实现一个高性能的网络通信应用。 下面是整合步骤: 1. 引入 NettyMyBatis-Plus 的依赖: ```xml <!-- Netty --> <dependency> <groupId>io.netty</groupId> <artifactId>netty-all</artifactId> <version>${netty.version}</version> </dependency> <!-- MyBatis-Plus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>${mybatis-plus.version}</version> </dependency> ``` 2. 编写 Netty 的服务端代码,实现业务逻辑处理: ```java public class MyNettyServer { private static final int PORT = 8888; public void start() { EventLoopGroup bossGroup = new NioEventLoopGroup(); EventLoopGroup workerGroup = new NioEventLoopGroup(); try { 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 MyNettyServerHandler()); } }); ChannelFuture future = bootstrap.bind(PORT).sync(); future.channel().closeFuture().sync(); } catch (InterruptedException e) { e.printStackTrace(); } finally { bossGroup.shutdownGracefully(); workerGroup.shutdownGracefully(); } } } ``` 3. 编写 Netty 的处理器 MyNettyServerHandler,实现业务逻辑: ```java public class MyNettyServerHandler extends ChannelInboundHandlerAdapter { @Autowired private UserService userService; @Override public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { ByteBuf byteBuf = (ByteBuf) msg; String request = byteBuf.toString(CharsetUtil.UTF_8); String response = userService.getUser(request); ByteBuf responseBuf = Unpooled.copiedBuffer(response, CharsetUtil.UTF_8); ctx.writeAndFlush(responseBuf); } } ``` 4. 编写 MyBatis-Plus 的服务: ```java @Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public String getUser(String name) { User user = getOne(new LambdaQueryWrapper<User>().eq(User::getName, name)); return user == null ? "User not found" : user.toString(); } } ``` 5. 在 Spring Boot整合 NettyMyBatis-Plus: ```java @SpringBootApplication public class MyApplication implements CommandLineRunner { @Autowired private MyNettyServer myNettyServer; public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } @Override public void run(String... args) throws Exception { myNettyServer.start(); } } ``` 至此,NettyMyBatis-Plus 的整合就完成了,可以在 Netty 的处理器中调用 MyBatis-Plus 的服务实现业务逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值