Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Mengekor Fail Log dengan Cekap dalam Python?

Bagaimanakah Saya Boleh Mengekor Fail Log dengan Cekap dalam Python?

Linda Hamilton
Linda Hamiltonasal
2024-11-11 06:38:03284semak imbas

How Can I Efficiently Tail Log Files in Python?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn