Go防缓存击穿——singleflight

本文介绍了Go语言中如何使用singleflight来防止缓存击穿问题。通过一个简单的示例,展示了如何在并发环境中利用singleflight确保接口请求的幂等性,从而避免服务响应延迟或宕机。核心代码简洁明了,适合在幂等接口上应用。
摘要由CSDN通过智能技术生成

我们在开发时,有时会碰到一个接口的访问量突然上升,导致服务响应延迟或者宕机的情况。这时,除了利用缓存之外,也可以用到singlefilght来解决,下面是一个简单的示例

package main

import (
	"fmt"
	"sync"
	"sync/atomic"
	"time"

	"golang.org/x/sync/singleflight"
)

func main() {
   
	g := singleflight.Group{
   }

	wg := sync.WaitGroup{
   }

	for i := 0; i < 100; i++ {
   
		wg.Add(1)
		go func(j int) {
   
			defer wg.Done()
			val, err, shared := g.Do("a", a)
			
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值