Linux作为广泛使用的服务器操作系统和开发环境,文件上传下载是日常操作中的核心需求,无论是从服务器下载备份文件、上传代码到远程仓库,还是在本地与设备间传输数据,掌握Linux下的上传下载工具和方法都至关重要,本文将详细介绍Linux中常用上传下载工具的安装步骤、使用方法,以及服务器端文件传输服务的搭建,帮助用户根据不同场景选择合适的方案。
命令行工具:高效灵活的传输利器
命令行工具是Linux环境下最常用的文件传输方式,尤其适合服务器管理、自动化脚本等场景,以下介绍几款主流工具的安装与使用。
wget:纯下载工具,支持多种协议
wget是一款免费的网络文件下载工具,支持HTTP、HTTPS、FTP等多种协议,具备断点续传、后台下载、递归下载等实用功能。
安装步骤:
- 基于Debian/Ubuntu的系统:
sudo apt update && sudo apt install wget -y
- 基于RHEL/CentOS的系统:
sudo yum install wget -y # CentOS 7及以下 sudo dnf install wget -y # CentOS 8/RHEL 8及以上
常用使用场景:
- 下载单个文件:
wget http://example.com/file.zip
- 断点续传(网络中断后继续下载):
wget -c http://example.com/large_file.iso
- 后台下载(关闭终端后仍继续):
wget -b http://example.com/file.log
- 下载并重命名文件:
wget -O new_name.zip http://example.com/file.zip
curl:多功能传输工具,支持上传下载
curl功能比wget更丰富,支持HTTP、HTTPS、FTP、SCP、SFTP等多种协议,不仅能下载文件,还能上传文件到服务器、模拟HTTP请求等,适合与API交互或复杂传输场景。
安装步骤:
- 基于Debian/Ubuntu的系统:
sudo apt update && sudo apt install curl -y
- 基于RHEL/CentOS的系统:
sudo yum install curl -y # CentOS 7及以下 sudo dnf install curl -y # CentOS 8/RHEL 8及以上
常用使用场景:
- 下载文件并显示进度条:
curl -O http://example.com/file.txt
- 上传文件到HTTP服务器(需服务器支持):
curl -X POST -F "file=@/local/path/to/file" http://example.com/upload
- 显示HTTP响应头信息(调试网络请求):
curl -I http://example.com
scp:基于SSH的远程文件复制
scp(Secure Copy)通过SSH协议传输文件,具备加密传输功能,适合在本地与远程服务器间安全传输单个或少量文件。
安装步骤:
scp通常随OpenSSH客户端一起安装,若系统中未安装,可通过以下命令安装:
- 基于Debian/Ubuntu的系统:
sudo apt install openssh-client -y
- 基于RHEL/CentOS的系统:
sudo yum install openssh-clients -y # CentOS 7及以下 sudo dnf install openssh-clients -y # CentOS 8/RHEL 8及以上
常用使用场景:
- 从本地上传文件到远程服务器:
scp /local/file.txt user@remote_ip:/remote/path/
- 从远程服务器下载文件到本地:
scp user@remote_ip:/remote/file.txt /local/path/
- 指定SSH端口(非默认22端口时):
scp -P 2222 /local/file.txt user@remote_ip:/remote/path/
rsync:高效文件同步工具
rsync(Remote Sync)支持增量同步,仅传输文件差异部分,适合大文件或目录同步,常用于数据备份、镜像服务器搭建等场景。
安装步骤:
- 基于Debian/Ubuntu的系统:
sudo apt update && sudo apt install rsync -y
- 基于RHEL/CentOS的系统:
sudo yum install rsync -y # CentOS 7及以下 sudo dnf install rsync -y # CentOS 8/RHEL 8及以上
常用使用场景:
- 本地目录同步(目标目录不存在则创建,存在则覆盖):
rsync -av /local/src/ /local/dest/
- 远程目录同步(通过SSH):
rsync -av -e ssh /local/src/ user@remote_ip:/remote/dest/
- 压缩传输(减少网络带宽占用):
rsync -avz -e ssh /local/src/ user@remote_ip:/remote/dest/
- 排除特定文件(如日志文件):
rsync -av --exclude='*.log' /local/src/ /local/dest/
命令行工具对比
工具 | 主要协议 | 核心功能 | 适用场景 |
---|---|---|---|
wget | HTTP/HTTPS/FTP | 纯下载,支持断点续传、后台 | 批量下载、HTTP/FTP资源获取 |
curl | HTTP/HTTPS/FTP/SCP等 | 下载/上传,支持协议丰富,可交互 | REST API调用、上传文件到服务器 |
scp | SSH | 远程文件复制,基于加密传输 | 快速传输单个/少量文件到远程 |
rsync | SSH/RSYNC | 增量同步,压缩传输 | 大文件/目录同步,数据备份 |
图形界面工具:适合普通用户的可视化操作
对于不熟悉命令行的用户,图形界面工具(GUI)提供了更直观的文件传输方式,通过拖拽即可完成上传下载。
FileZilla:跨平台FTP/SFTP客户端
FileZilla是免费的跨平台FTP客户端,支持FTP、SFTP、FTPES等协议,具备多文件传输、断点续传、站点管理等功能,适合Windows、Linux、macOS系统。
安装步骤:
- 基于Debian/Ubuntu的系统:
sudo apt update && sudo apt install filezilla -y
- 基于RHEL/CentOS的系统:
sudo yum install filezilla -y # CentOS 7及以下 sudo dnf install filezilla -y # CentOS 8/RHEL 8及以上
- 或从官网(https://filezilla-project.org/)下载deb/rpm包安装。
使用方法:
- 打开FileZilla,点击“文件”→“站点管理器”,新建站点并命名;
- 选择协议(如SFTP),输入主机IP、用户名、密码,端口默认为22(SFTP);
- 点击“连接”,左侧显示本地文件,右侧显示远程服务器文件;
- 拖拽文件即可上传或下载,支持批量操作。
Linux自带文件管理器:Nautilus/Dolphin
大多数Linux发行版的文件管理器(如GNOME的Nautilus、KDE的Dolphin)支持直接连接远程服务器,无需额外安装软件。
使用方法(以Nautilus为例):
- 打开Nautilus文件管理器,在地址栏输入
sftp://user@remote_ip
(或ftp://user@remote_ip
); - 输入用户名和密码,连接成功后即可浏览远程文件;
- 拖拽本地文件到远程窗口即可上传,反之下载。
服务器端上传下载服务搭建:搭建自己的传输服务
若需要为团队或用户提供文件上传下载服务,可在服务器上搭建FTP或SFTP服务,以下以vsftpd(Very Secure FTP Daemon)为例,介绍FTP服务的搭建步骤。
安装vsftpd
vsftpd是Linux下常用的FTP服务器软件,安全性高、稳定性好。
安装步骤:
- 基于Debian/Ubuntu的系统:
sudo apt update && sudo apt install vsftpd -y
- 基于RHEL/CentOS的系统:
sudo yum install vsftpd -y # CentOS 7及以下 sudo dnf install vsftpd -y # CentOS 8/RHEL 8及以上
配置vsftpd
- 备份原配置文件:
sudo cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.bak
- 编辑配置文件:
sudo nano /etc/vsftpd/vsftpd.conf
- 修改以下关键参数:
anonymous_enable=NO # 禁止匿名登录 local_enable=YES # 允许本地用户登录 write_enable=YES # 允许写入(上传、删除文件) chroot_local_user=YES # 限制用户仅能访问家目录 pasv_min_port=10000 # 被动模式最小端口 pasv_max_port=10100 # 被动模式最大端口
创建FTP用户并设置权限
- 创建用户(如ftpuser)并设置家目录:
sudo useradd -m ftpuser
- 设置用户密码:
sudo passwd ftpuser
- 若需限制用户仅能通过FTP访问(禁止SSH登录),可修改
/etc/passwd
文件,将用户 shell 改为/usr/sbin/nologin
:sudo usermod -s /usr/sbin/nologin ftpuser
启动并配置防火墙
- 启动vsftpd服务并设置开机自启:
sudo systemctl start vsftpd sudo systemctl enable vsftpd
- 配置防火墙允许FTP端口(21)和被动模式端口(10000-10100):
- 基于Ubuntu的系统(使用ufw):
sudo ufw allow 20:21/tcp sudo ufw allow 10000:10100/tcp
- 基于CentOS的系统(使用firewalld):
sudo firewall-cmd --permanent --add-port=20:21/tcp sudo firewall-cmd --permanent --add-port=10000:10100/tcp sudo firewall-cmd --reload
- 基于Ubuntu的系统(使用ufw):
测试FTP服务
使用FileZilla或命令行连接FTP服务器:
- 主机:服务器IP
- 协议:FTP
- 用户名:ftpuser
- 密码:设置的密码
- 端口:21(主动模式)或10000-10100(被动模式)
连接成功后即可上传下载文件。
Linux下的文件上传下载方式多样,可根据需求选择合适的工具:
- 命令行工具(wget、curl、scp、rsync):适合服务器管理、自动化脚本,高效灵活;
- 图形界面工具(FileZilla、Nautilus):适合普通用户,操作直观;
- 服务器端服务(vsftpd、SFTP):适合搭建团队共享文件传输环境,支持多用户访问。
掌握这些工具和方法,能显著提升Linux环境下的文件传输效率,满足不同场景下的需求。
相关问答FAQs
问题1:Linux中使用wget下载文件时提示“Permission denied”,如何解决?
解答:通常是因为当前用户没有目标目录的写权限,可通过两种方式解决:1. 切换到有权限的目录(如cd /home/user/downloads
);2. 使用sudo wget
下载(需管理员权限,但注意下载的文件所有者可能变为root,后续可通过sudo chown user:group file
修改权限)。
问题2:如何通过rsync同步大文件时提高传输速度?
解答:1. 使用压缩选项(-z
),启用压缩传输减少网络带宽占用;2. 调整块大小(--block-size=4M
),根据网络情况调整(大文件可增大块大小);3. 使用多线程工具(如parallel-rsync
)结合rsync实现多线程传输;4. 确保服务器间网络稳定,避免丢包(可调整MTU值优化网络性能)。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/25264.html