如何实现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 qt如何静态编译程序

    Linux 下使用 Qt 静态编译程序,需配置 Qt 的静态库路径,并在 .

    2025年8月18日
    3500
  • Mac装Linux,双系统还是虚拟机?

    准备工作硬件兼容性检查Intel 芯片 Mac:支持大多数 Linux 发行版(如 Ubuntu、Fedora),Apple Silicon(M1/M2/M3):需选择支持 ARM 架构的发行版(如 Ubuntu ARM、Asahi Linux),T2 安全芯片机型(2018年后部分 Intel Mac):需关……

    2025年7月5日
    5700
  • Linux如何打开程序?图形与命令行全攻略

    图形界面打开程序(适合桌面用户)应用程序菜单点击桌面左下角或顶部的 应用程序菜单(不同桌面环境名称可能不同,如GNOME称“Activities”,KDE称“Application Launcher”),在分类列表中找到目标程序(如Firefox、LibreOffice),单击图标即可启动,快捷方式与桌面图标若……

    2025年8月8日
    3600
  • Linux启动时如何中止启动?

    Linux启动是一个涉及多个阶段的复杂过程,从BIOS/UEFI初始化硬件,到引导加载程序加载内核,再到initramfs准备根文件系统,最后由init系统启动用户空间服务,若在启动过程中遇到系统故障(如忘记密码、服务冲突、文件系统错误等),可能需要中止正常启动流程,进入救援模式或单用户模式进行修复,以下是不同……

    2025年10月2日
    1200
  • Linux系统中如何查看所有用户及其详细信息?

    在Linux系统中,查看用户信息是系统管理和日常运维中的常见操作,掌握多种方法可以灵活应对不同场景,本文将详细介绍Linux中查看用户的各类命令及其使用场景,帮助用户全面了解系统中的用户状态,查看当前登录用户若需快速确认当前操作系统的登录用户,可以使用以下命令:whoami:最简单的命令,仅返回当前用户的用户名……

    2025年9月21日
    2100

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信