golang.org/x/time/rate 提对速度进行限制的算法
l := rate.NewLimiter(1, 3) // 一个参数为每秒发生多少次事件,第二个参数是最大可运行多少个事件(burst)
Limter提供三中主要的函数 Allow, Reserve, Wait. 大部分时候使用Wait
Wait/WaitN 当没有可用事件时,将阻塞等待
1
2
3
4
5
|
c, _ := context.WithCancel(context.TODO()) for { l.Wait(c) fmt.Println(time.Now().Format("04:05.000")) } |
输出
1
2
3
4
5
6
|
07:35.055 07:35.055 07:35.055 07:36.060 07:37.059 07:38.059 |
缓存3次后,每秒执行一次
1
2
3
4
5
6
7
8
9
10
|
Allow/AllowN 当没有可用事件时,返回false for { if (l.AllowN(time.Now(), 1)) { fmt.Println(time.Now().Format("04:05.000")) } else { time.Sleep(1 * time.Second / 10) fmt.Println(time.Now().Format("Second 04:05.000")) } } |
Reserve/ReserveN 当没有可用事件时,返回 Reservation,和要等待多久才能获得足够的事件
1
2
3
4
5
6
7
|
for { r := l.ReserveN(time.Now(), 1) s := r.Delay() time.Sleep(s) fmt.Println(s, time.Now().Format("04:05.000")) } |
补充:关于golang.org/x包问题
由于谷歌被墙,跟谷歌相关的模块无法通过go get来下载
解决方法:
git clone https://github.com/golang/net.git $GOPATH/src/github.com/golang/net
git clone https://github.com/golang/sys.git $GOPATH/src/github.com/golang/sys
git clone https://github.com/golang/tools.git $GOPATH/src/github.com/golang/tools
ln -s $GOPATH/src/github.com/golang $GOPATH/src/golang.org/x
如果是Windows下,最后一条可以替换为mklink命令,或者直接拷贝文件夹修改一下名称即可。
go的官方包都在这个目录下:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/u010066807/article/details/79961957