百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

Nginx负载均衡的一些安全配置说明

ztj100 2025-03-26 19:21 30 浏览 0 评论

在之前的几篇文章里,我们都说到了负载均衡,而负载均衡的转发服务器使用了Nginx,但是我们没有详细的对Nginx的安全配置做一个分析,如果对负载均衡的知识比较有兴趣,欢迎订阅我的头条号:一点热,然后再阅读我之前的文章。

快速入口

java项目如何实现单一的nginx负载均衡

关于Nginx的一些安全设置,我在这里做个分析。

1、限制IP访问

有时,我们需要对网站的IP进行过滤,禁止其他外部的IP访问到我们的数据,只允许我们特定的IP访问,那么我们需要对服务器进行白名单配置。

我们如果对某个IP允许的话输入allow ip,如果是禁止的话deny ip;如果是禁止所以的就deny all;

location / {

allow 192.168.1.101;

deny 192.168.1.101;

deny all;

}

2、文件目录禁止访问限制。

有些文件或者目录,我们仅仅用于内部读取等用途,我们不希望被其它人访问到,那么我们需要对Nginx添加相应的限制,以防止用户访问到我们的网站。特别是我们tomcat的项目,我们如果使用Nginx进行转发的时候,我们需要对tomcat项目的配置文件进行禁止访问,否则,数据库的密码很容易泄露出去。

比、如我们要保护config目录下的所有文件,那么我们可以这样配置:

location ^~ /config/ {

deny all;

}

当然我们还可以限制IP访问到该目录

location ^~ /config/ {

allow 192.168.1.0/24;

deny all;

}

3、需要防止DOS攻击

在互联网中,我们经常会遇到不明的IP进行DOS攻击,那么我们需要对DOS攻击进行防护,对于怎么防止DOS攻击,我们可以从IP的请求数,在日常中,我们经常会遇到大量的攻击IP攻击我们的服务器,如果我们不加以对这些恶意的IP限制,那么我们的机器很容易会崩溃,同样我们也可以对我们的客户端的连接数进行限制,在实际操作,我们的开放平台,会经常遇到同一个客户端,每秒的请求数可能是1000,其实就是与我们的防止DOS攻击设计的原来一样。值得,我们注意的是,我们虽然做到了这个防止DOS攻击,但是同时,我们也大大限制了爬虫的访问,别的爬虫就无法多次连接我们的网站进行采集,那么可能出现的后果就是,如果百度谷歌的搜索引擎,要收集你的页面,那么会出现采集不到,同时也有可能降低你的网站的权重。所有这个要衡量一下,取一个适中的值。

在Nginx里面我们可以使用两个参数来设置IP请求数和连接数,它们分别是limit_zonelimit_conn

使用方法

limit_zone

限制某一段时间内同一ip访问数实例

用法:limit_zone zone_name $variable memory_max_size

limit_conn

说明:连接数限制

用法:limit_conn zone_name max_clients_per_ip

http{

#定义一个名为ming 的limit_req_zone用来存储session,大小是10M内存,

limit_zone ming $binary_remote_addr 10m;

#另外的设法如下:

#limit_req_zone $binary_remote_addr zone=ming2:10m rate=20r/s;

#以$binary_remote_addr 为key,限制平均每秒的请求为20个,rete的值必须为整数,

server {

location /yeehot/ {

limit_conn ming 3;#这将指定一个地址只能同时存在3个连接。

}

}

4、请求方法的限制

有时,我们可能有些请求方法我们是不需要用到的,而且不希望客户端通过碰撞的方式来攻击我们的网站,那么我们需要对某些方法禁止使用。

对于我们常用三种方法get \post这个我们是一般是开启的,而其他的我们可以把它不开启。在Nginx我们可以这样设计

location ~* /yeehot{

if ($request_method = PUT ) {

return 403;

}

if ($request_method = DELETE ) {

return 403;

}

}

5、限制文件上传的大小。

对于为什么需要我们文件上传大小进行限制,那是因为在互联网中,每个用户是无意识的上传文件的,那么对于他们来说,不知道存储设备的可贵,类似恶意的上传大文件攻击服务器,同时如果批量的上传一些木马上去的话,便导致我们的服务器安全性形成一个攻击的工具。就是我们经常听到的挂马。这个我们可以在后端服务器进行过滤。

location / {

proxy_pass http://loginserver;

client_max_body_size 20m;

}

今天的课程就讲到这里,下一节我们继续把Nginx的一些安全知识为大家讲一讲,欢迎订阅我的头条号,一点热,如果有问题欢迎留言咨询,欢迎转发与收藏,如果转载到其他地方,请与我联系。

相关推荐

30天学会Python编程:16. Python常用标准库使用教程

16.1collections模块16.1.1高级数据结构16.1.2示例...

强烈推荐!Python 这个宝藏库 re 正则匹配

Python的re模块(RegularExpression正则表达式)提供各种正则表达式的匹配操作。...

Python爬虫中正则表达式的用法,只讲如何应用,不讲原理

Python爬虫:正则的用法(非原理)。大家好,这节课给大家讲正则的实际用法,不讲原理,通俗易懂的讲如何用正则抓取内容。·导入re库,这里是需要从html这段字符串中提取出中间的那几个文字。实例一个对...

Python数据分析实战-正则提取文本的URL网址和邮箱(源码和效果)

实现功能:Python数据分析实战-利用正则表达式提取文本中的URL网址和邮箱...

python爬虫教程之爬取当当网 Top 500 本五星好评书籍

我们使用requests和re来写一个爬虫作为一个爱看书的你(说的跟真的似的)怎么能发现好书呢?所以我们爬取当当网的前500本好五星评书籍怎么样?ok接下来就是学习python的正确姿...

深入理解re模块:Python中的正则表达式神器解析

在Python中,"re"是一个强大的模块,用于处理正则表达式(regularexpressions)。正则表达式是一种强大的文本模式匹配工具,用于在字符串中查找、替换或提取特定模式...

如何使用正则表达式和 Python 匹配不以模式开头的字符串

需要在Python中使用正则表达式来匹配不以给定模式开头的字符串吗?如果是这样,你可以使用下面的语法来查找所有的字符串,除了那些不以https开始的字符串。r"^(?!https).*&...

先Mark后用!8分钟读懂 Python 性能优化

从本文总结了Python开发时,遇到的性能优化问题的定位和解决。概述:性能优化的原则——优化需要优化的部分。性能优化的一般步骤:首先,让你的程序跑起来结果一切正常。然后,运行这个结果正常的代码,看看它...

Python“三步”即可爬取,毋庸置疑

声明:本实例仅供学习,切忌遵守robots协议,请不要使用多线程等方式频繁访问网站。#第一步导入模块importreimportrequests#第二步获取你想爬取的网页地址,发送请求,获取网页内...

简单学Python——re库(正则表达式)2(split、findall、和sub)

1、split():分割字符串,返回列表语法:re.split('分隔符','目标字符串')例如:importrere.split(',','...

Lavazza拉瓦萨再度牵手上海大师赛

阅读此文前,麻烦您点击一下“关注”,方便您进行讨论和分享。Lavazza拉瓦萨再度牵手上海大师赛标题:2024上海大师赛:网球与咖啡的浪漫邂逅在2024年的上海劳力士大师赛上,拉瓦萨咖啡再次成为官...

ArkUI-X构建Android平台AAR及使用

本教程主要讲述如何利用ArkUI-XSDK完成AndroidAAR开发,实现基于ArkTS的声明式开发范式在android平台显示。包括:1.跨平台Library工程开发介绍...

Deepseek写歌详细教程(怎样用deepseek写歌功能)

以下为结合DeepSeek及相关工具实现AI写歌的详细教程,涵盖作词、作曲、演唱全流程:一、核心流程三步法1.AI生成歌词-打开DeepSeek(网页/APP/API),使用结构化提示词生成歌词:...

“AI说唱解说影视”走红,“零基础入行”靠谱吗?本报记者实测

“手里翻找冻鱼,精心的布局;老漠却不言语,脸上带笑意……”《狂飙》剧情被写成歌词,再配上“科目三”背景音乐的演唱,这段1分钟30秒的视频受到了无数网友的点赞。最近一段时间随着AI技术的发展,说唱解说影...

AI音乐制作神器揭秘!3款工具让你秒变高手

在音乐创作的领域里,每个人都有一颗想要成为大师的心。但是面对复杂的乐理知识和繁复的制作过程,许多人的热情被一点点消磨。...

取消回复欢迎 发表评论: