mdr*_*drg 9 filesystem permissions windows ntfs
我的 PC 有 3 个 NTFS 分区(主分区和备份分区)以及双引导下的 Ubuntu。我想保持 NTFS 分区可用,但默认情况下以只读方式挂载,以便其他用户(甚至是我)不会以有害的方式修改它们。我看到我无法更改 NTFS 分区的权限,这是可以理解的。
如果可能,我希望只有 root 可以更改默认权限,这样其他用户都不能在不切换到 Windows 的情况下修改它们。如果这是不可能的,使 NTFS 不可挂载也可以。
这主要是为了避免损坏我的 Windows 系统的保护措施,因为我仍然会经常使用它。
编辑 1:这是我的 fstab
# <file system> <mount point> <type> <options> <dump> <pass>
proc /proc proc nodev,noexec,nosuid 0 0
# / was on /dev/sda7 during installation
UUID=4a5ff937-5220-4b4e-b994-304ba37d3448 / ext4 errors=remount-ro 0 1
# swap was on /dev/sda8 during installation
UUID=a0285d57-8247-4efe-88ca-14bee4b8630b none swap sw 0 0
/dev/fd0 /media/floppy0 auto rw,user,noauto,exec,utf8 0 0
Run Code Online (Sandbox Code Playgroud)
所以,我想将我所有的 3 个 NTFS HD 设置为只读(没有自动安装)。另外,请告诉我在哪里可以找到/path/to/ntfs
每个分区的。
另外,我可以评论软盘条目吗?反正我没有=)
编辑 2:'mount -v' 的相关部分
/dev/sda1 on /media/1A7099D97099BC47 type fuseblk (rw,nosuid,nodev,allow_other,blksize=4096,default_permissions)
/dev/sda5 on /media/Stuff type fuseblk (rw,nosuid,nodev,allow_other,blksize=4096,default_permissions)
/dev/sda6 on /media/Backup type fuseblk (rw,nosuid,nodev,allow_other,blksize=4096,default_permissions)
Run Code Online (Sandbox Code Playgroud)
编辑 3:好的,所以我安装了 pysdm(存储设备管理器),将我所有的 NTFS 分区设置为可挂载我的任何用户,只读,然后重新启动。现在我无法挂载分区:
Unprivileged user can not mount NTFS block devices using the external FUSE library. Either mount the volume as root, or rebuild NTFS-3G with integrated FUSE support and make it setuid root. Please see more information at http://ntfs-3g.org/support.html#unprivileged
Run Code Online (Sandbox Code Playgroud)
经过一些阅读后,似乎以 root 身份安装分区不是一个好主意。那么,我怎样才能允许安装(由任何用户)?
我认为实现这一点的最简单方法是检查/etc/fstab
并更改 NTFS 分区的选项以只读方式安装。
在正在运行的系统中,您可以使用mount -o remount,ro /path/to/ntfs
.
所以,我得到了一个解决方案。
对于那些尝试这样做的人,请编辑您的 fstab 并包括:
#change '/dev/sda1' to your partition id
#change '/mnt/ntfsfolder' to whatever mount point you want
/dev/sda1 /mnt/ntfsfolder ntfs-3g defaults,umask=022 0 0
Run Code Online (Sandbox Code Playgroud)
这样,只有 root 用户才能在 NTFS 分区上写入,所有其他用户只能读取它。如果您想更改此类分区上的某些内容,请使用gksu
命令以 root 身份执行。例子:
gksu nautilus
Run Code Online (Sandbox Code Playgroud)
这将以 root 身份打开 Nautilus(文件管理器)。
归档时间: |
|
查看次数: |
8088 次 |
最近记录: |