Membaca Baris Terakhir Fail Besar Secara Bertambah dalam Go
Dalam senario ini, kami menyasarkan untuk membaca dua baris terakhir log besar fail tanpa memuatkannya ke dalam memori dan mengulangi proses ini setiap 10 saat.
Dalam coretan kod Go yang disediakan:
package main import ( "fmt" "time" "os" ) const MYFILE = "logfile.log" func main() { c := time.Tick(10 * time.Second) for now := range c { readFile(MYFILE) } } func readFile(fname string){ file, err:=os.Open(fname) if err!=nil{ panic(err) }
Kami boleh meningkatkan fungsinya untuk mencapai matlamat kami dengan memanfaatkan fail. Kaedah stat untuk menentukan saiz fail dan fail. Kaedah ReadAt untuk membaca data daripada ofset bait tertentu dalam fail.
import ( "fmt" "os" "time" ) const MYFILE = "logfile.log" func main() { c := time.Tick(10 * time.Second) for _ = range c { readFile(MYFILE) } } func readFile(fname string) { file, err := os.Open(fname) if err != nil { panic(err) } defer file.Close() // Determine the size of the file stat, statErr := file.Stat() if statErr != nil { panic(statErr) } fileSize := stat.Size() // Assuming you know the size of each line in bytes (e.g., 62) start := fileSize - (62 * 2) // Read the last two lines from the file buf := make([]byte, 62 * 2) _, err = file.ReadAt(buf, start) if err == nil { fmt.Printf("%s\n", buf) } }
Dengan menggunakan maklumat saiz fail dan bacaan ofset bait langsung, kami boleh membaca dengan cekap dua baris terakhir fail tanpa memuatkannya sepenuhnya ke dalam memori dan ulangi proses ini setiap 10 saat.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membaca Dua Baris Terakhir Fail Besar dalam Go Setiap 10 Saat dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!