mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
41 lines
1.2 KiB
Markdown
41 lines
1.2 KiB
Markdown
![]() |
# flock
|
||
|
[data:image/s3,"s3://crabby-images/8b1fc/8b1fc427b5970cb37e018e4a1f0e7caa56816682" alt="TravisCI Build Status"](https://travis-ci.org/gofrs/flock)
|
||
|
[data:image/s3,"s3://crabby-images/e9699/e96993b5123046f033910eeb4d614411488f97bb" alt="GoDoc"](https://godoc.org/github.com/gofrs/flock)
|
||
|
[data:image/s3,"s3://crabby-images/b1bd7/b1bd7d8c10f8e6a517ae4fb4a1b576123b04907a" alt="License"](https://github.com/gofrs/flock/blob/master/LICENSE)
|
||
|
|
||
|
`flock` implements a thread-safe sync.Locker interface for file locking. It also
|
||
|
includes a non-blocking TryLock() function to allow locking without blocking execution.
|
||
|
|
||
|
## License
|
||
|
`flock` is released under the BSD 3-Clause License. See the `LICENSE` file for more details.
|
||
|
|
||
|
## Go Compatibility
|
||
|
This package makes use of the `context` package that was introduced in Go 1.7. As such, this
|
||
|
package has an implicit dependency on Go 1.7+.
|
||
|
|
||
|
## Installation
|
||
|
```
|
||
|
go get -u github.com/gofrs/flock
|
||
|
```
|
||
|
|
||
|
## Usage
|
||
|
```Go
|
||
|
import "github.com/gofrs/flock"
|
||
|
|
||
|
fileLock := flock.New("/var/lock/go-lock.lock")
|
||
|
|
||
|
locked, err := fileLock.TryLock()
|
||
|
|
||
|
if err != nil {
|
||
|
// handle locking error
|
||
|
}
|
||
|
|
||
|
if locked {
|
||
|
// do work
|
||
|
fileLock.Unlock()
|
||
|
}
|
||
|
```
|
||
|
|
||
|
For more detailed usage information take a look at the package API docs on
|
||
|
[GoDoc](https://godoc.org/github.com/gofrs/flock).
|