|
8 N0 q$ @$ M+ f& I
1. 介绍自从了解了error和access日志的重要性,并且学会阅读相关log文档之后通过调整nginx配置,解决error中的大量报错提示通过过滤js等静态资源减少大量的access日志记录内容同时,经过使用阿里云安全组封禁大量国外ip地址的访问。 , d( l- [) r' M2 F! w2 n
我的access.log文件和error.log的尺寸得到了有效压缩管理access.log 从原先的12m左右的的文件,变成了现在的400KB记录的访问数据也清晰了很多error.log也从原先的8M左右的文件,变成了现在的1KB,或者300Bytes的文件。
# E7 O4 j( R3 q6 y4 V 甚至有时候还是0 Bytes日志文件的减少,也降低了服务器的IO读取的性能开支可以将更多的内存资源用于处理正常的请求可以说是一个双赢的结局本篇作为一个回顾总结内容具体的error文件内容配置可以参考:https://zinyan.com/?p=450 ,https://zinyan.com/?p=453。
* T; I# L0 N% x access.log的文件配置可以参考:https://zinyan.com/?p=445,https://zinyan.com/?p=444,以及爬虫屏蔽过滤返回444:https://zinyan.com/?p=454。
9 a7 p( }2 g; @7 ^$ S 2. 总结现在error文件中,剩下的记录主要就是SSL: error:141CF06C:SSL routines:tls_parse_ctos_key_share:bad key share异常了处理这个异常,可以通过封禁ip地址的访问,也可以不用在意。
5 C( ~2 p& _* | 剩下的就是access.log文件了当我们配置UserAgent请求中带有爬虫关键字的请求直接返回444之后,例如:Status:444,Bytes:0,IP:185.117.225.171,Time:[ ! z6 |4 q# e, C1 \
2022-11-24T04:18:36+08:00],Host:"zinyan.com",Request:"GET /robots.txt HTTP/1.1",Referer:"-",UserAgent ; \/ r4 M7 ^8 g, s# w- V- ~) V i- r
:"python-requests/2.28.1"Status:444,Bytes:0,IP:51.77.247.119,Time:[2022-11-24T04:57:39+08:00],Host:"47.101.47.241" - {8 }3 D+ b' C" ]
,Request:"POST /phpinfo HTTP/1.1",Referer:"-",UserAgent:"curl/7.64.0"对比不同日期的access.log 可以发现,爬虫请的数量在不断变少。 * s$ W8 b p: m/ X3 I% Q. t& t
因为当爬虫多次请求得到结果是444后,会渐渐降低我们网站的爬取级别,最终犹豫得不到数据而放弃爬取但是,也会有一些新增加的爬虫需要我们注意,并添加到过滤条件中而且也有一些过滤无法生效的情况,需要我们随时进行一些配置的修改例如:。 5 k" g: z( ?- g0 N4 u# E( d5 w
Status:404,Bytes:177,IP:18.195.96.149,Time:[2022-11-24T04:58:10+08:00],Host:"zinyan.com",Request:"GET /s/.git/HEAD HTTP/1.1"
4 g) v% @9 L' _/ T$ D3 b- E/ _ ,Referer:"-",UserAgent:"RepoLookoutBot/1.0.0 (abuse reports to abuse@repo-lookout.org)"Status:404,Bytes
1 d& g! v+ u$ R5 ]% ` :186,IP:18.195.96.149,Time:[2022-11-24T04:58:42+08:00],Host:"zinyan.com",Request:"GET /categories/.git/HEAD HTTP/1.1" % f; p0 j* |/ v/ f8 t1 r
,Referer:"-",UserAgent:"RepoLookoutBot/1.0.0 (abuse reports to abuse@repo-lookout.org)"我们需要新增:RepoLookoutBot 爬虫工具的过滤。 5 R( K9 |4 D+ v$ F7 N7 z; ]
还有通过CensysInspect 工具:Status:400,Bytes:248,IP:167.248.133.62,Time:[2022-11-24T07:17:24+08:00],Host:"47.101.47.241:443"
$ t x; u2 u/ c2 p ,Request:"GET / HTTP/1.1",Referer:"-",UserAgent:"Mozilla/5.0 (compatible; CensysInspect/1.1; +https://about.censys.io/)" 2 [/ c: ]8 a8 J$ t. D
同时在屏蔽过程中出现了有些能够屏蔽而有些无法屏蔽的问题:Status:444,Bytes:0,IP:167.248.133.62,Time:[2022-11-24T07:17:20+08:00],Host
8 n' Z% v7 L1 C- D" u& v1 c :"47.101.47.241:443",Request:"GET / HTTP/1.1",Referer:"-",UserAgent:"-"Status:400,Bytes:248,IP:167.248 7 A1 P9 ~) @+ X. o+ n$ V
.133.62,Time:[2022-11-24T07:17:23+08:00],Host:"47.101.47.241:443",Request:"GET / HTTP/1.1",Referer:"-"
$ q0 [3 ^, M( Z, p& q% U# x- C7 X3 u ,UserAgent:"-"两种访问从access.log中看到,可以说完全一样但是却一个返回444,一个返回400 返回444说明我的nginx过滤规则生效了而400说明没有生效同时,还需要添加上Host为空的访问,将它们进行过滤,例如:。
) b1 d2 c. z' k j Status:400,Bytes:150,IP:167.248.133.62,Time:[2022-11-24T07:17:24+08:00],Host:"-",Request:"PRI * HTTP/2.0"
5 k6 z# W" `0 ]1 O# p ,Referer:"-",UserAgent:"-"同时,我们也可以检查静态资源是否全部都过滤的情况,例如我的资源用到了jfif,webp文件我就需要添加到过滤规则中去PS:可能存在部分的过滤失败,但是整体上来说。 3 g# o2 y6 i( a+ x( P7 P) F2 u3 _
提高了网站的安全性,降低了大量的非法请求在收获上来说,这一些配置的付出是值得的3. 改进 nginx过滤规则基于发现的问题,再次改进access的过滤规则以及非法请求返回444的判断逻辑3.1 修改access_log 记录。 ) I+ {0 P: P' L$ q' y, d7 X# ~
在/etc/nginx/nginx.conf文件中修改如下:
: Q/ Y* o1 X/ [4 D' } http {
4 Q9 p" S. o/ {4 n ... G* ~; j* Z% z% d5 c
log_format main Status status,Bytes body_bytes_sent,IP remote_addr,Time:[$time_iso8601],Host:"$http_host",Request:"$request",Referer:"$http_referer",UserAgent:"$http_user_agent"
1 o. [3 `5 @: k0 u$ P ;1 G D5 T! X( j/ H5 V6 P
map $uri $zinyanloggable {
; G" j |& d( D, L2 ^- j8 J; K default 1;
+ M( c% X9 I: E1 C ~^(.*\.(ico|gif|jpg|jpeg|png|bmp|swf|js| & W+ ^# U" k8 T$ f! r
css|svg|woff|ttf|jfif|webp)$) 0;
) X7 C! y8 L; p8 p }$ K, d! I6 S+ l. H! R$ [0 H
access_log /var/log/nginx/access.log main if=$zinyanloggable;9 H8 R% P9 ^! p7 Z! C
...- o9 z% _4 A0 `
} / u( [" h! J1 f3 O' {1 ^
这样,access文件中就不会添加ico|gif|jpg|jpeg|png|bmp|swf|js|css|svg|woff|ttf|jfif|webp 作为后缀结尾的日志内容了3.2 map实现爬虫屏蔽。
4 B% E: I" o( H* V9 H 老版本写法为: server{
- m4 z' p2 _5 l c1 g; E1 z .... c, T6 K% b5 A U+ u7 @
if ($http_user_agent ~ ^$){8 I5 i& |3 \3 P, B8 ~$ O8 V
return444;
" P. U+ s# j" M4 Z5 T7 \" q }; V9 v: A8 u8 R# ^
if ($http_user_agent ~* " X0 u/ J9 \# _$ @/ P- H* x
"scrapy|python|curl|java|wget|httpclient|okhttp|MJ12bot|Expanse|ahrefsbot|seznambot|serpstatbot|sindresorhus|zgrab" # W/ e8 T3 s4 J% ~7 g5 M5 t2 B
){
: ]1 t4 Q0 g. n+ | return444;8 a6 _8 V: y9 ]! X: U
}% C$ e: F4 \6 i. M. w, `% P
...
/ W! `# @3 Y4 {$ x8 G }效率比较低,如果是多个server那么得写多遍所以修改为map的规则进行但是如果改为map的话,需要在http{}之中先创建map规则,然后再到server中使用就可以了。
) a# `6 g' z6 P" O3 [8 |/ i# G 示例如下: http {
4 \& m0 _& M% ?: q ...
0 n, `$ J; x ]3 u X+ y, c7 [ # 创建一个屏蔽规则zinyanUA,而它的取值从$http_user_agent 中获取
3 }+ }0 w5 S1 P0 |+ H8 K: p6 k map $http_user_agent $zinyanUA {
5 y0 J' f: C6 u+ \5 W! K3 _5 @) N default 。 ) a0 V+ U9 Y8 R4 Y1 A
0; j2 k" R) K4 {( u4 C4 ?# t, u
~*(scrapy|python|curl|java|wget|httpclient|okhttp|MJ12bot|Expanse|ahrefsbot|seznambot|serpstatbot|
, i# G& ]: W; k2 H8 X1 J sindresorhus|zgrab|censys|RepoLookoutBot) 1;1 ?6 l) a7 x7 `, ?0 R
~ ^$ 1;
) N8 k4 c! n) t- n5 d- E }
0 p6 @4 N3 O! \3 V' {3 s ...
8 U3 `1 b6 e4 G) J. j }语法解释:~ 表示正则表达式对大小写敏感~* 表示正则表达式对大小写不敏感。 3 w3 N' E. a0 d5 Y+ s
后面跟着的内容就是正则表达式了在正则表达式中^代表开头,$代表结尾,^$就代表开头和结尾中间没有字符也就是字符串为空的配置完毕后,在需要的server{}段中添加:server{
7 ]& j# F9 g6 K ...
8 r6 F. Q/ L/ q0 b7 O7 _ 。 1 d9 w6 ^( W" U0 k) e- |$ ?
if ($zinyanUA){
6 e' m. w5 i$ Q return 444;" p, b1 ?5 `; {8 v0 s
}
. _6 u r% B. s7 X. u ...8 l" {! N9 \2 e) N
}因为在nginx 的if判断中,参数值0或者为空字符串,会判断为false,其他判断为true。
3 b, r! A: n) `- r 而我在上面创建的map对象中,规范了,如果匹配就返回1,不匹配返回0所以if ($zinyanUA)为true的就是需要返回444的请求了nginx: [emerg] unknown directive "if($http_host)" in /etc/nginx/conf.d/zinyan.conf:49 nginx: configuration file /etc/nginx/nginx.conf test failed。 3 { u1 F) [. r
如果你出现了这个if命名错误的提示,并不是所谓的缺乏if命名的依赖库,而是Nginx中的if命名和括号中间需要有空格nginx -t 检测通过后,通过service nginx reload刷新配置就可以生效了。
# f( ? a3 @" U( P PS:如果实在过滤不了的,建议直接封IP地址,特别是国外的访问。国内也有不少的攻击 0 {* }5 f$ ~. ]: i
5 n, I6 ~+ S* ~; _: v
4 F9 H+ ~9 `% d' c
/ g8 t, Y: |9 E8 j$ v% w
8 X' C0 Q# @! @9 c7 C1 N/ V
|