close方法中,客戶端發出正常的揮手請求,在服務端的AbstractNioByteChannel的內部類NioByteUnsafe的read方法中,close = allocHandle.lastBytesRead() < 0這句為true,就不會進入channelRead而是進入if (close) {closeOnRead(pipeline);}----close(voidPromise())----doClose0 + fireChannelInactiveAndDeregister----執行pipeline里面的inactive和unregister方法。
而客戶端所在Java進程正常/異常關閉,客戶端來不及發出揮手請求,發出的是RST復位請求,服務端在剛才說的unsafe.read方法中doReadBytes(byteBuf)這句直接拋出I/O異常,被捕捉后進入handleReadException方法,在方法中有fireExceptionCaught調用pipeline的exceptionCaught方法,而fireExceptionCaught下面還有之前說的closeOnRead,執行pipeline里面的inactive和unregister方法。