SFTP传输速度慢,归根结底就两个方向:要么是网络路径上堵车了,要么是服务器或客户端本身处理能力跟不上。别急着怪带宽,先理清问题出在哪一环。下面从六个维度入手,把提速方案拆开讲清楚。

1. 网络环境:先把“高速公路”修好
传输速度再快,遇上丢包或高延迟也白搭。优先用有线连接,以太网或光纤比WiFi稳定太多——无线干扰有时能砍掉一半速度。带宽方面,如果经常传大文件,100M升级到1000M甚至更高,效果立竿见影。另外,物理距离带来的延迟可以通过CDN加速缓解。别忘了检查防火墙和路由器:SFTP默认走22端口,如果被安全策略拦截或限速,速度自然上不去。
2. 服务器配置:把“引擎”调校到最佳状态
硬件是基础。CPU别太老,新一代英特尔至强铂金系列这种级别最好;内存至少8GB以上;硬盘坚决上SSD,机械硬盘的读写瓶颈在SFTP场景下尤其明显。软件层面,内核参数要调:编辑/etc/sysctl.conf,把net.core.rmem_max和wmem_max都设到16777216,打开net.ipv4.tcp_window_scaling,这些参数直接影响TCP窗口大小和吞吐量。SSH服务配置里,MaxSessions可以从默认10调到1024,MaxStartups建议改成20:30:60,同时开启Compression yes来压缩传输数据。改完记得重启SSH服务(sudo systemctl restart sshd)。
3. 客户端设置:别让工具拖后腿
选对客户端能省不少事。FileZilla、WinSCP这些成熟工具都支持多线程和压缩。客户端也可以开启压缩:FileZilla里走“偏好设置→传输→文件类型”,勾选“压缩传输”。连接稳定性方面,在~/.ssh/config里加上TCPKeepAlive yes和ServerAliveInterval 60,防止闲置断连。如果需要传大量小文件,多线程传输是神器——lftp的mirror --parallel=N命令,N设成4或8,速度能翻几倍。
4. 高效传输技术:压缩和并行双管齐下
SFTP本身支持压缩。客户端连接时加-C参数(比如sftp -C user@host),服务器端也开启压缩,数据量能减少30%~50%。对于大文件,并行传输更实用:lftp的get -P 4 file.zip同时开4个线程下载。rsync也可以配合--bwlimit限速并利用多线程。另外,传输模式要选二进制(binary),防止图片、视频这类文件因文本模式下的换行符转换而出错。
5. 硬件与存储:该升级就别犹豫
服务器硬件升级是治本的办法:内存至少加到8GB,CPU选Intel Xeon级别。硬盘从HDD换到SSD是性价比最高的提升——SSD的随机读写速度比HDD快几十倍,尤其适合SFTP这种频繁读写的小文件场景。磁盘I/O调度也值得优化:用echo deadline > /sys/block/sda/queue/scheduler改成deadline或noop算法,能减少排队等待时间。
6. 加密算法:平衡安全与速度
SFTP的加密过程占用CPU,如果算法选得不好,CPU直接成为瓶颈。在保证安全的前提下,优先选性能更好的算法:编辑/etc/ssh/sshd_config,设置Ciphers aes128-ctr,aes192-ctr,aes256-ctr。AES-CTR比AES-CBC快不少。如果是内网传输(比如局域网),可以进一步降低加密级别,只用aes128-ctr,速度和安全之间取个平衡。改完记得重启SSH服务。
其实归根结底一句话:找瓶颈、补短板。网络不行就先修路,服务器慢就升级硬件,客户端设置不对就优化配置。把这六个点逐一排查下来,SFTP传输速度基本不会让你失望。
