AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 453541
Accepted
localhost
localhost
Asked: 2018-07-05 22:51:54 +0800 CST2018-07-05 22:51:54 +0800 CST 2018-07-05 22:51:54 +0800 CST

创建仅具有写入权限且没有读取权限的 samba 共享

  • 772

用例

我是唯一的用户。我有一个带有全盘加密的 ubuntu NAS,我正在尝试将我自己的 Windows 机器备份到那个。我想要一个可以启动的 USB 记忆棒,以将 Windows 驱动器克隆到 NAS,但我不希望任何可能遇到带有共享凭据的 USB 记忆棒的人都可以读取整个备份共享。你能想出更好的解决方案吗?

我在想什么可以工作

我一直在寻找但找不到我需要的东西,我发现的一切都是关于简单地启用对共享的写访问,这不是我想要做的。

我想在我的 ubuntu 机器上创建一个 samba 共享,用户只有写权限。我希望他们能够创建文件但不能读取它们,也不能列出共享中的文件夹。

这是为了备份。我想要一个可启动的 USB 驱动器,我可以从中启动它会获取该机器中驱动器的磁盘映像并保存到 samba 共享中,但我不希望该 USB 能够访问所有映像。

如果文件已经存在,我很高兴它只是失败,我将通过使用驱动器 UUID/时间来确保文件名不会冲突。

backup samba
  • 2 2 个回答
  • 1623 Views

2 个回答

  • Voted
  1. ctrl-alt-delor
    2018-07-06T03:06:20+08:002018-07-06T03:06:20+08:00

    挂载点仅支持禁用写入(只读),但不支持禁用读取。但是,您可以使用文件权限完成大部分操作。无法阻止用户读取她自己的文件,但您可以阻止她读取其他人的文件。

    你会需要:

    • 粘性位,以阻止用户删除彼此的文件。
    • 关闭目录的读取位以阻止其他人读取
    • 设置默认权限,关闭文件的读取位以阻止其他人读取它们。

    如何

      chmod +t "«the directory»"
      setfacl -m "u::wx,g::wx,o:-" "«the directory»"
      setfacl -m "d:u::-,d:g::-,d:o:-" "«the directory»"
    

    警告

    这不会被用户轻易使用,考虑给予一些额外的权限。或每个用户一个目录。

    我也不认为这是进行备份的方法。设置一个 cron 作业以每天进行备份。您可能正在使用备份进行修订控制,请考虑使用修订控制系统。子版本(svn),对于必须用户和大多数文件类型来说是一个很好的版本。Mercurial 对程序员也有好处,可以用于其他文件类型,但我不建议将它用于任何不可合并的文件(例如 MS-Office)。

    • 1
  2. Best Answer
    yahol
    2019-03-12T03:25:44+08:002019-03-12T03:25:44+08:00

    我做过类似的事情,唯一的区别是一个用户可以只写而不阅读(甚至列出目录),另一个用户只能阅读。

    /etc/samba/smb.conf

    [write-only]
      comment = Write-only access without read
      path = /smbshare
      hosts allow = 172.17.10.10
      hosts deny = 0.0.0.0/0
      read only = no
      write list = smbwrite
      force user = smbwrite
      force group = smbread
      create mask = 0350
      directory mask = 0350
      force create mode = 0350
      force directory mode = 0350
    

    服务器端的初始访问权限:

    chmod -R 350 /smbshare
    chown -R smbwrite:smbread /smbshare
    

    唯一的缺点是,如果您知道确切的文件名,则可以列出它。

    以下部分供参考:

    [read-only]
      comment = Read-only access
      path = /smbshare
      read only = yes
      hosts allow = 172.17.10.20
      hosts deny = 0.0.0.0/0
      read list = @smbread
    

    /etc/fstab两个客户端上的条目:

    smbwrite (172.17.10.10),本地用户“foo”:

    //172.17.10.1/write-only      /mnt/write      cifs    user=smbwrite,pass=s3kr1t,uid=foo,vers=3.0 0 0
    

    smbread (172.17.10.20),本地用户“bar”:

    //172.17.10.1/read-only /mnt/read cifs user=smbread,pass=s3kr1t,uid=bar,vers=3.0 0 0
    
    • 1

相关问题

  • 如何在 Samba Active Directory 中导出完整的用户列表?

  • 挂载 samba 共享时出错:CIFS VFS:未指定用户名

  • 如何为多个项目组织您的系统?[关闭]

  • 我可以将时移快照保存到保管箱吗?

  • Iptables 规则允许 appVM 通过配置为仅通过 QubesOS 中的 VPN 的 proxyVM

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve