Netty parsing is stuck, how to deal with it?

is a game server written in java,netty, which is often requested by crawlers.

at present, after one night, the netty is stuck and the new request will remain stuck, that is, it will not be printed on the console or respond to the client request.

sometimes I press enter on the cmd of the server and respond to the client request. But this method obviously doesn"t work.

do I turn off ChannelHandlerContext chc.close (); so that the connection cannot be disconnected, causing the thread to be full?

 //  

  protected static final int BisGroupSize = 6;

  //  

  protected static final int worGroupSize = 10;

,.

the red box is output after I press enter, not according to the request of the client before enter.

    //SocketControl
    public static void  run(int port) throws Exception {  
        ServerBootstrap bootstrap = new ServerBootstrap();  
        bootstrap.group(bossGroup, workerGroup);
        bootstrap.channel(NioServerSocketChannel.class);  
        bootstrap.childHandler(new ChannelInitializer<SocketChannel>() {
            @Override  
            protected void initChannel(SocketChannel ch) throws Exception {
                ChannelPipeline pipeline = ch.pipeline();  
                
                // ("\n")   
                pipeline.addLast("framer", new DelimiterBasedFrameDecoder(10240, Delimiters.lineDelimiter()));  
                pipeline.addLast("decoder", new MyStringDecoder(Charset.forName("UTF-8")));  
                pipeline.addLast("encoder", new StringEncoder(Charset.forName("UTF-8")));  
                pipeline.addLast(new SocketServerHandler());  
            }  
        });  
        bootstrap.bind(IP,port).sync();  
        log.info("Socket, "+port+" ");  
    }  
public class MyStringDecoder extends MessageToMessageDecoder<ByteBuf> {
 
    private final Charset charset;
    
    /**
     * Creates a new instance with the current system character set.
     */
    public MyStringDecoder() {
        this(Charset.defaultCharset());
    }

    /**
     * Creates a new instance with the specified character set.
     */
    public MyStringDecoder(Charset charset) {
        if (charset == null) {
            throw new NullPointerException("charset");
        }
        this.charset = charset;
    }

    @Override
    protected void decode(ChannelHandlerContext ctx, ByteBuf msg, List<Object> out) throws Exception {
        if(msg.getByte(0)!="{" || msg.getByte(msg.capacity()-1)!="}"){
            
        }else{
            out.add(msg.toString(charset));
        }
    }
}
public class SocketServerHandler extends SimpleChannelInboundHandler<String> {  
    private static final Logger log = Logger.getLogger("ruanxin");  
  
    @Override  
    public void exceptionCaught(ChannelHandlerContext chc, Throwable cause) throws Exception {  
        log.info(cause.getMessage());
        chc.close();
    }  
  
    @SuppressWarnings("unchecked")
    @Override  
    public void channelRead(ChannelHandlerContext chc, Object data) throws Exception {    
        if(data==null || !(data instanceof String)){
            log.info("");
            chc.close();
            return;
        }
        String dataStr=(String) data;
        log.info("|||" + dataStr+"|||");
        if(!dataStr.startsWith("{") || !dataStr.endsWith("}")){
            log.info(":data=" + dataStr);
            chc.close();
            return;
        }
        log.info("Read:data=" + data);
        //...
    }
}
Mar.07,2021

I don't see any problem. Add some logs to see if you haven't finished running.
in the past, when dealing with map updates through redis, there was a locking situation with high concurrency. Later, take out the frequently updated values in map and put them directly into redis.

it doesn't have to be netty to take the blame


this problem is solved.

win10 sometimes gets stuck because cmd opens quick editing, causing the java project to get stuck together. Press enter to continue to run the project, and things will be output.

cmd easily gets stuck when executing programs

@ ccfish you are moving in the right direction, but you are not solving the problem.

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1ea7dbb-1e8d.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1ea7dbb-1e8d.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?