题目一场景:某一高并发web服务器需限制IP的频繁访问,现模拟100个IP同时并发访问该服务器,每个IP需访问1000次。
题目一要求:每个IP三分钟内只能访问一次。
题目一内容:修改以下代码完成上述题目要求,要求能成功输出【success100】。
题目代码如下:
package mainimport ("fmt""time")type Ban struct {visitIPs map[string]time.Time}func NewBan() *Ban {return &Ban{visitIPs: make(map[string]time.Time),}}func (o *Ban) visit(ip string) bool {if _, ok := o.visitIPs[ip]; ok {return true}o.visitIPs[ip] = time.Now()return false}func main() {success := 0ban := NewBan()for i := 0; i < 1000; i++ {for j := 0; j < 100; j++ {go func() {ip := fmt.Sprintf("192.168.1.%d", j)if !ban.visit(ip) {success++}}()}}fmt.Println("success:", success)}
解析:上述问题主要考察的是并发情况下map的读写问题,上述案例代码中又存在for循环中启动goroutine时变量使用问题以及goroutine执行滞后问题。
我们首先要做的就是保证启动的goroutine能得到正常的参数,然后就是保证map的并发读写,左后保证三分钟之内只能访问一次。
多CPU核心下修改int的值极端情况下会存在不同步的情况,一次需要原子

最低0.47元/天 解锁文章
&spm=1001.2101.3001.5002&articleId=120511204&d=1&t=3&u=229e36a613754890a9b737dab7edf381)
1771





