Go复制大文件应优先使用io.Copy实现流式处理,其内置32KB缓冲可避免内存溢出;需手动关闭文件句柄,必要时用io.CopyBuffer自定义缓冲大小(512KB–2MB较优);内容复制后需额外处理权限、时间戳等元数据,特殊文件类型需用os.Lstat等函数保留属性。

用 Go 复制大文件,核心是避免内存爆满,关键在于用 io.Copy 配合缓冲流,而不是一次性读进内存。
用 io.Copy 直接复制,最简单也最稳妥
io.Copy 内部已实现智能缓冲(默认 32KB),自动分块读写,不占大量内存,适合任意大小文件。
- 打开源文件和目标文件(
os.Open和os.Create或os.OpenFile) - 调用
io.Copy(dst, src),它会持续从 src 读、往 dst 写,直到 EOF 或出错 - 别忘了关闭文件句柄,建议用
defer f.Close()
手动控制缓冲区大小,按需优化吞吐
如果默认缓冲不够理想(比如千兆网+SSD 环境想压满带宽),可改用 io.CopyBuffer 指定缓冲区。
- 创建一个字节切片作为缓冲,例如
buf := make([]byte, 1024*1024)(1MB) - 调用
io.CopyBuffer(dst, src, buf) - 缓冲太大未必更快(受磁盘/IO调度影响),通常 512KB–2MB 是较优区间
复制时校验或进度提示,不破坏流式处理
需要 MD5 或实时进度?不能直接读全文件,而是用 io.TeeReader 或包装 io.Reader。
立即学习“go语言免费学习笔记(深入)”;
- 进度提示:用自定义
reader包装源文件,在每次Read后累加并回调通知 - 校验和:用
io.TeeReader(src, hash.Hash),让数据流过哈希器再进Copy - 避免在复制中途多次
Seek或重读——大文件下代价极高
注意文件权限和元数据,复制后可能需补全
io.Copy 只管内容,不复制权限、ModTime、Owner 等。如需“真正复制”,得额外处理:
- 复制完后,用
dst.Chmod(info.Mode())和dst.Chtimes(info.ModTime(), info.ModTime()) - 注意:Windows 不支持 Owner/Group,Linux/macOS 上若需保留属主,需以 root 运行并调用
syscall.Chown - 符号链接、设备文件等特殊类型,
os.Open默认跟随,如需保留链接本身,要用os.Lstat+os.Readlink
基本上就这些。不复杂但容易忽略细节——尤其权限和缓冲选择。实际项目中,优先用 io.Copy,有特殊需求再叠加包装逻辑。










