我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么使用lua进行nginx redis访问控制

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么使用lua进行nginx redis访问控制

本篇内容介绍了“怎么使用lua进行nginx redis访问控制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

怎么使用lua进行nginx redis访问控制

1. 需求分析

\1. Nginx来处理访问控制的方法有多种,实现的效果也有多种,访问IP段,访问内容限制,访问频率限制等。

\2. 用Nginx+Lua+Redis来做访问限制主要是考虑到高并发环境下快速访问控制的需求。

\3. Nginx处理请求的过程一共划分为11个阶段,分别是:

post-read、server-rewrite、find-config、rewrite、post-rewrite、 preaccess、access、post-access、try-files、content、log.

在openresty中,可以找到:

set_by_lua,access_by_lua,content_by_lua,rewrite_by_lua等方法。

那么访问控制应该是,access阶段。

解决方案

按照正常的逻辑思维,我们会想到的访问控制方案如下:

检测是否被forbidden? =》是,forbidden是否到期:是,清除记录,返回200,正常访问;否,返回403; =》否,返回200,正常访问

每次访问,访问用户的访问频率+1处理

检测访问频率是否超过限制,超过即添加forbidden记录,返回403

这是简单地方案,还可以添加点枝枝叶叶,访问禁止时间通过算法导入,每次凹曲线增加。

实现方法

首先为nginx添加vhost配置文件,vhost.conf部分内容如下:

lua_package_path "/usr/local/openresty/lualib/?.lua;;";#告诉openresty库地址lua_package_cpath "/usr/local/openresty/lualib/?.so;;";error_log /usr/local/openresty/nginx/logs/openresty.debug.log debug;server {   listen 8080 default;   server_name www.ttlsa.com;       root  /www/openresty;   location /login {       default_type 'text/html';       access_by_lua_file "/usr/local/openresty/nginx/lua/access_by_redis.lua";#通过lua来处理访问控制   }}

Access_by_redis.lua

参考了下v2ex.com的做法,redis存储方案只做简单地string存储就足够了。key分别是:

用户登录记录:user:127.0.0.1:time(unix时间戳)

访问限制:block:127.0.0.1

先连接Redis吧:

local red = redis:new()function M:redis()red:set_timeout(1000)local ok, err = red:connect("127.0.0.1", 6379)if not ok then ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR)endend

按照我们的逻辑方案,第二步是,检测是否forbidden,下面我们就检测block:127.0.0.1,如果搜索到数据,检测时间是否过期,未过期返回403,否则直接返回200:

function M:check1()local time=os.time() --system timelocal res, err = red:get("block:"..ngx.var.remote_addr)if not res then -- redis error ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR) --redis get data error  endif type(res) == "string" then --if red not null then type(red)==string if tonumber(res) >= tonumber(time) then  --check if forbidden expired  ngx.exit(ngx.HTTP_FORBIDDEN)  --ngx.say("forbidden") endend}

接下来会做检测,是否访问频率过高,如果过高,要拉到黑名单的,

实现的方法是,检测user:127.0.0.1:time的值是否超标:

function M:check2()local time=os.time() --system timelocal res, err = red:get("user:"..ngx.var.remote_addr..":"..time)if not res then -- redis error ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR) --redis get data errorendif type(res) == "string" then if tonumber(res) >= 10 then -- attack, 10 times request/s  red:del("block:"..self.ip)  red:set("block:"..self.ip, tonumber(time)+5*60 ) --set block time  ngx.exit(ngx.HTTP_FORBIDDEN) endendend

最后呢,还要记得,把每次访问时间做一个自增长,user:127.0.0.1:time:

function M:add()local time=os.time() --system timeok, err = red:incr("user:"..ngx.var.remote_addr..":"..time)if not ok then ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR) --redis get data errorendend

那么,测试,强刷几次浏览器,发现过一会,返回了403,ok,搞定。

“怎么使用lua进行nginx redis访问控制”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么使用lua进行nginx redis访问控制

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么使用lua进行nginx redis访问控制

本篇内容介绍了“怎么使用lua进行nginx redis访问控制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 需求分析\1. Ngin
2023-06-27

怎么使用Nginx和Lua进行JWT校验

这篇文章将为大家详细讲解有关怎么使用Nginx和Lua进行JWT校验,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Lua脚本这里的secret我遇到了很大的坑。一开始直接从Java后端项目中复制了密钥出来
2023-06-22

Nagios如何进行用户权限管理和访问控制

Nagios是一个开源的监控系统,它提供了一套用户权限管理和访问控制功能,可以帮助管理员精细地控制用户对监控系统的访问权限。下面是Nagios进行用户权限管理和访问控制的一些常用方法:定义用户角色:在Nagios中,可以定义不同的用户角色,
Nagios如何进行用户权限管理和访问控制
2024-03-15

Windows中怎么使用VNC进行远程控制

在Windows中使用VNC进行远程控制,您需要按照以下步骤进行操作:下载和安装VNC服务器软件:您可以从RealVNC、TightVNC或UltraVNC等网站下载VNC服务器软件,并按照安装向导进行安装。配置VNC服务器:在安装完成后,
2023-10-25

Eclipse中怎么使用Git进行版本控制

在Eclipse中使用Git进行版本控制,需要先安装Git插件。下面是具体的步骤:安装Eclipse的EGit插件打开Eclipse,点击菜单栏的"Help" -> “Eclipse Marketplace”在搜索框中输入"EGit",找
Eclipse中怎么使用Git进行版本控制
2024-04-03

如何用访问代码进行产品描述的权限控制

在企业的日常管理中,处于权限管理需要,可能需要实行代码化的管理,即操作人员只需要按照产品编码进行收发作业,只有研发人员才可以看到其详细描述,比如很多化工食品行业,考虑到用料保密的需要,都会有这一管理需求。Sage X3访问代码可以实现这一
2023-06-05

使用Golang怎么模拟令牌桶进行访问

使用Golang怎么模拟令牌桶进行访问?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。golang的优点golang是一种编译语言,可以将代码编译为机器代码,编译后的二进制文件可
2023-06-14

Cacti系统如何进行用户权限管理和访问控制

Cacti系统提供了基本的用户权限管理和访问控制功能,可以通过以下步骤进行设置:创建用户:在Cacti系统中,管理员可以创建新用户账号,并为每个用户分配不同的权限和角色。分配角色:管理员可以为每个用户分配不同的角色,如管理员、操作员、普通用
Cacti系统如何进行用户权限管理和访问控制
2024-03-11

Vsftpd+tcp_wrappers怎么控制主机和用户访问

本篇内容主要讲解“Vsftpd+tcp_wrappers怎么控制主机和用户访问”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vsftpd+tcp_wrappers怎么控制主机和用户访问”吧!RH
2023-06-13

怎么在HTML5中使用DOM进行自定义控制

怎么在HTML5中使用DOM进行自定义控制?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。代码如下:
2023-06-09

Ubuntu怎么使用iptables控制来自某个国家的访问

这篇“Ubuntu怎么使用iptables控制来自某个国家的访问”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Ubuntu怎
2023-07-04

怎么用云服务器进行版本控制

使用云服务器进行版本控制可以按照以下步骤进行:1. 选择合适的云服务器提供商,注册账号并创建一个新的云服务器实例。2. 在云服务器上安装版本控制系统,比如Git。可以通过SSH登录到云服务器,然后使用包管理工具(比如apt-get或yum)
2023-09-27

怎么用云服务器进行版本控制

云服务器版本控制云服务器提供了一种方便且可扩展的方式来托管版本控制系统,例如Git。通过设置远程仓库、使用SSH密钥、推送和拉取代码,开发人员可以协作工作,追踪代码更改并回滚到以前的版本。云服务器版本的控制提供了集中存储、协作工作、历史记录跟踪、回滚选项和可扩展性等好处。
怎么用云服务器进行版本控制
2024-04-12

Ubuntu中怎么配置用户权限和访问控制

在Ubuntu中配置用户权限和访问控制可以通过以下几个步骤实现:创建用户:可以使用adduser命令创建新用户,例如sudo adduser newuser。分配用户到用户组:可以使用usermod命令将用户添加到指定的用户组,例如sud
Ubuntu中怎么配置用户权限和访问控制
2024-03-05

Teradata中怎么管理用户权限和访问控制

在Teradata中,用户权限和访问控制主要通过以下几种方式进行管理:创建和管理用户:管理员可以通过使用Teradata Administrator工具或者SQL语句来创建新用户,设置用户的登录名、密码、默认数据库等信息,并且可以随时修改或
Teradata中怎么管理用户权限和访问控制
2024-04-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录