Golang与区块链

gobox中处理文件系统通知

2018-07-15  本文已影响3人  ligang1109

今天来说下使用gobox中inotify来处理文件系统通知

inotify介绍

inotify是linux系统的文件事件通知机制,例如我们想得知某个文件是否被改变,目录的读写情况等,都可以使用这个机制。

用法示例

package main

import (
    "github.com/goinbox/inotify"

    "fmt"
    "path/filepath"
)

func main() {
    path := "/tmp/a.log"

    watcher, _ := inotify.NewWatcher()
    watcher.AddWatch(path, inotify.IN_ALL_EVENTS)
    watcher.AddWatch(filepath.Dir(path), inotify.IN_ALL_EVENTS)

    for i := 0; i < 5; i++ {
        events, _ := watcher.ReadEvents()
        for _, event := range events {
            if watcher.IsUnreadEvent(event) {
                fmt.Println("it is a last remaining event")
            }
            showEvent(event)
        }
    }

    watcher.Free()
    fmt.Println("bye")
}

func showEvent(event *inotify.Event) {
    fmt.Println(event)

    if event.InIgnored() {
        fmt.Println("inotify.IN_IGNORED")
    }

    if event.InAttrib() {
        fmt.Println("inotify.IN_ATTRIB")
    }

    if event.InModify() {
        fmt.Println("inotify.IN_MODIFY")
    }

    if event.InMoveSelf() {
        fmt.Println("inotify.IN_MOVE_SELF")
    }

    if event.InMovedFrom() {
        fmt.Println("inotify.IN_MOVED_FROM")
    }

    if event.InMovedTo() {
        fmt.Println("inotify.IN_MOVED_TO")
    }

    if event.InDeleteSelf() {
        fmt.Println("inotify.IN_DELETE_SELF")
    }

    if event.InDelete() {
        fmt.Println("inotify.IN_DELETE")
    }

    if event.InCreate() {
        fmt.Println("inotify.IN_CREATE")
    }
}

如示例,我们监听了/tmp/a.log/tmp目录的文件系统事件。

执行程序,接下来我们做如下操作:

ligang@vm-xubuntu /tmp $ echo a > a.log
ligang@vm-xubuntu /tmp $ echo aa >> a.log
ligang@vm-xubuntu /tmp $ mv a.log b.log
ligang@vm-xubuntu /tmp $ rm b.log
rm: remove regular file 'b.log'? y

得到输出:

&{1 256 0 /tmp a.log}
inotify.IN_CREATE
&{1 32 0 /tmp a.log}
&{1 2 0 /tmp a.log}
inotify.IN_MODIFY
&{1 8 0 /tmp a.log}
&{1 32 0 /tmp a.log}
&{1 2 0 /tmp a.log}
inotify.IN_MODIFY
&{1 8 0 /tmp a.log}
&{1 64 1801 /tmp a.log}
inotify.IN_MOVED_FROM
&{1 128 1801 /tmp b.log}
inotify.IN_MOVED_TO
&{1 512 0 /tmp b.log}
inotify.IN_DELETE
bye

inotify对系统编程开发有着很大的意义, 如果对inotify不是很熟悉,我在这里推荐阅读Linux/UNIX系统编程手册:https://book.douban.com/subject/25809330/

欢迎大家使用,使用中有遇到问题随时反馈,我们会尽快响应,谢谢!

上一篇下一篇

猜你喜欢

热点阅读