BigFileTransfer
利用Netty进行大文件传输(zero-copy)
Install / Use
/learn @zhangjihhu/BigFileTransferREADME
BigFileTransfer
利用Netty进行大文件传输(zero-copy)
使用Netty自带的ChunkedWriteHandler在客户端和服务器之间传输超大文件
write()方法,将数据包装成PendingWrite塞入发送队列
flush()方法,从发送队列取出数据(如果是ChunkedInput类型的数据,同时根据isEndOfInput()方法,判断stream中是否还有数据), 将其发送到对应的channel中,该过程如果发生阻塞,通过注册监听以及channelWritabilityChanged()方法在通道可写的情况下继续发送。
|>|ByteBuf|>|inbound|>|FileReceiveHandler|>|FileSendHandler|>|FilePacketHandler| |----|----|----|----|----|----|----|----|----|----| | | | | | |如果是文件内容直接读取| |使用FileRegion直接发送文件内容| |获取接收文件的属性|
该项目操作流程:
- 开启服务端(Server)
- 开启客户端(Client),完成与服务端连接
- 输入文件路径,完成从client->server/server->client的文件发送
有问题可以联系zhangjimic@outlook.com交流学习
