Я знаю, что эти IP-адреса являются поддельными ботами Google, и я хотел бы их заблокировать. IP не статичен, поэтому я хотел бы заблокировать диапазон в Cloudflare.
Однако это не работает. Вот пример журнала поддельного бота Google: https://gyazo.com/f4bd7182923c6caa92cf95a7f84116cd
Вот поддельные IP-адреса ботов:
162.158.74.61
162.158.74.175
162.158.75.188
162.158.75.68
162.158.75.230
162.158.75.242
162.158.75.26
162.158.74.205
172.68.58.213
172.68.58.141
172.68.58.21
172.68.59.40
172.68.59.184
108.162.216.176
108.162.216.248
108.162.216.92
Вот моя текущая конфигурация Cloudflare: https://gyazo.com/91af7d0964621c95d5cc5a462724cb9a
Любые идеи о том, как это должно быть сделано?
Вы можете заблокировать всех ботов через robots.txt и поместив это
User-agent: *
Disallow: /
Это заблокирует всех ботов, сканирующих ваш сайт.
Также, если вы хотите, чтобы бот, например, googlebot, поместил это
User-agent: Googlebot
Allow: /
Добавьте в /etc/nginx/nginx.conf
в блок http:
geo $fakebotip {
default 0;
108.162.0.0/16 1;
141.101.0.0/16 1;
162.158.0.0/16 1;
172.68.0.0/16 1;
172.69.0.0/16 1;
}
А затем к /etc/nginx/sites-available/your-site.pl
:
if ($fakebotip = 1) {
set $naughtyBot A;
}
if ($http_user_agent ~ (Googlebot|SemrushBot|AhrefsBot|bingbot|Qwantify|YandexBot|YandexImages|DotBot|linkfluence|Mediatoolkitbot|BoardReader) ) {
set $naughtyBot "${naughtyBot}B";
}
if ($naughtyBot = AB) {
return 404;
}
Проверяем конфиг nginx:
sudo nginx -t
Если все в порядке, перезагрузите nginx:
sudo systemctl reload nginx
Я не хочу блокировать всех роботов. Просто нужно заблокировать поддельных роботов, и я вставил IP-адреса поддельных ботов выше. Блокировка каждого робота уничтожила бы мой SEO. Более того, мне нужно заблокировать его в Cloudflare.