![Самый простой/лучший способ разрешить доступ только определенным диапазонам IP-адресов](https://rvso.com/image/769296/%D0%A1%D0%B0%D0%BC%D1%8B%D0%B9%20%D0%BF%D1%80%D0%BE%D1%81%D1%82%D0%BE%D0%B9%2F%D0%BB%D1%83%D1%87%D1%88%D0%B8%D0%B9%20%D1%81%D0%BF%D0%BE%D1%81%D0%BE%D0%B1%20%D1%80%D0%B0%D0%B7%D1%80%D0%B5%D1%88%D0%B8%D1%82%D1%8C%20%D0%B4%D0%BE%D1%81%D1%82%D1%83%D0%BF%20%D1%82%D0%BE%D0%BB%D1%8C%D0%BA%D0%BE%20%D0%BE%D0%BF%D1%80%D0%B5%D0%B4%D0%B5%D0%BB%D0%B5%D0%BD%D0%BD%D1%8B%D0%BC%20%D0%B4%D0%B8%D0%B0%D0%BF%D0%B0%D0%B7%D0%BE%D0%BD%D0%B0%D0%BC%20IP-%D0%B0%D0%B4%D1%80%D0%B5%D1%81%D0%BE%D0%B2.png)
Я ищу самый простой/лучший способ доступа только к определенным диапазонам IP-адресов для моей установки Ubuntu 20.04. Я бы хотел, чтобы это было в основном для блокировки веб-трафика (apache), но лучше всего было бы полностью заблокировать сервер.
Я понимаю, что аппаратный вариант лучше всего подходит для этого, но я не могу себе этого позволить. Я также понимаю, что «самый простой» и «лучший» не всегда идут вместе.
Кроме того, замедляет ли работу сервера наличие большего количества диапазонов IP-адресов?
Любая помощь будет оценена по достоинству.
решение1
Вы можете фильтровать весь IP-трафик, кроме нужного вам, довольно легко на большинстве установок Linux. Помните, что при этом вы можете потерять доступ к серверу.
Вот небольшая база, которая может подойти.
# Allow some related traffic
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
# Allow single source ip
iptables -A INPUT -s x.x.x.x/net -j ACCEPT
# Drop everything else
iptables -P INPUT DROP
Перед запуском последней строки сброса, которая активирует все, вы можете использовать , iptables -vnL
которая показывает вам счетчики для случаев, когда правило срабатывает, убедитесь, что это так.
Выполнение ip-фильтрации использует циклы ЦП, но также и ответ на любые пакеты. Это почти никогда не вызывает беспокойства, если только вы не делаете сложные правила на высокой пропускной способности. это не сложные правила.