• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

go-redis分布式锁

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

package main

import (
	"fmt"
	"log"
	"sync"
	"time"

	"github.com/go-redis/redis"
)

// 声明一个全局的rdb变量
var rdb *redis.Client
var mutex sync.Mutex

// 初始化连接
func initClient() (err error) {
	rdb = redis.NewClient(&redis.Options{
		Addr:     "ip:port",
		Password: "",
		DB:       7,
	})

	_, err = rdb.Ping().Result()
	if err != nil {
		return err
	}
	return nil
}

// 加锁
func Lock(key string) bool {
	// ex:设置默认过期时间10秒,防止死锁
	ex:=10*time.Second
	mutex.Lock()
	defer mutex.Unlock()
	bool,err := rdb.SetNX(key, `{"lock":1}`, ex).Result()
	if err != nil {
		return bool
	}
	return bool
}

// 解锁
func UnLock(key string) int64 {
	nums, err := rdb.Del(key).Result()
	if err != nil {
		log.Println(err.Error())
		return 0
	}
	return nums
}

func main() {
	err := initClient()
	if err != nil {
		fmt.Println(err)
	}

	b := Lock("lock")
	if b == true{
		// 抢锁成功
		
		执行自己的逻辑
		
		nums:=UnLock("lock")
		if nums == 1{
			// 释放锁成功
		}
	}else {
		// 抢锁失败
	}
}


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Go之讲解GOROOT、GOPATH、GOBINGo语言之讲解GOROOT、GOPATH、GOBIN发布时间:2022-07-10
下一篇:
go语言之进阶篇正则表达式发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap