Fail Log Ekor dalam Python: Pendekatan Moden
Pengenalan
Fail log ekor ialah tugas biasa dalam pentadbiran sistem. Dalam Python, keupayaan untuk mengakses keluaran fail log dengan cara tidak menyekat amat berguna untuk pemantauan masa nyata dan analisis data.
Tailing Tanpa Sekat
Untuk tailing tidak menyekat, subproses dan modul terpilih boleh digabungkan. Pendekatan ini menggunakan proses anak untuk menjalankan perintah ekor, manakala proses utama meninjau output kanak-kanak untuk data baharu.
import time import subprocess import select f = subprocess.Popen(['tail', '-F', filename], stdout=subprocess.PIPE, stderr=subprocess.PIPE) p = select.poll() p.register(f.stdout) while True: if p.poll(1): print(f.stdout.readline()) time.sleep(1)
Dalam coretan kod ini, arahan ekor dijalankan tanpa menyekat, membenarkan yang utama proses untuk meneruskan pelaksanaan. Modul pilihan digunakan untuk meninjau paip output untuk data baharu, dan apabila data tersedia, ia dicetak.
Menyekat Tailing
Untuk menyekat tailing, subproses modul boleh digunakan tanpa modul pilihan. Pendekatan ini menyekat proses utama sehingga program ekor keluar atau dimatikan.
import subprocess f = subprocess.Popen(['tail', '-F', filename], stdout=subprocess.PIPE, stderr=subprocess.PIPE) while True: line = f.stdout.readline() print(line)
Dalam coretan kod ini, arahan ekor dijalankan menyekat, menghalang proses utama daripada melaksanakan sehingga program ekor selesai.
Kesimpulan
Pendekatan ini menyediakan pilihan berbeza untuk mengekori fail log dalam Python berdasarkan tingkah laku yang diingini. Pendekatan tidak menyekat sesuai untuk pemantauan masa nyata, manakala pendekatan menyekat boleh digunakan untuk senario yang lebih tradisional di mana proses utama menunggu program ekor selesai.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengekor Fail Log dengan Cekap dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!