承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

redis散布式锁的go-redis实现方法详解

管理员 2023-06-25 08:19:14 互联网圈 16 ℃ 0 评论 2127字 收藏

redis散布式锁的go-redis实现方法详解

在散布式的业务中 , 如果有的同享资源需要安全的被访问和处理 , 那就需要散布式锁

散布式锁的几个原则;

1.「锁的互斥性」:在散布式集群利用中,同享资源的锁在同一时间只能被一个对象获得。

2. 「可重入」:为了不死锁,这把锁是可以重入的,并且可以设置超时。

3. 「高效的加锁和解锁」:能够高效的加锁和解锁,获得锁和释放锁的性能也好。

4. 「阻塞、公平」:可以根据业务的需要,斟酌是使用阻塞、或者非阻塞,公平或者非公平的锁。

redis实现散布式锁主要靠setnx命令

1. 当key存在时失败 , 保证互斥性

2.设置了超时 , 避免死锁

3.利用mutex保证当前程序不存在并发冲突问题

package redis

import (
“context”
“github.com/go-redis/redis/v8”
“github.com/taoshihan1991/miaosha/setting”
“log”
“sync”
“time”
)

var rdb *redis.Client
var ctx = context.Background()
var mutex sync.Mutex

func NewRedis() {
rdb = redis.NewClient(&redis.Options{
Addr: setting.Redis.Ip + “:” + setting.Redis.Port,
Password: “”, // no password set
DB: 0, // use default DB
})
}
func Lock(key string) bool {
mutex.Lock()
defer mutex.Unlock()
bool, err := rdb.SetNX(ctx, key, 1, 10*time.Second).Result()
if err != nil {
log.Println(err.Error())
}
return bool
}
func UnLock(key string) int64 {
nums, err := rdb.Del(ctx, key).Result()
if err != nil {
log.Println(err.Error())
return 0
}
return nums
}

到此这篇关于redis散布式锁的go-redis实现方法的文章就介绍到这了,更多相关redis散布式锁内容请搜索之前的文章或继续浏览下面的相关文章希望大家以后多多支持!

文章来源:丸子建站

文章标题:redis散布式锁的go-redis实现方法详解

https://www.wanzijz.com/view/59011.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信