在Linux系统中,共享文件是常见的网络需求,无论是企业环境中的跨平台协作,还是家庭网络内的文件互通,都需要高效的共享方案,Linux提供了多种文件共享协议和服务,支持不同场景下的文件传输与访问需求,本文将详细介绍主流的Linux文件共享方法,包括Samba(与Windows共享)、NFS(Linux/Unix内网共享)、FTP(文件上传下载)、HTTP/S(Web访问)以及SSH(安全传输),涵盖原理、配置步骤及优缺点分析,帮助用户根据实际需求选择合适的方案。

通过Samba实现与Windows系统共享文件
Samba是基于SMB/CIFS协议的开源软件,主要用于Linux与Windows系统之间的文件共享,支持用户认证、权限管理及打印机共享,是跨平台环境的首选方案。
安装Samba
以CentOS/RHEL为例,使用yum安装:
sudo yum install samba samba-client -y
Ubuntu/Debian系统则使用apt:
sudo apt update && sudo apt install samba samba-common -y
创建共享目录并设置权限
假设共享目录为/home/samba/shared,创建后赋予读写权限:
sudo mkdir -p /home/samba/shared sudo chmod 777 /home/samba/shared # 临时开放权限,生产环境建议按需设置
配置Samba核心文件
编辑主配置文件/etc/samba/smb.conf,在文件末尾添加共享段配置:
[shared]
comment = Windows Shared Folder
path = /home/samba/shared
browseable = yes
writable = yes
guest ok = no # 禁用匿名访问,需用户认证
valid users = @smbgroup # 限制用户组(需提前创建组并添加用户)
create mask = 0664
directory mask = 0775
参数说明:browseable控制是否在网络中可见;writable允许写入;valid users指定可访问的用户或组。
创建Samba用户并设置密码
Samba用户需是Linux系统用户,且需单独设置Samba密码:
sudo groupadd smbgroup sudo useradd -G smbgroup smbuser # 创建用户并加入组 sudo smbpasswd -a smbuser # 设置Samba密码
启动并设置开机自启
sudo systemctl start smb nmb sudo systemctl enable smb nmb
防火墙与SELinux配置
放行Samba相关端口(139/TCP、445/TCP):
sudo firewall-cmd --permanent --add-service=samba sudo firewall-cmd --reload
若使用SELinux,需设置上下文:
sudo semanage fcontext -a -t samba_share_t "/home/samba/shared(/.*)?" sudo restorecon -Rv /home/samba/shared
Windows端访问
在Windows文件资源管理器地址栏输入\Linux主机IPshared,输入Samba用户名和密码即可访问。
通过NFS实现Linux/Unix系统内网共享
NFS(Network File System)是Linux/Unix系统间常用的文件共享协议,基于RPC(远程过程调用)实现,客户端可像访问本地目录一样挂载远程共享目录,适合内网服务器集群场景。
安装NFS服务端与客户端
服务端安装:

sudo yum install nfs-utils rpcbind -y # CentOS/RHEL sudo apt install nfs-kernel-server rpcbind -y # Ubuntu/Debian
客户端仅需安装nfs-utils(CentOS)或nfs-common(Ubuntu)。
配置共享目录
编辑/etc/exports文件,添加共享规则:
/home/nfs/shared 192.168.1.0/24(rw,sync,no_root_squash)
参数说明:/home/nfs/shared为共享目录;168.1.0/24为允许访问的网段;rw读写权限;sync数据同步写入;no_root_squash允许客户端root用户映射为服务端root(生产环境慎用)。
创建共享目录并启动服务
sudo mkdir -p /home/nfs/shared sudo chmod 755 /home/nfs/shared sudo systemctl start rpcbind nfs-server sudo systemctl enable nfs-server
客户端挂载远程共享
在客户端创建挂载点并执行挂载命令:
sudo mkdir -p /mnt/nfs_shared sudo mount -t nfs 192.168.1.100:/home/nfs/shared /mnt/nfs_shared # 替换为服务端IP
查看挂载状态:df -h,设置开机自启可写入/etc/fstab:
168.1.100:/home/nfs/shared /mnt/nfs_shared nfs defaults 0 0
通过FTP实现文件上传下载
FTP(File Transfer Protocol)适合需要频繁上传下载文件的场景,如网站资源管理、文件备份等,推荐使用vsftpd(Very Secure FTP Daemon),安全性较高。
安装vsftpd
sudo yum install vsftpd -y # CentOS sudo apt install vsftpd -y # Ubuntu
配置匿名用户与本地用户
编辑/etc/vsftpd/vsftpd.conf,关键配置如下:
anonymous_enable=NO # 禁用匿名用户 local_enable=YES # 允许本地用户 write_enable=YES # 允许写入 chroot_local_user=YES # 限制用户在家目录 allow_writeable_chroot=YES # 允许chroot目录写入 pasv_min_port=10000 # 被动模式最小端口 pasv_max_port=10100 # 被动模式最大端口
创建FTP用户并设置目录
sudo useradd -d /home/ftpuser -s /sbin/nologin ftpuser # 创建不可登录系统用户 sudo passwd ftpuser # 设置FTP密码 sudo mkdir -p /home/ftpuser/upload sudo chown -R ftpuser:ftpuser /home/ftpuser
启动服务与防火墙
sudo systemctl start vsftpd sudo systemctl enable vsftpd
防火墙放行FTP端口(21/TCP)及被动模式端口:
sudo firewall-cmd --permanent --add-service=ftp sudo firewall-cmd --permanent --add-port=10000-10100/tcp sudo firewall-cmd --reload
客户端连接
使用FileZilla、WinSCP等工具,主机填Linux IP,端口21,用户名/密码为ftpuser及设置的密码。
通过HTTP/S实现Web方式共享文件
若需通过浏览器直接访问共享文件,可搭建HTTP/S文件服务器,适合临时分享或小型团队文件查看。
使用Apache搭建HTTP共享
安装Apache:
sudo yum install httpd -y # CentOS sudo apt install apache2 -y # Ubuntu
创建共享目录并配置虚拟主机:

sudo mkdir -p /var/www/shared echo "This is a shared file." | sudo tee /var/www/shared/test.txt
编辑Apache配置文件/etc/httpd/conf/httpd.conf(CentOS)或/etc/apache2/sites-enabled/000-default.conf(Ubuntu),添加:
<Directory /var/www/shared>
Options Indexes FollowSymLinks
AllowOverride None
Require all granted
</Directory>
启动服务:sudo systemctl start httpd(CentOS)或sudo systemctl start apache2(Ubuntu)。
启用HTTPS加密(可选)
使用Let’s Encrypt免费证书:
sudo yum install certbot python3-certbot-apache -y # CentOS sudo certbot --apache -d yourdomain.com # 替换为域名
配置后通过https://IP/shared访问,浏览器会显示文件列表并支持下载。
通过SSH实现安全文件传输
SSH(Secure Shell)协议支持加密传输,适合需要高安全性的场景,可通过scp(命令行)或SSHFS(挂载远程目录)实现文件共享。
使用scp传输文件
基本语法:scp [选项] 本地文件 用户@远程主机:远程路径
# 上传文件到远程主机 scp /home/localfile.txt user@192.168.1.100:/home/ # 从远程主机下载文件 scp user@192.168.1.100:/home/remotefile.txt /home/
使用SSHFS挂载远程目录
客户端安装SSHFS:
sudo yum install fuse-sshfs -y # CentOS sudo apt install sshfs -y # Ubuntu
挂载远程目录:
sudo mkdir -p /mnt/sshfs sshfs user@192.168.1.100:/home /mnt/sshfs -o allow_other
卸载:sudo umount /mnt/sshfs
Linux文件共享协议对比
| 协议 | 适用场景 | 传输协议 | 权限控制 | 易用性 | 安全性 |
|---|---|---|---|---|---|
| Samba | Linux与Windows跨平台共享 | SMB/CIFS | 用户/组/共享权限 | 高 | 中(支持SMB3加密) |
| NFS | Linux/Unix内网共享 | NFS(RPC) | UID/GID | 中 | 中(基于IP限制) |
| FTP | 文件上传下载 | FTP/TLS | 用户/匿名 | 高 | 低(建议FTPS) |
| HTTP/S | Web方式访问文件 | HTTP/HTTPS | URL/认证 | 高 | 高(HTTPS加密) |
| SSH | 安全文件传输/目录挂载 | SSH/SFTP | SSH密钥/密码 | 中 | 高(端到端加密) |
相关问答FAQs
问题1:如何在Linux和Windows之间共享文件,且Windows用户可直接编辑文件?
解答:推荐使用Samba协议,首先在Linux端安装Samba并创建共享目录,配置/etc/samba/smb.conf时设置writable=yes和valid users包含Windows对应的Linux用户(需提前创建Samba用户),在Windows端通过\LinuxIP共享名访问,输入用户名密码后即可像操作本地文件一样编辑,需确保Linux目录权限(如chmod 775)和Samba用户组权限匹配。
问题2:共享文件时如何防止未授权访问?
解答:可通过以下措施增强安全性:1. 身份认证:禁用匿名访问(如Samba的guest ok=no,FTP的anonymous_enable=NO),仅允许授权用户访问;2. 加密传输:使用SMB3、HTTPS、SSH/SFTP等加密协议,避免FTP明文传输;3. 权限控制:按需设置目录权限(如chmod 750),限制用户只访问必要文件;4. IP限制:通过防火墙规则(如iptables或firewalld)限制访问IP,或NFS的/etc/exports中指定允许网段;5. 定期更新:保持共享服务软件(如Samba、vsftpd)为最新版本,修复安全漏洞。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/27376.html