SkillAgentSearch skills...

BigFileTransfer

利用Netty进行大文件传输(zero-copy)

Install / Use

/learn @zhangjihhu/BigFileTransfer
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

BigFileTransfer

利用Netty进行大文件传输(zero-copy)

使用Netty自带的ChunkedWriteHandler在客户端和服务器之间传输超大文件

write()方法,将数据包装成PendingWrite塞入发送队列

flush()方法,从发送队列取出数据(如果是ChunkedInput类型的数据,同时根据isEndOfInput()方法,判断stream中是否还有数据), 将其发送到对应的channel中,该过程如果发生阻塞,通过注册监听以及channelWritabilityChanged()方法在通道可写的情况下继续发送。

|>|ByteBuf|>|inbound|>|FileReceiveHandler|>|FileSendHandler|>|FilePacketHandler| |----|----|----|----|----|----|----|----|----|----| | | | | | |如果是文件内容直接读取| |使用FileRegion直接发送文件内容| |获取接收文件的属性|

该项目操作流程:

  1. 开启服务端(Server)
  2. 开启客户端(Client),完成与服务端连接
  3. 输入文件路径,完成从client->server/server->client的文件发送

有问题可以联系zhangjimic@outlook.com交流学习

View on GitHub
GitHub Stars62
CategoryDevelopment
Updated5mo ago
Forks22

Languages

Java

Security Score

77/100

Audited on Oct 30, 2025

No findings