Golangは、複数のプロセスの繰り返しを防ぎます

ロックファイルを作成します。

lockFile := "./lock.pid"
lock, err := os.Create(lockFile)
if err != nil {
    log.Fatal("创建文件锁失败", err)
}
defer os.Remove(lockFile)
defer lock.Close()

lockFileカスタム変数の値は、ロックファイルを読み取り、ファイルを閉じ行う主な機能の完了後に除去する必要があります。

ロックファイル

err = syscall.Flock(int(lock.Fd()), syscall.LOCK_EX|syscall.LOCK_NB)
if err != nil {
    log.Println("上一个任务未执行完成,暂停执行")
    os.Exit(1)
}

syscall.LOCK_EX排他ロックは、他の人が読み書きすることはできません。syscall.LOCK_NB操作をブロックすることはできませんファイルがロックされないことを意味し、すぐにプロセスに戻りました。lock.Fd()ファイル記述子を返し、ファイルディスクリプタは、現在のプロセスのオープンファイルテーブルレコードを指し示す指標値です。最後に、完成した後、ファイルのロックを解除。

defer syscall.Flock(int(lock.Fd()), syscall.LOCK_UN)

おすすめ

転載: www.cnblogs.com/enochzzg/p/11418527.html