etcd-lock
Import
# Master via standard import
get get github.com/Scalingo/go-etcd-lock
# Last stable is v0 via gopkg.in
go get gopkg.in/Scalingo/go-etcd-lock.v3vendor/github.com/Scalingo/go-etcd-lock/lock/lock
Example
l, err := lock.Acquire(client, "/name", 60)
if lockErr, ok := err.(*lock.Error); ok {
// Key already locked
fmt.Println(lockErr)
return
} else if err != nil {
// Communication with etcd has failed or other error
panic(err)
}
// It's ok, lock is granted for 60 secondes
// When the opration is done we release the lock
err = l.Release()
if err != nil {
// Something wrong can happen during release: connection problem with etcd
panic(err)
}
Testing
You need a etcd instance running on localhost:2379
, then:
go test ./...
Generate mock
From the /lock/
folder:
mockgen -destination lockmock/gomock_locker.go -package lockmock github.com/Scalingo/go-etcd-lock/lock Locker
mockgen -destination lockmock/gomock_lock.go -package lockmock github.com/Scalingo/go-etcd-lock/lock Lock