OpenResty--搭建简单的CC防护

说明:写在前面,本防护思路为设定阈值和时间段,在记录每个IP访问+uri(可不加,因为考虑到了不同的接口访问次数也许会有不同)的次数,在单位时间段内超过所设定阈值返回403,并将其IP封禁一段时间。

用到的ngx_lua模块:

ngx.var
ngx.shared.DICT

先编写ngx.conf配置文件:

http{
    ....
    lua_shared_dict cc_dict 50m; #大小根据业务访问量来定
    ....
server{
    ....
    access_by_lua_file path/to/your/luacode/access.lua;
    ....
}
}

编写access.lua

local cc_dict=ngx.shared.cc_dict
local access_ip=ngx.var.remote_addr
local access_uri=ngx.var.uri
local policy_table={
    api_1={
        uri="/test1",
        threshold=20,
        period=2
    },
    api_2={
        uri="/test2",
        threshold=30,
        period=1
    },
    default={
        threshold=10,
        period=1
    }
}

--anti_CC module
local cc_policy_table=nil
for k,v in pairs(policy_table) do
    if v.uri==access_uri then
        cc_policy_table=v
        break
    end
end
if not cc_policy_table then
    cc_policy_table=policy_table["default"]
end
local threshold=cc_policy_table.threshold
local time_period=cc_policy_table.period
local forbidden_ip,status=cc_dict:get("forbidden ip"..access_ip)
if forbidden_ip==1 then
    ngx.exit(ngx.HTTP_FORBIDDEN)
end
local visit_num,status=cc_dict:get(access_ip)
if visit_num then
    if visit_num>=threshold then
        cc_dict:set("forbidden ip"..access_ip,1,10)
        ngx.exit(ngx.HTTP_FORBIDDEN)
    else
        cc_dict:incr(access_ip,1)
    end
else
    cc_dict:set(access_ip,1,time_period)
end
保存运行即可,可以用apache-jmter测试下是否有效。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误提示说明无法找到名为openresty-1.15.8.3.service的服务单元。这通常是因为服务单元的名称不正确或者未正确安装OpenResty导致的。 要解决这个问题,你可以尝试以下步骤: 1. 确认你的OpenResty版本是否正确安装。可以通过运行openresty -v命令来检查OpenResty的版本信息。 2. 确认你的服务单元名称是否正确。在错误提示中,服务单元名称是openresty-1.15.8.3.service。你可以使用systemctl命令来查看所有已安装的服务单元列表,并确认服务单元名称是否与之匹配。 示例命令:systemctl list-unit-files | grep openresty 如果服务单元名称不正确,你需要根据你的OpenResty版本和配置文件中的设置来确定正确的服务单元名称。 3. 如果你确认服务单元名称和OpenResty的安装正确,但仍然无法启动服务,可能是由于其他配置文件的问题。你可以检查OpenResty的配置文件,确保没有发生语法错误或者配置错误。 示例命令:openresty -t -c /path/to/config/file 如果配置文件中存在错误,你需要修改配置文件中的错误并重新加载OpenResty。 综上所述,要解决该错误,你可以检查OpenResty的安装情况、服务单元名称和配置文件的正确性,并根据需要做出相应的更改。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [高性能web平台【OpenResty入门与实战】](https://blog.csdn.net/qq_42588990/article/details/121787741)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值