Jawaban:
Jika Anda perlu melihat lebih jauh dalam sejarah lebih dari satu bulan, Anda dapat membaca /var/log/wtmp.1
file dengan last
perintah.
last -f wtmp.1 john
akan menampilkan riwayat login untuk pengguna bulan sebelumnya john
.
Output log terakhir tidak terlalu berat dan relatif mudah diurai, jadi saya mungkin akan mem-pipe output ke grep untuk mencari pola tanggal tertentu.
last john | grep -E 'Aug (2[0-9]|30) '
untuk menunjukkan 20-30 Agustus. Atau sesuatu seperti:
last -f /var/log/wtmp.1 john | grep -E 'Jul (1[0-9]|2[0-9]|30) '
untuk memperoleh 10-30 Juli untuk pengguna john
.
Bagaimana cara mengekstrak riwayat login untuk rentang tanggal tertentu di Linux?
Contoh untuk mendaftar semua pengguna yang masuk dari 25 hingga 28 Agustus
last | while read line
do
date=`date -d "$(echo $line | awk '{ print $5" "$6" "$7 }')" +%s`
[[ $date -ge `date -d "Aug 25 00:00" +%s` && $date -le `date -d "Aug 28 00:00" +%s` ]] && echo $line
done
awk '{ print $5" "$6" "$7 }'
untuk mengekstrak waktu tanggal pada kolom yang sesuai dari last
output+%s
untuk mengubah datetime ke waktu Epoch-ge
berdiri lebih besar atau sama-le
berdiri kurang dari atau samaAnda juga dapat melakukannya untuk pengguna tertentu last <username>
.
last
output cukup mudah dibaca?
grep
mulai dari "15 Agustus 09:00" hingga "25 Agustus 21:00"?