代码拉取完成,页面将自动刷新
golang 基于 zk 的分布式锁实现方案
go get gitee.com/go-arch/golang-zk-distribution-lock
package demo
import (
lock "gitee.com/go-arch/zk-distribution-lock"
"github.com/samuel/go-zookeeper/zk"
"time"
"log"
)
//demo shows a demo function use specific lock name
func demo() {
conn,_,err := zk.Connect([]string{"127.0.0.1"}, time.Minute,zk.WithLogInfo(false))
if err != nil {
panic(err)
}
locker, err := lock.NewLocker(conn, lock.WithBasePath("/test/"))
if err != nil {
panic(err)
}
log.Println("try to get lock")
err = locker.Lock("lock")
if err != nil {
log.Println(err)
panic(err)
}
// do your codes
log.Println("thread get lock successful", locker.Name())
defer func() {
err = locker.Release()
}()
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。