婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 使用nginx實現(xiàn)分布式限流的方法

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

熱門標簽:威海人工智能電銷機器人系統(tǒng) 福州外呼系統(tǒng)中間件 上海電銷卡外呼系統(tǒng)廠家 貴州全自動外呼系統(tǒng)廠家 百度地圖標注備注 機器人電銷有什么用 好看的地圖標注圖標下載 地圖標注員怎么去做 德州外呼系統(tǒng)排名

1.前言

一般對外暴露的系統(tǒng),在促銷或者黑客攻擊時會涌來大量的請求,為了保護系統(tǒng)不被瞬間到來的高并發(fā)流量給打垮, 就需要限流 .

本文主要闡述如何用nginx 來實現(xiàn)限流. 聽說 Hystrix 也可以, 各位有興趣可以去研究哈 .

2.首先部署一個對外暴露接口的程序

我這里部署的是一個spring boot 項目 里面暴露了如下接口, 很簡單

暴露了一個 get 請求返回 hello world 的restful 接口.

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

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

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

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

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

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

第一行:

limit_req_zone : 是限流聲明.

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

zone=perip: 表示 用 perip 這個 名稱 來標識 這行限流配置, 待會 會通過 perip 這個名稱來引用這行限流配置(也就是說限流配置是可以定義為多個的)

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

rate=1r/s: 表示頻率是 一秒一個請求.

第二行:

表示在 myserver 這個集群上, 使用 名稱為 perip 的限流配置

4.用docker 部署 nginx

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

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

用代碼訪問 第一步定義的 helloworld 接口

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

如果改哈代碼, 改為一秒執(zhí)行一次get 請求, 就不會報錯, 各位可以去試一下

總結(jié)

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

標簽:白城 撫州 葫蘆島 南陽 邵陽 南陽 泉州 岳陽

巨人網(wǎng)絡(luò)通訊聲明:本文標題《使用nginx實現(xiàn)分布式限流的方法》,本文關(guān)鍵詞  使用,nginx,實現(xiàn),分布式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用nginx實現(xiàn)分布式限流的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用nginx實現(xiàn)分布式限流的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 闽清县| 九龙坡区| 梁平县| 卢湾区| 山东省| 竹山县| 西盟| 神木县| 平陆县| 安化县| 洛扎县| 旺苍县| 百色市| 云浮市| 德阳市| 宁阳县| 梓潼县| 柘荣县| 城固县| 耒阳市| 泰安市| 浦北县| 泾源县| 贞丰县| 乐清市| 东宁县| 永安市| 建昌县| 漳浦县| 东阳市| 浦城县| 军事| 西昌市| 通城县| 漳州市| 宣恩县| 二连浩特市| 北票市| 寿光市| 封丘县| 兰溪市|