NettyServerThread.java 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. package com.zksy.water.config;
  2. import com.zksy.water.utils.MessageHandler;
  3. import io.netty.bootstrap.ServerBootstrap;
  4. import io.netty.channel.ChannelFuture;
  5. import io.netty.channel.ChannelInitializer;
  6. import io.netty.channel.ChannelOption;
  7. import io.netty.channel.EventLoopGroup;
  8. import io.netty.channel.nio.NioEventLoopGroup;
  9. import io.netty.channel.socket.SocketChannel;
  10. import io.netty.channel.socket.nio.NioServerSocketChannel;
  11. import io.netty.handler.timeout.ReadTimeoutHandler;
  12. import lombok.extern.slf4j.Slf4j;
  13. import org.slf4j.Logger;
  14. import org.slf4j.LoggerFactory;
  15. import org.springframework.beans.factory.annotation.Autowired;
  16. import org.springframework.beans.factory.annotation.Value;
  17. import org.springframework.stereotype.Component;
  18. @Slf4j
  19. @Component
  20. public class NettyServerThread {
  21. @Value("${netty.port:8313}")
  22. private int port;
  23. private static Logger logger = LoggerFactory.getLogger(NettyServerThread.class);
  24. private final MessageHandler messageHandler;
  25. @Autowired
  26. public NettyServerThread(MessageHandler messageHandler) {
  27. this.messageHandler = messageHandler;
  28. }
  29. public void startServer() {
  30. System.out.println("Netty服务启动端口号" + port);
  31. EventLoopGroup acceptor = new NioEventLoopGroup();
  32. EventLoopGroup worker = new NioEventLoopGroup();
  33. NettyServer.acceptor = acceptor;
  34. NettyServer.worker = worker;
  35. ServerBootstrap bootstrap = new ServerBootstrap();
  36. // 添加boss和worker组
  37. bootstrap.group(acceptor, worker);
  38. //这句是指定允许等待accept的最大连接数量,我只需要连一个客户端,这里就关掉了,java默认是50个
  39. // bootstrap.option(ChannelOption.SO_BACKLOG, 1024);
  40. bootstrap.option(ChannelOption.TCP_NODELAY, true);
  41. // 用于构造socketchannel工厂
  42. bootstrap.channel(NioServerSocketChannel.class);
  43. /**
  44. * 传入自定义客户端Handle(处理消息)
  45. */
  46. bootstrap.childHandler(new ChannelInitializer<SocketChannel>() {
  47. @Override
  48. public void initChannel(SocketChannel ch) throws Exception {
  49. logger.info("来自" + ch.remoteAddress() + "的新连接接入");
  50. // 注册handler
  51. ch.pipeline().addLast(new ReadTimeoutHandler(3600));// 超时时间,1小时内没有从通道(Channel)读取到任何数据
  52. ch.pipeline().addLast(messageHandler);
  53. }
  54. });
  55. // 绑定端口,开始接收进来的连接
  56. ChannelFuture f;
  57. try {
  58. f = bootstrap.bind(port).sync();
  59. // 等待服务器 socket 关闭 。
  60. f.channel().closeFuture().sync();
  61. } catch (InterruptedException e) {
  62. e.printStackTrace();
  63. } finally {
  64. if (acceptor != null) {
  65. acceptor.shutdownGracefully();
  66. }
  67. if (worker != null) {
  68. worker.shutdownGracefully();
  69. }
  70. }
  71. }
  72. }