这段代码是参照慕课网的视频教程,主要是f.Seek(0, os.SEEK_END)移动到末尾,但是里面有个小问题,当打开的文件被重新清空内容的清空下,就再也不能到读取数据了,比如在开启读取后 echo ''>1.log 这样就再也读不到了,tail包是解决了这个问题的
package main import ( "bufio" "fmt" "io" "os" "strings" "time" ) func main() { readChannel := make(chan string) go readFile(readChannel) for r := range readChannel { fmt.Println(r) } } func readFile(readChannel chan string) { f, err := os.Open("1.txt") if err != nil { panic(fmt.Sprintf("open file error:%s", err.Error())) } //移动到文件末尾 f.Seek(0, os.SEEK_END) reader := bufio.NewReader(f) for { line, err := reader.ReadBytes(' ') fmt.Println(err) if err == io.EOF { time.Sleep(time.Second) continue } else if err != nil { panic("ReadBytes error:" + err.Error()) } lineStr := strings.TrimSpace(string(line)) readChannel <- lineStr } }
使用tail包测试时,有re-open文件