2024-11-06 17:34:57 +03:00
# Быстрая настройка Linux/OpenWrt
> [!CAUTION]
2024-11-06 06:52:52 +03:00
> Н е пишите в issue вопросы типа "как скопировать файл", "как скачать", "как
> запустить", ... Т о есть все , что касается базовых навыков обращения с О С
> linux. Эти вопросы будут закрывать сразу. Если у вас подобные вопросы
> возникают, рекомендую не использовать данный софт или искать помощь где-то в
> другом месте. Т о же самое могу сказать тем, кто хочет нажать 1 кнопку, чтобы
> все заработало, и совсем не хочет читать и изучать. Увы, такое не подвезли и
> не подвезут. Ищите другие более простые методы обхода. Этот метод **не для
> рядового пользователя**.
## Вступление
Специально для тех, кто хочет побыстрее начать, но не хочет слишком углубляться
в простыню [readme.md ](readme.md ).
Обход DPI является хакерской методикой. Под этим словом понимается метод,
которому сопротивляется окружающая среда, которому автоматически не
гарантирована работоспособность в любых условиях и на любых р е с у р с а х , требуется
настройка под специфические условия у вашего провайдера. Условия могут меняться
с о временем, и методика может начинать или переставать работать, может
потребоваться повторный анализ ситуации. Могут обнаруживаться отдельные
ресурсы, которые заблокированы иначе, и которые не работают или перестали
работать. Могут и сломаться отдельные не заблокированные ресурсы. Поэтому очень
желательно иметь знания в области сетей, чтобы иметь возможность
проанализировать техническую ситуацию. Н е будет лишним иметь обходные каналы
проксирования трафика на случай, если обход DPI не помогает.
2024-11-08 11:12:32 +03:00
Вариант, когда вы нашли стратегию где-то в интернете и пытаетесь е е приспособить к своему случаю - заведомо проблемный.
2024-11-08 11:14:48 +03:00
Нет универсальной таблетки. Везде ситуация разная. В сети гуляют написанные кем-то откровенные глупости, которые тиражируются массово ничего не понимающей публикой.
2024-11-08 11:12:32 +03:00
Такие варианты чаще всего работают нестабильно, только на части ресурсов, только на части провайдеров, не работают вообще или ломают другие ресурсы. В худших случаях еще и устраивают флуд в сети.
Если даже вариант когда-то и работал неплохо, завтра он может перестать, а в сети останется устаревшая информация.
2024-11-06 06:52:52 +03:00
Будем считать, что у вас есть система на базе традиционного **linux** или
**openwrt**. Если у вас традиционный linux - задача обойти блокировки только на
этой системе, если openwrt - обойти блокировки для подключенных устройств. Это
наиболее распространенный случай.
2024-11-06 17:34:57 +03:00
2024-11-06 06:52:52 +03:00
## Настройка
2024-11-06 17:34:57 +03:00
> [!TIP]
> Чтобы процедура установки сработала в штатном режиме на openwrt, нужно
> рассчитывать на свободное место около 1-2 Mb для установки самого zapret и
> необходимых дополнительных пакетов. Если места мало и нет возможности е г о
> увеличить за счет `extroot`, возможно придется отказаться от варианта простой
> установки и прикручивать в ручном режиме без имеющихся скриптов запуска.
> Можно использовать [облегченный `tpws` вариант](../init.d/openwrt-minimal),
> либо попробовать засунуть требуемые zapret дополнительные пакеты в сжатый
> образ `squashfs` с помощью `image builder` и перешить этим вариантом роутер.
2024-11-08 10:25:13 +03:00
1. Скачайте последний [tar.gz релиз ](https://github.com/bol-van/zapret/releases ) в /tmp, распакуйте е г о , затем удалите архив.
2024-11-24 18:00:01 +03:00
Для openwrt и прошивок используйте вариант `openwrt-embedded` .
Для экономия места в /tmp можно качать через curl в stdout и сразу распаковывать.
2024-11-06 06:52:52 +03:00
2024-11-06 17:34:57 +03:00
2. Убедитесь, что у вас отключены все средства обхода блокировок, в том числе и
2024-11-06 06:52:52 +03:00
сам zapret. Гарантированно уберет zapret скрипт `uninstall_easy.sh` .
2024-11-06 17:34:57 +03:00
3. Если вы работаете в виртуальной машине, необходимо использовать соединение с
2024-11-06 06:52:52 +03:00
сетью в режиме bridge. NAT **не** подходит.
2024-11-06 17:34:57 +03:00
4. Выполните однократные действия по установке требуемых пакетов в О С и
2024-11-06 06:52:52 +03:00
настройке исполняемых файлов правильной архитектуры:
```sh
$ install_bin.sh
$ install_prereq.sh
```
> В а с могут спросить о типе фаервола (iptables/nftables) и использовании
> ipv6. Это нужно для установки правильных пакетов в О С , чтобы не
> устанавливать лишнее.
2024-11-06 17:34:57 +03:00
5. Запустите `blockcheck.sh` . Скрипт вначале проверяет DNS. Если выводятся
2024-11-06 06:52:52 +03:00
сообщения о подмене адресов, то нужно будет решить проблему с DNS.
`blockcheck.sh` перейдет в этом случае на DoH и будет пытаться получить и
использовать реальные IP адреса. Н о если вы не настроите решение этой
проблемы, обход будет работать только для тех программ или О С , которые сами
реализуют механизмы SecureDNS. Для других программ обход работать не будет.
2024-11-06 17:54:23 +03:00
> Решение проблемы DNS выходит за рамки проекта. Обычно она решается либо
> заменой DNS серверов от провайдера на публичные (`1.1.1.1`, `8.8.8.8`),
> либо в случае перехвата провайдером обращений к сторонним серверам - через
> специальные средства шифрования DNS запросов, такие как `dnscrypt`, `DoT`,
> `DoH`.
>
> Еще один эффективный вариант - использовать ресолвер от yandex
> (`77.88.8.88`) на нестандартном порту `1253`. Многие провайдеры не
> анализируют обращения к DNS на нестандартных портах.
>
> Проверить работает ли этот вариант можно так:
> ```sh
> $ dig -p 53 @77.88.8.88 rutracker.org dig -p 1253 @77.88.8.88 rutracker.org
> ```
>
> Если DNS действительно подменяется, и ответ на эти 2 команды разный,
> значит метод вероятно работает.
>
> В openwrt DNS на нестандартном порту можно прописать в `/etc/config/dhcp`
> таким способом :
>
> ```
> config dnsmasq
> <...>
> list server '77.88.8.88#1253'
> ```
>
> Если настройки IP и DNS получаются автоматически от провайдера, в
> `/etc/config/network` найдите секцию интерфейса `wan` и сделайте так:
>
> ```
> config interface 'wan'
> <...>
> option peerdns '0'
> ```
>
> ```sh
> $ /etc/init.d/network restart
> $ /etc/init.d/dnsmasq restart
> ```
>
> Если это не подходит, можно перенаправлять обращения на UDP и TCP порты
> `53` вашего DNS сервера на `77.88.8.88:1253` средствами
> `iptables`/`nftables`. В `/etc/resolv.conf` нельзя прописать DNS на
> нестандартном порту.
6. `blockcheck.sh` позволяет выявить рабочую стратегию обхода блокировок. По
2024-11-06 06:52:52 +03:00
результатам скрипта нужно понять какой вариант будете использовать : `nfqws`
2024-11-06 17:54:23 +03:00
или `tpws` и запомнить найденные стратегии для дальнейшего применения.
2024-11-06 06:52:52 +03:00
Следует понимать, что скрипт проверяет доступность только конкретного
домена, который вы вводите в начале. Вероятно, все остальные домены
блокированы подобным образом, **но не факт** . В большинстве случаев можно
2024-11-06 17:54:23 +03:00
объединить несколько стратегий в одну универсальную, и это **крайне
желательно**. Необходимо понимать как работают стратегии. zapret **не может
пробить блокировку по IP адресу**. Для проверки нескольких доменов вводите
их через пробел.
> Сейчас блокираторы ставят на магистральных каналах. В сложных случаях у
> вас может быть несколько маршрутов с различной длиной по ХОПам, с DPI на
> разных хопах. Приходится преодолевать целый зоопарк DPI, которые еще и
> включаются в работу хаотичным образом или образом, зависящим от
> направления (IP сервера). скрипт не всегда может выдать вам в итогах
> оптимальную стратегию, которую надо просто переписать в настройки. В
> некоторых случаях надо реально думать что происходит, анализируя результат
2024-11-07 19:04:23 +03:00
> на разных стратегиях. Если вы применяете большой TTL, чтобы достать до
2024-11-06 17:54:23 +03:00
> магистрала, то не лишним будет добавить дополнительный ограничитель
> `--dpi-desync-fooling`, чтобы не сломать сайты на более коротких
> дистанциях. `md5sig` наиболее совместим, но работает **только** на linux
2024-11-07 19:04:23 +03:00
> серверах. `badseq` может работать только на https и не работать на http.
> Чтобы выяснить какие дополнительные ограничители работают, смотрите
> результат теста аналогичных стратегий без TTL с каждым из этих
> ограничителей.
2024-11-06 17:54:23 +03:00
>
> При использовании `autottl` следует протестировать как можно больше разных
> доменов. Эта техника может на одних провайдерах работать стабильно, на
> других потребуется выяснить при каких параметрах она стабильна, на третьих
> полный х а о с , и проще отказаться.
>
2024-11-07 19:04:23 +03:00
> Далее, имея понимание что работает на http, https, quic нужно
2024-11-06 17:54:23 +03:00
> сконструировать параметры запуска `tpws` и/или `nfqws` с использованием
2024-12-06 11:41:06 +03:00
> мультистратегии. Как работают мультистратегии описано в [readme.md](./readme.md#множественные-стратегии).
2024-11-06 17:54:23 +03:00
>
> Если кратко, то обычно параметры конструируются так:
> ```sh
> "--filter-udp=443 'параметры для quic' <HOSTLIST_NOAUTO> --new
> --filter-tcp=80,443 'обьединенные параметры для http и https' <HOSTLIST>"
> ```
>
> Или так:
> ```sh
> "--filter-udp=443 'параметры для quic' <HOSTLIST_NOAUTO> --new
> --filter-tcp=80 'параметры для http' <HOSTLIST> --new
> --filter-tcp=443 'параметры для https' <HOSTLIST>"
> ```
>
> `<HOSTLIST>` и `<HOSTLIST_NOAUTO>` так и пишутся. Их не надо на что-то
> заменять. Это сделают скрипты запуска, если вы выбрали режим фильтрации по
> хостлистам, и уберут в противном случае. Если для какого-то протокола надо
> дурить все без стандартного хостлиста - просто уберите оттуда `<HOSTLIST>`
> и `<HOSTLIST_NOAUTO>`. Можно писать свои параметры `--hostlist` и
> `--hostlist-exclude` для дополнительных хостлистов или в профилях
> специализаций под конкретный р е с у р с . В последнем случае стандартный
> хостлист там не нужен. Следует избегать указания собственных параметров
> `--hostlist` на листы из директории ipset. Эта логика включена в
> `<HOSTLIST>` и `<HOSTLIST_NOAUTO>`. Отличие `<HOSTLIST_NOAUTO>` в том, что
> стандартный автолист по этому профилю используется как обычный, то есть
> без автоматического добавления доменов. Однако, добавления в других
> профилях автоматически отражаются во всех остальных.
>
> Если стратегии отличаются по версии ip протокола, и вы не можете их
> обьединить, фильтр пишется так:
> ```sh
> "--filter-l3=ipv4 --filter-udp=443 lпа р а ме тр ы для quic ipv4' <HOSTLIST_NOAUTO> --new
> --filter-l3=ipv4 --filter-tcp=80 'параметры для http ipv4' <HOSTLIST> --new
> --filter-l3=ipv4 --filter-tcp=443 'параметры для https ipv4' <HOSTLIST> --new
> --filter-l3=ipv6 --filter-udp=443 "параметры для quic ipv6" <HOSTLIST_NOAUTO> --new
> --filter-l3=ipv6 --filter-tcp=80 'параметры для http ipv6' <HOSTLIST> --new
> --filter-l3=ipv6 --filter-tcp=443 'параметры для https ipv6' <HOSTLIST>"
> ```
>
> Н о здесь совсем "копи-пастный" вариант. Чем больше вы объедините стратегий и
> сократите их общее количество, тем будет лучше.
>
> Если вам не нужно дурение отдельных протоколов, лучше всего будет их
> убрать из системы перехвата трафика через параметры `TPWS_PORTS`,
> `NFQWS_PORTS_TCP`, `NFQWS_PORTS_UDP` и убрать соответствующие им профили
> мультистратегии.
>
> | Протокол | Порт | Примечание |
> |---|---|---|
> | `tcp` | `80` | `http` соединение |
> | `tcp` | `443` | `https` соединение |
> | `udp` | `443` | `quic` соединение |
>
> Если используются методы нулевой фазы десинхронизации (`--mss`,
> `--wssize`, `--dpi-desync=syndata`) и режим фильтрации `hostlist`, то все
> параметры, относящиеся к этим методам, следует помещать в отдельные
2024-11-11 14:54:27 +03:00
> профили мультистратегии, которые получат управление до определения имени
2024-11-06 17:54:23 +03:00
> хоста. Необходимо понимать алгоритм работы мультистратегий. Самым надежным
> вариантом будет дублирование этих параметров на 2 профиля. Какой-нибудь
> сработает в зависимости от параметра `MODE_FILTER`.
>
> ```sh
> "--filter-tcp=80 'параметры для http' <HOSTLIST> --new
> --filter-tcp=443 'параметры для https' --wssize 1:6 <HOSTLIST> --new
> --filter-tcp=443 --wssize 1:6"
> ```
>
2024-11-07 19:04:23 +03:00
> В этом примере `wssize` будет применяться всегда к порту tcp `443` вне
2024-11-06 17:54:23 +03:00
> зависимости от параметра `MODE_FILTER`. Хостлист будет игнорироваться,
2024-11-07 19:04:23 +03:00
> если таковой имеется. К http применять `wssize` вредно и бессмысленно.
2024-11-06 06:52:52 +03:00
2024-11-06 17:34:57 +03:00
7. Запустите скрипт облегченной установки - `install_easy.sh` Выберите `nfqws`
2024-11-06 06:52:52 +03:00
и/или `tpws` , затем согласитесь на редактирование параметров. Откроется
редактор, куда впишите созданную на предыдущем этапе стратегию.
2024-11-06 17:34:57 +03:00
8. Н а все остальные вопросы `install_easy.sh` отвечайте согласно выводимой
2024-11-06 06:52:52 +03:00
аннотации.
2024-11-08 13:52:06 +03:00
9. Удалите директорию из /tmp, откуда производилась установка.
2024-11-11 14:53:36 +03:00
## Полное удаление
1. Прогоните `/opt/zapret/uninstall_easy.sh` .
2. Cо г ла с ите с ь на удаление зависимостей в openwrt.
3. Удалите каталог `/opt/zapret` .
2024-11-06 06:52:52 +03:00
## Итог
Это минимальная инструкция, чтобы быстро сориентироваться с чего начать.
Однако, это не гарантированное решение и в некоторых случаях вы не обойдетесь
без знаний и основного "талмуда". Подробности и полное техническое описание
расписаны в [README ](readme.md ).
Если ломаются отдельные **не заблокированные** ресурсы, следует вносить их в
исключения, либо пользоваться ограничивающим `ipset` или хост листом. Лучше
подбирать такие стратегии, которые вызывают минимальные поломки. Есть стратегии
довольно безобидные, а есть сильно ломающие, которые подходят только для
точечного пробития отдельных ресурсов, когда ничего лучше нет. Хорошая
2024-11-07 19:04:23 +03:00
стратегия может сильно ломать из-за плохо подобранных ограничителей для фейков
2024-11-07 23:48:05 +03:00
\- ttl, fooling.