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 / 问题 / 793356
Accepted
Kapa Pi
Kapa Pi
Asked: 2025-04-05 22:12:51 +0800 CST2025-04-05 22:12:51 +0800 CST 2025-04-05 22:12:51 +0800 CST

双启动系统(Windows、Linux)中共享文件的用户权限:无法在 Linux 上编辑共享文件

  • 772

我在同一系统上运行 Windows 10 和 Fedora Linux 40 KDE Plasma。每个操作系统都安装在不同的物理驱动器上。我还在系统上安装了一个额外的 SSD 驱动器,该驱动器在两个操作系统上都是自动安装的,并且这两个操作系统都对所述第三个驱动器(以下简称“共享驱动器”)具有读写访问权限。

使用双启动系统的想法是主要使用 Linux 来处理几乎所有事情,并在必要时跳转到 Windows(例如(但不限于)运行一些 Windows 独有的 GUI 应用程序)。

共享驱动器是btrfs文件系统驱动器。其挂载点条目/etc/fstab如下:

UUID=MY_BTRFS_UUID /MY_MOUNTPOINT btrfs nofail,defaults,compress-force=zstd:3,noatime,lazytime,commit=120,space_cache=v2,nofail 0 0

我注意到以下行为:

我正在 Linux 上使用 GUI 应用程序处理保存在共享驱动器上的特定文件(我正在使用 Blender 处理 .blend 文件)。该文件最初是在我的 Linux 系统上创建的(因此分配给了一个用户帐户)。当我启动 Windows 时,我可以正常编辑在 Linux 上创建的文件并在共享驱动器上保存更改。启动回 Linux 后,我可以通过 GUI 应用程序打开(我想是读取),但从那里我无法再保存(写入)它。 事实上,我只是尝试使用一个简单的文本文件重新创建相同的行为。我在 Windows 上创建了它,回到 Linux 后,我无法使用简单的文本编辑器(如 Kate)保存更改。

通过简单的检查以及我相当基础的知识,问题似乎源于在 Windows 上创建/覆盖的文件被分配给“nobody:users”(我相信它读作“user:group”)。无论在 Linux 上是否可编辑,在给定目录上使用 ls -lh 都会报告所有文件共享相同的权限,只是不同的用户:组组合。可编辑文件被分配给评估形式 $USER:$USER(我不记得明确指定了相同的用户名和组名,但是嘿,也许我指定了,我只是在设置过程中顺其自然)。“nobody”文件的副本(通过在 Dolphin 的 GUI 界面上进行简单的复制粘贴完成)被重新分配给当前 Linux 用户,使该文件可编辑。尝试使用 Kate 保存原始虚拟文本文件(在 Windows 上创建)会要求输入密码,当提供密码时,确实会写入更改,但所有权保持不变(“nobody”)。可以预见的是,再次尝试编辑同一个文件会再次要求 root 权限。

另一件值得一提的事情是,虽然一些 GUI 应用程序提供了提升权限的选项(如 Kate,如上所述),但其他 GUI 应用程序(如 Blender,就我而言)似乎没有提供任何选项来克服这个问题。Blender只是返回“ (路径)不可写”。我可以忍受(尽管并不高兴)在必要时提供密码,但事实并非如此,我需要找到一种解决方法。显然,我不希望每次都必须手动重新分配所有权。

现在,我是一个简单的人,我希望能够登录每个操作系统并无缝处理共享文件/目录。解决这个问题的最佳方法是什么?我认为我不应该特别关心所有权状态,除非它会带来我(很可能)不知道的事情。

fedora
  • 2 2 个回答
  • 180 Views

2 个回答

  • Voted
  1. telcoM
    2025-04-06T02:30:52+08:002025-04-06T02:30:52+08:00

    如果您的 Windows Btrfs 驱动程序是这个,它包含一种在 Windows 用户帐户和 Linux UID 之间设置映射的方法。听起来您还没有这样做,或者您的映射可能有错误。

    请参阅驱动程序 Github 页面上标题为“映射”的章节。

    • 3
  2. Best Answer
    ReflectYourCharacter
    2025-04-06T02:19:41+08:002025-04-06T02:19:41+08:00

    有多种选择:

    • 编辑您的/etc/fstab并添加条目,或修改您的.bashrc以在每次登录时重置权限。

    • 创建一个服务(或类似机制)来自动处理权限。

    exFAT

    最简单的解决方案:将文件系统切换为exFAT

    如果您使用exFAT,则两个系统之间不会有任何读/写权限问题,因为它完全exFAT不存储user:group元数据或权限位冲突。

    这些/etc/fstab设置仍然有用。它们确保所有新文件都属于您,即使 Windows 创建了它们。

    要在启动时使用正确的权限自动挂载驱动器,请将此条目添加到/etc/fstab:

    UUID=YOURUUID /YOURMOUNTPOINT exfat defaults,uid=1000,gid=1000,umask=0022 0 0

    btrfs

    如果添加这两个条目来/etc/fstab处理btrfs文件系统并设置用户和组,则会出错。

    The requested operation has failed: Error mounting system-managed device /dev/sda1: fsconfig system call failed: btrfs: Unknown parameter 'uid'

    UUID=YOUR_BTRFS_UUID /MOUNTPOINT btrfs defaults,noatime,uid=1000,gid=1000,umask=0022 0 0

    或者

    UUID=MY_BTRFS_UUID /MY_MOUNTPOINT btrfs nofail,defaults,compress-force=zstd:3,noatime,lazytime,commit=120,space_cache=v2,uid=1000,gid=1000,umask=0022 0 0

    发生错误是因为 Btrfs 不支持 uid/gid 挂载选项,与 ext4 或 fat 等文件系统不同。

    这些参数会被默默忽略或拒绝,这就是您尝试的解决方法失败的原因。

    • 通过 fstab 获取 btrfs 分区的所有权
    • 2

相关问题

  • 无法使用 git 克隆 https 网址

  • VirtualBox 无法在 Fedora 26 中安装

  • 使用触摸屏时如何禁用屏幕键盘?

  • 如何找出 nmcli 中缺少的插件?

  • 如何正确分区 SSD 以进行双启动设置

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

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

    • 4 个回答
  • Marko Smith

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

    • 5 个回答
  • Marko Smith

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

    • 3 个回答
  • 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
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +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

热门标签

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