如何在debian中实现文件共享
导读:在 Debian 中实现文件共享的常用方式 Samba:与 Windows/macOS/Linux 互通,适合跨平台办公与家庭网络。 NFS:Linux/Unix 间高性能共享,适合同网段服务器与工作站。 SSHFS:基于 SSH 的安全...
在 Debian 中实现文件共享的常用方式
- Samba:与 Windows/macOS/Linux 互通,适合跨平台办公与家庭网络。
- NFS:Linux/Unix 间高性能共享,适合同网段服务器与工作站。
- SSHFS:基于 SSH 的安全挂载,适合临时访问与小规模使用。
方案一 Samba 共享(跨平台)
- 安装组件
- 执行:
sudo apt update & & sudo apt install samba
- 执行:
- 创建共享目录与权限
- 示例:
sudo mkdir -p /srv/share & & sudo chmod 0775 /srv/share & & sudo chown nobody:nogroup /srv/share
- 示例:
- 编辑配置文件
- 文件:
/etc/samba/smb.conf - 示例共享段(可放在文件末尾):
[share] path = /srv/share browseable = yes read only = no guest ok = yes create mask = 0775 directory mask = 0775
- 文件:
- 添加 Samba 用户(系统用户需存在)
- 执行:
sudo smbpasswd -a youruser
- 执行:
- 启动与开机自启
- 执行:
sudo systemctl restart smbd nmbd & & sudo systemctl enable smbd nmbd
- 执行:
- 防火墙放行(如使用 UFW)
- 执行:
sudo ufw allow samba
- 执行:
- 客户端访问
- Windows:在资源管理器输入
\\服务器IP\share - Linux:
sudo apt install cifs-utils,然后sudo mount -t cifs //服务器IP/share /mnt -o username=youruser,password=yourpass
- Windows:在资源管理器输入
方案二 NFS 共享(Linux/Unix 同网段)
- 安装组件
- 执行:
sudo apt update & & sudo apt install nfs-kernel-server nfs-common
- 执行:
- 创建共享目录与权限
- 示例:
sudo mkdir -p /srv/nfs & & sudo chown nobody:nogroup /srv/nfs & & sudo chmod 0775 /srv/nfs
- 示例:
- 配置导出(/etc/exports)
- 示例(将 192.168.1.0/24 读写共享,其他只读):
/srv/nfs 192.168.1.0/24(rw,sync,no_subtree_check) /srv/nfs *(ro,sync,no_subtree_check)
- 示例(将 192.168.1.0/24 读写共享,其他只读):
- 应用配置并启动
- 执行:
sudo exportfs -arv & & sudo systemctl restart nfs-server & & sudo systemctl enable nfs-server
- 执行:
- 客户端挂载
- 执行:
sudo mkdir -p /mnt/nfs & & sudo mount -t nfs 服务器IP:/srv/nfs /mnt/nfs
- 执行:
- 常用导出选项说明
- ro/rw(只读/读写)、sync(同步写入)、no_subtree_check(提升性能)、root_squash(默认将 root 映射为匿名,更安全)
方案三 SSHFS 共享(基于 SSH 的安全挂载)
- 安装组件
- 执行:
sudo apt update & & sudo apt install sshfs
- 执行:
- 创建本地挂载点并挂载
- 执行:
sudo mkdir -p /mnt/sshfs & & sshfs user@服务器IP:/remote/path /mnt/sshfs
- 执行:
- 卸载
- 执行:
fusermount -u /mnt/sshfs
- 执行:
- 适用场景
- 临时访问、无需在服务器上配置额外服务,依赖 SSH 认证与加密
安全与排错要点
- 最小权限与身份映射
- Samba 建议使用 valid users、create mask/directory mask 精细化控制;NFS 默认 root_squash 更安全,必要时才用 no_root_squash。
- 防火墙与端口
- Samba:放行 TCP 139/445;NFS:放行 rpcbind 111/TCP+UDP 与 nfs 2049/TCP+UDP。
- 配置语法检查
- Samba 配置变更后用
testparm校验,避免语法错误导致服务异常。
- Samba 配置变更后用
- 客户端连通性
- NFS 客户端先用
showmount -e 服务器IP查看导出列表,再挂载测试。
- NFS 客户端先用
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: 如何在debian中实现文件共享
本文地址: https://pptw.com/jishu/780631.html
