如何实现Linux与Windows资源共享?

通过Samba实现双向共享(推荐方案)

Samba是Linux对SMB/CIFS协议的开源实现,完美兼容Windows共享协议,企业级应用验证其稳定性。

操作步骤:

  1. Linux端安装Samba服务

    # Debian/Ubuntu
    sudo apt update && sudo apt install samba samba-common-bin
    # RHEL/CentOS
    sudo yum install samba samba-client
  2. 创建专用共享账户

    sudo useradd smbuser -M -s /sbin/nologin  # 创建无登录权限的系统账户
    sudo smbpasswd -a smbuser  # 设置Samba专属密码
  3. 配置共享目录(编辑/etc/samba/smb.conf)

    [SharedFolder]
    path = /srv/shared  # 共享目录绝对路径
    valid users = smbuser
    writable = yes
    browseable = yes
    create mask = 0664
    directory mask = 0775
  4. 应用配置并启动服务

    sudo systemctl restart smbd nmbd
    sudo systemctl enable smbd nmbd
    sudo ufw allow samba  # 开放防火墙
  5. Windows访问共享
    Win+R 运行 \\Linux_IP\SharedFolder
    输入smbuser及对应密码


从Linux访问Windows共享

适用于临时获取Windows文件,无需在Linux部署服务。

命令行操作(适用于脚本化场景)

sudo mkdir /mnt/win_share
sudo mount -t cifs //192.168.1.100/Shared /mnt/win_share -o username=winuser,password=yourpass,vers=3.0

注:vers=3.0 指定SMB协议版本,需与Windows版本匹配(Win10+建议用3.0)

图形化操作(GNOME/KDE桌面)

  1. 文件管理器 > 其他位置 > 连接服务器
  2. 输入 smb://192.168.1.100/Shared
  3. 认证窗口输入Windows账户凭据

NFS共享(仅限Linux间)

虽非跨平台方案,但在纯Linux环境中性能更优。

Windows端准备

  1. 启用”NFS客户端服务”(控制面板 > 程序 > 启用功能)
  2. 管理员CMD执行:
    mount \\Linux_IP\SharedFolder Z:

Linux端配置

sudo apt install nfs-kernel-server
sudo vim /etc/exports  # 添加:/srv/nfs_share 192.168.1.0/24(rw,sync,no_subtree_check)
sudo exportfs -a

关键安全实践

  1. 最小权限原则

    chmod 2770 /srv/shared  # 设置SGID保持组权限
    setfacl -d -m g::rwx /srv/shared  # 继承目录权限
  2. 网络隔离

    sudo ufw allow from 192.168.1.0/24 to any app samba
  3. 传输加密(企业级)
    smb.conf启用:

    server min protocol = SMB3
    smb encrypt = required

故障排查指南

现象 解决方案
Windows无法发现共享 执行 sudo nmbd restart
权限拒绝(13) 检查SELinux状态:setsebool -P samba_export_all_rw on
协议版本不匹配 Windows启用SMB1:控制面板 > 程序 > 启用功能 > SMB 1.0

专业建议

  1. 企业级工具

    • 统一认证:集成Active Directory(smb.conf配置security = ads
    • 审计追踪:sudo auditctl -w /srv/shared -p wa
  2. 性能优化

    socket options = TCP_NODELAY IPTOS_LOWDELAY
    use sendfile = yes

引用说明

  • Samba官方文档:https://www.samba.org/samba/docs/
  • Microsoft SMB协议规范:https://docs.microsoft.com/en-us/openspecs/windows_protocols/ms-smb/
  • Linux内核NFS指南:https://www.kernel.org/doc/html/latest/filesystems/nfs/index.html
  • CIS安全基准:https://www.cisecurity.org/benchmark/linux

本方案经CentOS 7+/Ubuntu 20.04 LTS与Windows 10/11环境实测,遵循零信任安全模型,企业用户建议部署前在测试环境验证ACL策略,个人用户注意及时更新Samba补丁(CVE-2021-44142等漏洞修复)。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/6544.html

(0)
酷番叔酷番叔
上一篇 2025年7月7日 09:17
下一篇 2025年7月7日 09:37

相关推荐

  • 如何修改linux中的日期格式

    Linux中,可通过date命令设置日期格式,如date +%Y-%m-%d显示年月日格式。

    2025年8月19日
    1600
  • 如何在命令行中快速保存?

    在命令行界面中保存操作通常使用save或write命令(具体命令因系统而异,如思科设备常用copy running-config startup-config),将当前运行配置或更改永久写入存储设备(如闪存),确保设备重启后配置不丢失。

    2025年7月5日
    3800
  • Linux man命令如何退出?操作疑问标题

    Linux系统中的man命令(manual page的缩写)是用户获取命令、函数、配置文件等帮助信息的重要工具,几乎每个Linux用户都会用到,不少新手在使用man命令时,常常会遇到进入帮助页面后不知道如何退出的问题,尤其是在多屏显示的情况下,可能会误操作导致界面卡顿或无法返回命令行,man命令的退出方法并不复……

    2025年8月22日
    1000
  • Linux中z标识的压缩文件如何解压缩?

    在Linux系统中,“.z”后缀的文件是由早期的compress命令压缩生成的压缩文件,该工具采用LZW(Lempel-Ziv-Welch)压缩算法,是Unix系统中较早的压缩格式之一,尽管现代Linux发行版更推荐使用gzip(.gz)、bzip2(.bz2)或xz(.xz)等压缩率更高、效率更好的工具,但在……

    2025年8月25日
    1100
  • 如何删除名为 mylink 的软链接?

    删除软链接的核心命令使用 rm 命令(最常用)rm /path/to/softlink_name参数说明:rm:删除文件或链接的标准命令,/path/to/softlink_name:软链接的完整路径(结尾不能加 ),示例:使用 unlink 命令(专用于单文件删除)unlink /path/to/softli……

    2025年7月29日
    2200

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信