在 Ubuntu 中配置 Samba 实现「特定用户可写,其他用户只读」的共享目录

需求目标

  • 所有认证用户 可访问 Samba 共享目录 /path/to/home
  • **仅特定用户(如 developer)**拥有写权限;
  • 其他用户仅允许读取;
  • 禁止匿名访问

配置步骤

1. 设置文件系统权限

将目录 /home3/guest 的所有权设为 developer 用户和所属组,并设置权限:

bash 复制代码
sudo chown -R developer:developer /path/to/home
sudo chmod -R 755 /path/to/home
  • 755 权限:
    • 所有者(developer)可读写执行;
    • 其他用户仅可读和执行。

说明:此配置确保文件系统权限与 Samba 配置一致,避免权限冲突。


2. 配置 Samba 共享目录

编辑 Samba 配置文件(通常位于 /etc/samba/smb.conf),添加以下内容:

ini 复制代码
[public]
path = /path/to/home
public = no
browseable = yes
writable = no
write list = developer
create mask = 0644
directory mask = 0755
配置参数详解
参数 作用
path 共享目录的物理路径
public = no 禁止匿名访问
browseable = yes 允许用户浏览目录
writable = no 默认所有用户不可写
write list = developer developer 用户可写
create mask = 0644 新建文件的权限(所有者可读写,其他用户只读)
directory mask = 0755 新建目录的权限(所有者可读写执行,其他用户只读执行)

3. 重启 Samba 服务

应用配置更改:

bash 复制代码
sudo systemctl restart smbd

关键原理说明

1. Samba 的默认行为

  • 未设置 valid users:Samba 默认允许所有认证用户访问共享目录;
  • writable = no + write list :通过白名单控制写权限,避免手动维护 valid users 列表。

2. 权限优先级

  • Samba 配置 > 文件系统权限 :即使文件系统允许组写入(如 755),Samba 的 writable = nowrite list 会覆盖这一限制,确保仅白名单用户可写。

3. 安全性设计

  • 禁止匿名访问 :通过 public = no 和全局默认配置 map to guest = Bad User 实现;
  • 最小权限原则:默认只读,通过白名单授予写权限。

注意事项

1. 配置一致性

  • 确保文件系统权限与 Samba 配置一致,避免权限冲突。
  • 若发现权限异常,检查 Samba 日志:/var/log/samba/smbd.log

2. 扩展场景

  • 限制特定用户组访问
    添加 valid users = @group_name 限制仅某组用户可访问;
  • 更细粒度控制
    使用 ACL(setfacl)实现更复杂的权限管理。

总结

通过上述配置,你可以实现:

  • 所有认证用户可读共享目录;
  • 仅特定用户(如 developer 可写;
  • 无需频繁维护用户列表,适应用户频繁变动的场景;
  • 安全可控,避免匿名访问和权限泄露风险。

此方案适用于开发团队协作、自动化构建目录等场景,确保数据安全的同时提升协作效率。

相关推荐
爱学习的程序媛几秒前
PSTN(公共交换电话网)的起源与发展
网络·信息与通信
roman_日积跬步-终至千里37 分钟前
【Java并发】Java 线程池实战:警惕使用CompletableFuture.supplyAsync
java·开发语言·网络
xfddlm39 分钟前
边缘计算_ubuntu环境下使用瑞芯微RK3576NPU推理LLM
人工智能·ubuntu·边缘计算
lucky67071 小时前
Windows 上彻底卸载 Node.js
windows·node.js
编程小白20261 小时前
从 C++ 基础到效率翻倍:Qt 开发环境搭建与Windows 神级快捷键指南
开发语言·c++·windows·qt·学习
EHagSJVNpTY1 小时前
MATLAB 中基于最大重叠离散小波变换的心电信号处理探索
ubuntu
2的n次方_1 小时前
Runtime 内存管理深化:推理批处理下的内存复用与生命周期精细控制
c语言·网络·架构
.小墨迹2 小时前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
郝学胜-神的一滴3 小时前
深入浅出:使用Linux系统函数构建高性能TCP服务器
linux·服务器·开发语言·网络·c++·tcp/ip·程序人生
天若有情6733 小时前
【自研实战】轻量级ASCII字符串加密算法:从设计到落地(防查岗神器版)
网络·c++·算法·安全·数据安全·加密