内容简介:利用** 文章转自go语言中文文档如果想限制用户HTTP请求进行速率限制可以参考 https://github.com/didip/tollbooth 这个中间键
利用 go
channel
实现限流量控制,原理:设置一个缓冲通道,设置访问中间键,当用户请求连接时判断channel里面长度是不是大于设定的缓冲值,如果没有就存入一个值进入channel,如果大于缓冲值,channel自动阻塞。当用户请求结束的时候,取出channel里面的值。
** 文章转自 go 语言中文文档 http://www.topgoer.com **
如果想限制用户HTTP请求进行速率限制可以参考 https://github.com/didip/tollbooth 这个中间键
目录:
-videos
--ce.html
-limiter.go
-main.go
main.go文件代码:
package main import ( "log" "net/http" "text/template" "time" "github.com/julienschmidt/httprouter" ) type middleWareHandler struct { r *httprouter.Router l *ConnLimiter } //NewMiddleWareHandler ... func NewMiddleWareHandler(r *httprouter.Router, cc int) http.Handler { m := middleWareHandler{} m.r = r m.l = NewConnLimiter(cc) return m } func (m middleWareHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { if !m.l.GetConn() { defer func() { recover() }() log.Panicln("Too many requests") return } m.r.ServeHTTP(w, r) defer m.l.ReleaseConn() } //RegisterHandlers ... func RegisterHandlers() *httprouter.Router { router := httprouter.New() router.GET("/ce", ce) return router } func ce(w http.ResponseWriter, r *http.Request, p httprouter.Params) { //为了演示效果这块设置了等待 time.Sleep(time.Second * 100) t, _ := template.ParseFiles("./videos/ce.html") t.Execute(w, nil) } func main() { r := RegisterHandlers() //里面的参数2为设置的最大流量 mh := NewMiddleWareHandler(r, 2) http.ListenAndServe(":9000", mh) }
limiter.go文件代码
package main import ( "log" ) //ConnLimiter 定义一个结构体 type ConnLimiter struct { concurrentConn int bucket chan int } //NewConnLimiter ... func NewConnLimiter(cc int) *ConnLimiter { return &ConnLimiter{ concurrentConn: cc, bucket: make(chan int, cc), } } //GetConn 获取通道里面的值 func (cl *ConnLimiter) GetConn() bool { if len(cl.bucket) >= cl.concurrentConn { log.Printf("Reached the rate limitation.") return false } cl.bucket <- 1 return true } //ReleaseConn 释放通道里面的值 func (cl *ConnLimiter) ReleaseConn() { c := <-cl.bucket log.Printf("New connction coming: %d", c) }
videos/ce.html文件代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> 欢迎访问www.5lmh.com </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 科普:什么是上行流量什么是下行流量
- 混淆加密流量规避检测:黑客利用加密流量趋势明显
- 还为模拟流量测试发愁吗?!滴滴开源RDebug流量回放工具!
- 利用最新Flash漏洞,通过“流量宝”对流量从业者的攻击活动
- 亿级流量系统架构之如何设计承载百亿流量的高性能架构【石杉的架构笔记】
- Linux 查看网络流量
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Linux 系统编程(第二版)
Robert Love / 东南大学出版社 / 2014-1-1 / 78
如何编写那些直接依赖于Linux内核和核心系统库提供的服务的软件?通过《Linux系统编程(第2版)(影印版)》,Linux内核参与者RobertLove(洛夫)为你提供了Linux系统编程方面的教程,Linux系统调用的参考手册,以及对于如何编写更聪明和更快的代码的来自内部人士的建议。Love清晰地指出了POSIX标准函数和Linux特别提供服务之间的差异。通过关于多线程的新章节,这本修订和扩展......一起来看看 《Linux 系统编程(第二版)》 这本书的介绍吧!