ทำไมฉันไม่สามารถสร้างไฟล์ด้วยชื่อนำหน้าด้วย“ passwd” ใน“ / ฯลฯ ”?


9

ฉันมีพีซีที่ติดตั้ง Ubuntu 16.04 เมื่อเร็ว ๆ นี้ฉันต้องการติดตั้งแพคเกจบางอย่าง แต่มีปัญหาในการติดตั้ง หลังจากขุดบางฉันพบว่าความล้มเหลวดูเหมือนว่าจะเกี่ยวข้องกับระบบบัญชีผู้ใช้ linux ปัญหาคือไฟล์ที่มีชื่อนำหน้าด้วยpasswd.ไม่สามารถสร้างได้ใน/etcพา ธ

# ls /etc/passwd.*
ls: cannot access '/etc/passwd.*': No such file or directory

# touch /etc/passwd.test-test-test
touch: cannot touch '/etc/passwd.test-test-test': Permission denied

# ls /etc/passwe.*
ls: cannot access '/etc/passwe.*': No such file or directory

# touch /etc/passwe.test-test-test
#

ฉันสามารถสร้างไฟล์นั้นในเส้นทางอื่น ๆ เช่น/หรือ/usrแต่ไม่ได้อยู่ใน/etcและฉันสามารถสร้างไฟล์ที่มีชื่อไฟล์อื่น ๆ/etcแต่ไม่สามารถใช้กับชื่อไฟล์ที่ขึ้นpasswd.ต้นด้วย ฉันไม่สามารถทำซ้ำปัญหานี้กับพีซีเครื่องอื่น

ฉันได้ลองคำสั่งอื่น ๆ แล้ว:

  • nano /etc/shadow.xxx
  • echo xxx > /etc/shadow.xxx
  • touch /etc/test-temp-file && mv /etc/test-temp-file /etc/shadow.xxx
  • systemctl stop apparmor
  • รีบูทระบบ

ไม่มีอะไรทำงาน

สิ่งที่อาจทำให้เกิดปัญหานี้?

นี่คือเอาต์พุตคำสั่ง debug บางส่วน:

# ls -ld /etc
drwxr-xr-x 136 root root 12288 Aug 12 10:07 /etc

# lsattr -d /etc
----------I--e-- /etc

# ls -dZ /etc
? /etc

# type -a touch
touch is /usr/bin/touch
touch is /bin/touch

# file "$(command -v touch)"
/usr/bin/touch: symbolic link to /bin/touch

นี่คือstraceผลลัพธ์:

# strace touch /etc/passwd.test-test-test
execve("/usr/bin/touch", ["touch", "/etc/passwd.test-test-test"], [/* 22 vars */]) = 0
brk(NULL)                               = 0x8da000
access("/etc/ld.so.nohwcap", F_OK)      = -1 ENOENT (No such file or directory)
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY|O_CLOEXEC) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=80559, ...}) = 0
mmap(NULL, 80559, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7f9bc360e000
close(3)                                = 0
access("/etc/ld.so.nohwcap", F_OK)      = -1 ENOENT (No such file or directory)
open("/lib/x86_64-linux-gnu/libc.so.6", O_RDONLY|O_CLOEXEC) = 3
read(3, "\177ELF\2\1\1\3\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0P\t\2\0\0\0\0\0"..., 832) = 832
fstat(3, {st_mode=S_IFREG|0755, st_size=1868984, ...}) = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f9bc360d000
mmap(NULL, 3971488, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x7f9bc3033000
mprotect(0x7f9bc31f3000, 2097152, PROT_NONE) = 0
mmap(0x7f9bc33f3000, 24576, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x1c0000) = 0x7f9bc33f3000
mmap(0x7f9bc33f9000, 14752, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x7f9bc33f9000
close(3)                                = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f9bc360c000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f9bc360b000
arch_prctl(ARCH_SET_FS, 0x7f9bc360c700) = 0
mprotect(0x7f9bc33f3000, 16384, PROT_READ) = 0
mprotect(0x60e000, 4096, PROT_READ)     = 0
mprotect(0x7f9bc3622000, 4096, PROT_READ) = 0
munmap(0x7f9bc360e000, 80559)           = 0
brk(NULL)                               = 0x8da000
brk(0x8fb000)                           = 0x8fb000
open("/usr/lib/locale/locale-archive", O_RDONLY|O_CLOEXEC) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=1668976, ...}) = 0
mmap(NULL, 1668976, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7f9bc3473000
close(3)                                = 0
open("/etc/passwd.test-test-test", O_WRONLY|O_CREAT|O_NOCTTY|O_NONBLOCK, 0666) = -1 EACCES (Permission denied)
utimensat(AT_FDCWD, "/etc/passwd.test-test-test", NULL, 0) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/locale.alias", O_RDONLY|O_CLOEXEC) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=2995, ...}) = 0
read(3, "# Locale name alias data base.\n#"..., 4096) = 2995
read(3, "", 4096)                       = 0
close(3)                                = 0
open("/usr/share/locale/en_US.UTF-8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en_US.utf8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en_US/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en.UTF-8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en.utf8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en_US.UTF-8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en_US.utf8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en_US/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en.UTF-8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en.utf8/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en/LC_MESSAGES/coreutils.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
write(2, "touch: ", 7touch: )                  = 7
write(2, "cannot touch '/etc/passwd.test-t"..., 41cannot touch '/etc/passwd.test-test-test') = 41
open("/usr/share/locale/en_US.UTF-8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en_US.utf8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en_US/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en.UTF-8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en.utf8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale/en/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en_US.UTF-8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en_US.utf8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en_US/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en.UTF-8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en.utf8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
open("/usr/share/locale-langpack/en/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
write(2, ": Permission denied", 19: Permission denied)     = 19
write(2, "\n", 1
)                       = 1
close(1)                                = 0
close(2)                                = 0
exit_group(1)                           = ?
+++ exited with 1 +++

2
สิ่งที่ไม่ls -ld /etcพูด? แล้วไงlsattr -d /etcล่ะ หากคุณใช้ SELinux สิ่งที่จะls -dZ /etcพูด? หากคุณใช้ AppArmor คำสั่งเทียบเท่า (ฉันไม่รู้ว่ามันคืออะไร) พูดว่าอะไร? สิ่งนี้/etc/แตกต่างจาก/etcพีซีเครื่องอื่นอย่างไร เรียกใช้คำสั่งเดียวกันนั้นและค้นหาความแตกต่าง
NickD

คือtouchฟังก์ชั่นหรือสคริปต์หรืออะไร? รายงานtype -a touchและทำfile "$(command -v touch)"อะไร ฉันไม่สามารถทำซ้ำในกล่อง 16.04 ของฉัน
muru

@NickD ฉันได้เปรียบเทียบผลลัพธ์คำสั่งทั้งหมดยกเว้น AppArmor อันหนึ่งเพราะฉันไม่พบวิธีแสดงข้อมูลที่เกี่ยวข้องของโฟลเดอร์ ผลลัพธ์จะเหมือนกัน
EFanZh

1
เพื่อให้แน่ใจว่าคุณกำลังทำสิ่งนี้rootใช่ไหม
Panki

1
เห็นได้ชัดว่า Ubuntu ใช้ apparmor โปรดดู: help.ubuntu.com/community/AppArmor
Rafael Kitover

คำตอบ:


6

ฉันพบว่าทำไม เป็นเพราะ ISecTP (Endpoint Security สำหรับ Linux Threat Prevention) ได้รับการติดตั้งบนพีซีของฉัน ซึ่งจะรวมถึง " การป้องกันการเข้าถึง " ซึ่งใช้ทั้งอินเตอร์เฟซเคอร์เนล fanotify หรือฉีดโมดูลที่กำหนดเองใน kernel ( ที่กำหนดซึ่งของเหล่านี้มันไม่ ) เพื่อก่อให้เกิดการเข้าถึงเส้นทางที่กำหนดเองได้รับการปฏิเสธ ฉันไม่รู้เพราะฉันไม่ใช่คนเดียวที่ใช้พีซี หลังจากถอนการติดตั้งทุกอย่างเรียบร้อยดี

ขอบคุณทุกคนสำหรับความช่วยเหลือของคุณ!


น่าสนใจมากฉันไม่เคยได้ยินเรื่องซอฟต์แวร์เท่านี้เท่าที่ฉันรู้ว่าทุกคนกำลังใช้ selinux หรือ apparmor
Rafael Kitover

ขอขอบคุณที่แจ้งการอัปเดต เมื่อคุณทำได้โปรดยอมรับคำตอบของคุณเอง
roaima
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.