ノートブックを起動するたびに、フォルダ権限がリセットされます。

ノートブックを起動するたびに、フォルダ権限がリセットされます。

私はArch Linuxを使用しており、ユーザーとしてラップトップを起動するたびにハードドライブのフォルダ権限がrootとしてのみ設定されているため、ユーザーとして開くことはできません。次のコマンドを使用して権限を変更します。

sudo chmod -R 775 /mnt

ここで、/mntは私のハードドライブを含むフォルダです。ノートブックを再起動すると、すべてがリセットされ、ハードドライブに再度アクセスするために同じコマンドを使用する必要がありますが、どのように権限を保存しますか?

/etc/fstabの出力

# Static information about the filesystems.
# See fstab(5) for details.

# <file system> <dir> <type> <options> <dump> <pass>
# /dev/sda6
UUID=e0888535-4d8b-4b89-9a7e-4a85208fe129   /           ext4        rw,relatime 0 1

私のハードドライブはWindowsディスクで、Windows 10でデュアルブートします。

dfの出力:

Filesystem     1K-blocks      Used Available Use% Mounted on
dev              2973860         0   2973860   0% /dev
run              2982588       716   2981872   1% /run
/dev/sda6       30313412   4987780  23762752  18% /
tmpfs            2982588    101116   2881472   4% /dev/shm
tmpfs            2982588         0   2982588   0% /sys/fs/cgroup
tmpfs            2982588       220   2982368   1% /tmp
tmpfs             596516        24    596492   1% /run/user/1001
/dev/sda4      354528216 350712252   3815964  99% /mnt

マウントされた出力:

proc on /proc type proc (rw,nosuid,nodev,noexec,relatime)
sys on /sys type sysfs (rw,nosuid,nodev,noexec,relatime)
dev on /dev type devtmpfs (rw,nosuid,relatime,size=2973860k,nr_inodes=743465,mode=755)
run on /run type tmpfs (rw,nosuid,nodev,relatime,mode=755)
/dev/sda6 on / type ext4 (rw,relatime)
securityfs on /sys/kernel/security type securityfs (rw,nosuid,nodev,noexec,relatime)
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev)
devpts on /dev/pts type devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=000)
tmpfs on /sys/fs/cgroup type tmpfs (ro,nosuid,nodev,noexec,mode=755)
cgroup2 on /sys/fs/cgroup/unified type cgroup2 (rw,nosuid,nodev,noexec,relatime,nsdelegate)
cgroup on /sys/fs/cgroup/systemd type cgroup (rw,nosuid,nodev,noexec,relatime,xattr,name=systemd)
pstore on /sys/fs/pstore type pstore (rw,nosuid,nodev,noexec,relatime)
bpf on /sys/fs/bpf type bpf (rw,nosuid,nodev,noexec,relatime,mode=700)
cgroup on /sys/fs/cgroup/perf_event type cgroup (rw,nosuid,nodev,noexec,relatime,perf_event)
cgroup on /sys/fs/cgroup/net_cls,net_prio type cgroup (rw,nosuid,nodev,noexec,relatime,net_cls,net_prio)
cgroup on /sys/fs/cgroup/rdma type cgroup (rw,nosuid,nodev,noexec,relatime,rdma)
cgroup on /sys/fs/cgroup/cpu,cpuacct type cgroup (rw,nosuid,nodev,noexec,relatime,cpu,cpuacct)
cgroup on /sys/fs/cgroup/devices type cgroup (rw,nosuid,nodev,noexec,relatime,devices)
cgroup on /sys/fs/cgroup/pids type cgroup (rw,nosuid,nodev,noexec,relatime,pids)
cgroup on /sys/fs/cgroup/blkio type cgroup (rw,nosuid,nodev,noexec,relatime,blkio)
cgroup on /sys/fs/cgroup/freezer type cgroup (rw,nosuid,nodev,noexec,relatime,freezer)
cgroup on /sys/fs/cgroup/memory type cgroup (rw,nosuid,nodev,noexec,relatime,memory)
cgroup on /sys/fs/cgroup/cpuset type cgroup (rw,nosuid,nodev,noexec,relatime,cpuset)
cgroup on /sys/fs/cgroup/hugetlb type cgroup (rw,nosuid,nodev,noexec,relatime,hugetlb)
tmpfs on /tmp type tmpfs (rw,nosuid,nodev)
debugfs on /sys/kernel/debug type debugfs (rw,nosuid,nodev,noexec,relatime)
systemd-1 on /proc/sys/fs/binfmt_misc type autofs (rw,relatime,fd=29,pgrp=1,timeout=0,minproto=5,maxproto=5,direct,pipe_ino=13513)
mqueue on /dev/mqueue type mqueue (rw,nosuid,nodev,noexec,relatime)
hugetlbfs on /dev/hugepages type hugetlbfs (rw,relatime,pagesize=2M)
configfs on /sys/kernel/config type configfs (rw,nosuid,nodev,noexec,relatime)
tmpfs on /run/user/1001 type tmpfs (rw,nosuid,nodev,relatime,size=596516k,mode=700,uid=1001,gid=1001)
/dev/sda4 on /mnt type ntfs (rw,relatime,uid=0,gid=0,fmask=0177,dmask=077,nls=utf8,errors=continue,mft_zone_multiplier=1)

答え1

/etc/rc.localにchmodコマンドを追加して、起動時にchmodコマンドを自動化してみてください。

または:

/etc/systemd/system/ ディレクトリに SYSTEMD UNIT FILE を作成してみてください。たとえば、addpermission.service と呼ばれます。

ここに次のスクリプトを追加してください。

[Unit]
Description=Adding permissions to users


[Service]
ExecStart=/usr/bin/bash -c 'sudo chmod -R 775 /mnt'

[Install]
WantedBy=multi-user.target 

次に、次のスクリプトを実行して有効にします。 systemctl enable addpermission.service

正常に動作するかどうかをテストするには、/mntディレクトリが追加された場合は、そのディレクトリに対する権限を削除し、ユニットファイルを起動してステータスを確認してください。

systemctl start addpermission.service 
systemctl status addpermission.service 

状態が正常な場合。 /mnt ディレクトリに対する権限を確認してください。変更された場合は、再起動して再確認してください。変更がない場合は、エラーを確認し、ExecStart でコマンドを編集して修正します。結局は効果がありました。

答え2

最近、いくつかのサーバーでこの問題を確認し、最後にACLを削除して問題を解決しました。

したがって、既存のACL設定があるかどうかを確認することをお勧めします。

getfaclを使用してACL権限があることを確認し、それを削除すると、問題は永久に解決されます。

関連情報