Netty断线重连

Netty断线重连

最近使用Netty开发一个中转服务,需要一直保持与Server端的连接,网络中断后需要可以自动重连,查询官网资料,实现方案很简单,核心思想是在channelUnregistered钩子函数里执行重连。

创建连接#

需要把configureBootstrap重构为一个函数,方便后续复用

  1. EventLoopGroup group = new NioEventLoopGroup(); 
  2. private volatile Bootstrap bootstrap; 
  3.  
  4. public void init(String host, int port) throws RobotException
  5. this.serverIp = host; 
  6. this.serverPort = port; 
  7. try
  8. // 创建并初始化 Netty 客户端 Bootstrap 对象 
  9. bootstrap = configureBootstrap(new Bootstrap(),group); 
  10. bootstrap.option(ChannelOption.TCP_NODELAY, true); 
  11. doConnect(bootstrap); 

  12. catch(Exception ex){ 
  13. ex.printStackTrace(); 
  14. throw new RobotException("connect remote control server error!",ex.getCause()); 


  15.  
  16. Bootstrap configureBootstrap(Bootstrap b, EventLoopGroup g)
  17. b.group(g).channel(NioSocketChannel.class) 
  18. .remoteAddress(serverIp, serverPort) 
  19. .handler(new ChannelInitializer<SocketChannel>() { 
  20. @Override 
  21. public void initChannel(SocketChannel channel) throws Exception
  22. ChannelPipeline pipeline = channel.pipeline(); 
  23. // 编解码器 
  24. pipeline.addLast(protoCodec); 
  25. // 请求处理 
  26. pipeline.addLast(RobotClient.this); 

  27. }); 
  28.  
  29. return b; 

  30.  
  31. void doConnect(Bootstrap b)
  32. try
  33.  
  34. ChannelFuture future = b.connect(); 
  35. future.addListener(new ChannelFutureListener() { 
  36. @Override 
  37. public void operationComplete(ChannelFuture future) throws Exception
  38. if (future.isSuccess()) { 
  39. System.out.println("Started Tcp Client: " + serverIp); 
  40. } else
  41. System.out.println("Started Tcp Client Failed: "); 

  42. if (future.cause() != null) { 
  43. future.cause().printStackTrace(); 

  44.  

  45. }); 
  46. } catch (Exception e) { 
  47. e.printStackTrace(); 


断线重连#

来看断线重连的关键代码:

  1. @ChannelHandler.Sharable 
  2. public class RobotClient extends SimpleChannelInboundHandler<RobotProto>
  3. @Override 
  4. public void channelUnregistered(ChannelHandlerContext ctx) throws Exception
  5. // 状态重置 
  6. isConnected = false
  7. this.serverStatus = -1
  8.  
  9. final EventLoop loop = ctx.channel().eventLoop(); 
  10. loop.schedule(new Runnable() { 
  11. @Override 
  12. public void run()
  13. doConnect(configureBootstrap(new Bootstrap(), loop)); 

  14. }, 1, TimeUnit.SECONDS); 


需要注意,Client类需要添加@ChannelHandler.Sharable注解,否则重连时会报错


作者:Jadepeng
出处:jqpeng的技术记事本--http://www.cnblogs.com/xiaoqi
您的支持是对博主最大的鼓励,感谢您的认真阅读。
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

关注作者

欢迎关注作者微信公众号, 一起交流软件开发:欢迎关注作者微信公众号

posted @   JadePeng  阅读(2201)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示
CONTENTS