https://gocn.vip/article/995

GO实现文件夹监控

收获

  • 查看 watcher.go, 看出实现一个系统event的监控,代码不过 625行;
  • 执行exec.Cmd(), cmd.Run(), 可以获得shell的执行状态;
  • 开始阅读github上的开源代码, 代码特别精简;

说明

项目组有一个需求,即当团队人员更新Gitbook到服务器的时候,服务器的gitbook目录下需要pull操作;

通过了解,当成员提交push内容到服务器的时候, git/objects目录下内容会create, modify, access等事件;

前期通过shell+inotifywait实现,但是总存在push的时候获取不到,或者上push之后频繁更新gitbook;

本次使用 github.com/radovskyb/watcher 来使用;

其中在本地执行如下命令, 获取watcher的库;

  1. go get github.com/radovskyb/watcher

通过范例,结合自己的脚本 pull.book.sh; 完成git book的操作;

  1. package main
  2. import (
  3. "fmt"
  4. "log"
  5. "os/exec"
  6. "time"
  7. "github.com/radovskyb/watcher"
  8. )
  9. func main() {
  10. w := watcher.New()
  11. // SetMaxEvents to 1 to allow at most 1 event's to be received
  12. // on the Event channel per watching cycle.
  13. //
  14. // If SetMaxEvents is not set, the default is to send all events.
  15. w.SetMaxEvents(1)
  16. // Only notify rename and move events.
  17. // w.FilterOps(watcher.Rename, watcher.Move)
  18. w.FilterOps(watcher.Create, watcher.Write, watcher.Chmod)
  19. go func() {
  20. for {
  21. select {
  22. case event := <-w.Event:
  23. fmt.Println(event) // Print the event's info.
  24. c := "pull.book.sh"
  25. cmd := exec.Command(c, "")
  26. err := cmd.Run()
  27. fmt.Printf("Command finished with error: %v\n", err)
  28. case err := <-w.Error:
  29. log.Fatalln(err)
  30. case <-w.Closed:
  31. return
  32. }
  33. }
  34. }()
  35. // Watch this folder for changes.
  36. if err := w.Add("/srv/git/objects"); err != nil {
  37. log.Fatalln(err)
  38. }
  39. // Watch test_folder recursively for changes.
  40. if err := w.AddRecursive("/srv/git/objects"); err != nil {
  41. log.Fatalln(err)
  42. }
  43. /*
  44. // Print a list of all of the files and folders currently
  45. // being watched and their paths.
  46. for path, f := range w.WatchedFiles() {
  47. fmt.Printf("%s: %s\n", path, f.Name())
  48. }
  49. fmt.Println()
  50. */
  51. // Trigger 2 events after watcher started.
  52. go func() {
  53. w.Wait()
  54. w.TriggerEvent(watcher.Create, nil)
  55. w.TriggerEvent(watcher.Write, nil)
  56. w.TriggerEvent(watcher.Chmod, nil)
  57. }()
  58. // Start the watching process - it'll check for changes every 100ms.
  59. if err := w.Start(time.Millisecond * 100); err != nil {
  60. log.Fatalln(err)
  61. }
  62. }
ft_authoradmin  ft_create_time2018-09-27 10:28
 ft_update_time2018-09-27 10:29