一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

云服務(wù)器|WEB服務(wù)器|FTP服務(wù)器|郵件服務(wù)器|虛擬主機(jī)|服務(wù)器安全|DNS服務(wù)器|服務(wù)器知識(shí)|Nginx|IIS|Tomcat|

服務(wù)器之家 - 服務(wù)器技術(shù) - Nginx - 使用nginx實(shí)現(xiàn)分布式限流的方法

使用nginx實(shí)現(xiàn)分布式限流的方法

2019-12-19 13:48爛豬皮 Nginx

一般對(duì)外暴露的系統(tǒng),在促銷(xiāo)或者黑客攻擊時(shí)會(huì)涌來(lái)大量的請(qǐng)求,為了保護(hù)系統(tǒng)不被瞬間到來(lái)的高并發(fā)流量給打垮, 就需要限流。接下來(lái)通過(guò)本文給大家分享使用nginx實(shí)現(xiàn)分布式限流的方法,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧

1.前言

一般對(duì)外暴露的系統(tǒng),在促銷(xiāo)或者黑客攻擊時(shí)會(huì)涌來(lái)大量的請(qǐng)求,為了保護(hù)系統(tǒng)不被瞬間到來(lái)的高并發(fā)流量給打垮, 就需要限流 .

本文主要闡述如何用nginx 來(lái)實(shí)現(xiàn)限流. 聽(tīng)說(shuō) Hystrix 也可以, 各位有興趣可以去研究哈 .

2.首先部署一個(gè)對(duì)外暴露接口的程序

我這里部署的是一個(gè)spring boot 項(xiàng)目 里面暴露了如下接口, 很簡(jiǎn)單

使用nginx實(shí)現(xiàn)分布式限流的方法

暴露了一個(gè) get 請(qǐng)求返回 hello world 的restful 接口.

將此程序部署到 linux 服務(wù)器上. 部署步奏不再贅述, 自行百度 spring boot 部署 即可.

在此我向大家推薦一個(gè)架構(gòu)學(xué)習(xí)交流群。交流學(xué)習(xí)群號(hào):575745314 里面會(huì)分享一些資深架構(gòu)師錄制的視頻錄像:有Spring,MyBatis,Netty源碼分析,高并發(fā)、高性能、分布式、微服務(wù)架構(gòu)的原理,JVM性能優(yōu)化、分布式架構(gòu)等這些成為架構(gòu)師必備的知識(shí)體系。還能領(lǐng)取免費(fèi)的學(xué)習(xí)資源,目前受益良多

使用nginx實(shí)現(xiàn)分布式限流的方法

3.創(chuàng)建一個(gè)名稱(chēng)為 nginx.conf 的 nginx 配置文件

創(chuàng)建一個(gè) 名叫 nginx.conf 的配置文件, 完整內(nèi)容如下

使用nginx實(shí)現(xiàn)分布式限流的方法

配置文件中限流部分解釋:

如上, nginx 的限流配置 , 只有兩行代碼.

第一行:

使用nginx實(shí)現(xiàn)分布式限流的方法

limit_req_zone : 是限流聲明.

$binary_remote_addr: 表示根據(jù)客戶(hù)端 ip 來(lái) 限流, 比如 上面的限流配置 限制每個(gè)客戶(hù)端ip的請(qǐng)求頻率為一秒一次, 你如果耍流氓一秒兩次, 就會(huì)被限流 會(huì)返回一個(gè)http 503 錯(cuò)誤給你.

zone=perip: 表示 用 perip 這個(gè) 名稱(chēng) 來(lái)標(biāo)識(shí) 這行限流配置, 待會(huì) 會(huì)通過(guò) perip 這個(gè)名稱(chēng)來(lái)引用這行限流配置(也就是說(shuō)限流配置是可以定義為多個(gè)的)

10m: 表示存儲(chǔ)客戶(hù)端ip的空間為10MB, 1MB 大概存儲(chǔ)1萬(wàn)多ip , 10 MB 大概 10多萬(wàn)Ip , 參考解釋: http://www.ttlsa.com/nginx/ng... 在這篇文章中搜索 binary_remote_addr 即可定位相關(guān)解釋.

rate=1r/s: 表示頻率是 一秒一個(gè)請(qǐng)求.

第二行:

使用nginx實(shí)現(xiàn)分布式限流的方法

表示在 myserver 這個(gè)集群上, 使用 名稱(chēng)為 perip 的限流配置

4.用docker 部署 nginx

將上一步創(chuàng)建的 nginx.conf 配置文件, 拷貝到linux 目錄 , /root/nginx/ 下 (目錄可以任意), 然后 一個(gè)docker 命令部署好 nginx 環(huán)境

使用nginx實(shí)現(xiàn)分布式限流的方法

這里暴露的是 8080 端口, 通過(guò) 8080 端口可以訪(fǎng)問(wèn)到 nginx 配置中的負(fù)載均衡節(jié)點(diǎn), 即 192.168.10.253:8090 ip端口, 這個(gè) ip端口對(duì)應(yīng)的就是 , 第一步創(chuàng)建部署的 hello world 程序.

用代碼訪(fǎng)問(wèn) 第一步定義的 helloworld 接口

使用nginx實(shí)現(xiàn)分布式限流的方法

我這里是 一秒 執(zhí)行 10次 get 請(qǐng)求, 已經(jīng)大于了 nginx中配置的 rate=1r/s 一秒一次的請(qǐng)求, 所以會(huì)看到 503 報(bào)錯(cuò), 如下.

使用nginx實(shí)現(xiàn)分布式限流的方法

如果改哈代碼, 改為一秒執(zhí)行一次get 請(qǐng)求, 就不會(huì)報(bào)錯(cuò), 各位可以去試一下

總結(jié)

以上所述是小編給大家介紹的使用nginx實(shí)現(xiàn)分布式限流,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!

原文鏈接:https://my.oschina.net/u/3636867/blog/1817669

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 性导航h | 亚洲精品国产专区91在线 | 91一区二区在线观看精品 | 手机在线免费观看高清 | 窝窝色资源站 | 青青草精品在线观看 | 毛片视频在线免费观看 | 亚洲精品电影天堂网 | 色噜噜国产精品视频一区二区 | 国产aⅴ一区二区三区 | www.四虎网站| 日本三级在线观看免费 | 亚洲网视频 | 日本高清va不卡视频在线观看 | 精品国产自在现线拍400部 | 大吊操| 午夜福利试看120秒体验区 | 日本高清在线播放一区二区三区 | 99久热只有精品视频免费观看17 | 国产毛片一级aaaaa片 | 無码一区中文字幕少妇熟女H | 痴mu动漫成年动漫在线观看 | 含羞草传媒一天免费看下 | 放荡护士玩3p口述 | 久久综合给合久久狠狠狠… | 黄情视频| 日本久久热 | 国产乱妇无码大片在线观看 | 亚洲精品久久久成人 | 天作谜案免费完整版在线观看 | 久久久无码精品无码国产人妻丝瓜 | 猛男强攻变sao货 | 色综合久久中文字幕网 | 久久久久久久尹人综合网亚洲 | 鄂州一家三口完整版免费 | 久久99国产综合精品AV蜜桃 | 亚州在线视频 | 欧美一区二区三区免费看 | 4438全国最大成人网视频 | 国产免费好大好硬视频 | 久久综合中文字幕佐佐木希 |