GNU/Linux >> Znalost Linux >  >> Linux

Jak identifikovat uživatele, který maže soubory z daného adresáře v Linuxu

Otázka

Jak zjistit, který uživatel odstraňuje soubory v konkrétním adresáři v systému Linux?

Řešení

Službu auditd můžete použít k zaznamenání upozornění, když je v určitém souboru nebo adresáři provedena jakákoli změna. Níže je uveden příklad, který zaznamená všechny změny provedené v libovolném souboru v adresáři /tmp/dir.

1. Spuštěním níže uvedeného příkazu přidejte pravidlo auditu:

# auditctl -a always,exit -F dir=/tmp/dir/ -F perm=war -k file_del

Ověřte nakonfigurovaná pravidla auditu:

# auditctl -l
-w /tmp/dir// -p rwa -k file_del

2. Smažte soubor v adresáři /tmp/dir/ a poté zkontrolujte soubor audit.log:

$ date > /tmp/dir/when
$ rm /tmp/dir/when

3. Audit.log můžete zkontrolovat tak, že jej ohraničíte:

# tail -f /var/log/audit/audit.log
...
type=SYSCALL msg=audit(1515697690.586:2237): arch=c000003e syscall=2 success=yes exit=3 a0=251a9f0 a1=90800 a2=251a9c0 a3=a items=1 ppid=12424 pid=12425 auid=0 uid=501 gid=501 euid=501 suid=501 fsuid=501 egid=501 sgid=501 fsgid=501 tty=pts0 ses=332 comm="bash" exe="/bin/bash" key="file_del"
type=CWD msg=audit(1515697690.586:2237): cwd="/home/test"
type=PATH msg=audit(1515697690.586:2237): item=0 name="/tmp/dir/" inode=912888 dev=f9:00 mode=040777 ouid=0 ogid=0 rdev=00:00 nametype=NORMAL
type=PROCTITLE msg=audit(1515697690.586:2237): proctitle="-bash"
type=SYSCALL msg=audit(1515697690.861:2238): arch=c000003e syscall=263 success=yes exit=0 a0=ffffffffffffff9c a1=f2f0c0 a2=0 a3=100 items=2 ppid=12425 pid=12519 auid=0 uid=501 gid=501 euid=501 suid=501 fsuid=501 egid=501 sgid=501 fsgid=501 tty=pts0 ses=332 comm="rm" exe="/bin/rm" key="file_del"
type=CWD msg=audit(1515697690.861:2238): cwd="/home/test"
type=PATH msg=audit(1515697690.861:2238): item=0 name="/tmp/dir/" inode=912888 dev=f9:00 mode=040777 ouid=0 ogid=0 rdev=00:00 nametype=PARENT
type=PATH msg=audit(1515697690.861:2238): item=1 name="/tmp/dir/when" inode=913056 dev=f9:00 mode=0100664 ouid=501 ogid=501 rdev=00:00 nametype=DELETE
type=PROCTITLE msg=audit(1515697690.861:2238): proctitle=726D002F746D702F6469722F31

4. Alternativně lze soubor protokolu prohledávat pomocí nástroje ausearch:

# ausearch -k file_del
----
time->Thu Jan 11 19:08:10 2018
type=PROCTITLE msg=audit(1515697690.586:2237): proctitle="-bash"
type=PATH msg=audit(1515697690.586:2237): item=0 name="/tmp/dir/" inode=912888 dev=f9:00 mode=040777 ouid=0 ogid=0 rdev=00:00 nametype=NORMAL
type=CWD msg=audit(1515697690.586:2237): cwd="/home/test"
type=SYSCALL msg=audit(1515697690.586:2237): arch=c000003e syscall=2 success=yes exit=3 a0=251a9f0 a1=90800 a2=251a9c0 a3=a items=1 ppid=12424 pid=12425 auid=0 uid=501 gid=501 euid=501 suid=501 fsuid=501 egid=501 sgid=501 fsgid=501 tty=pts0 ses=332 comm="bash" exe="/bin/bash" key="file_del"
----
time->Thu Jan 11 19:08:10 2018
type=PROCTITLE msg=audit(1515697690.861:2238): proctitle=726D002F746D702F6469722F31
type=PATH msg=audit(1515697690.861:2238): item=1 name="/tmp/dir/when" inode=913056 dev=f9:00 mode=0100664 ouid=501 ogid=501 rdev=00:00 nametype=DELETE
type=PATH msg=audit(1515697690.861:2238): item=0 name="/tmp/dir/" inode=912888 dev=f9:00 mode=040777 ouid=0 ogid=0 rdev=00:00 nametype=PARENT
type=CWD msg=audit(1515697690.861:2238): cwd="/home/test"
type=SYSCALL msg=audit(1515697690.861:2238): arch=c000003e syscall=263 success=yes exit=0 a0=ffffffffffffff9c a1=f2f0c0 a2=0 a3=100 items=2 ppid=12425 pid=12519 auid=0 uid=501 gid=501 euid=501 suid=501 fsuid=501 egid=501 sgid=501 fsgid=501 tty=pts0 ses=332 comm="rm" exe="/bin/rm" key="file_del"
Poznámka :Tento systém auditu nemůže zabránit nežádoucímu přístupu. Lze provést pouze záznam auditní stopy.Auditování úprav a spouštění souborů v systému Linux


Linux
  1. Jak přidat nebo odebrat uživatele ze skupiny v Linuxu

  2. Jak najít a zkopírovat určitý typ souborů z jednoho adresáře do druhého v Linuxu

  3. Jak vytvořit video ze souborů PDF v Linuxu

  1. Jak extrahovat soubory Tar do konkrétního nebo jiného adresáře v Linuxu

  2. linux:jak spustit příkaz v daném adresáři

  3. Jak mohu vypsat uživatelské atributy Active Directory z počítače s Linuxem?

  1. Jak odstranit uživatelské účty pomocí domovského adresáře v systému Linux

  2. Jak spravovat uživatele pomocí useradd v linuxu

  3. Jak odebrat uživatele ze skupiny v Linuxu [Rychlý tip]