Поднимаем мобильные прокси на 3G/4G модеме(ах)
Новая инфа по поднятию прокси на более проф. уровне-читайте по ссылке
https://vk.com/@ipv6proxy-podnimaem-mobilnye-proksi
Всем привет. Думаю моя новая статья Вам понравится и вы её оцените. Долго решался её написать, но всё таки , руки дошли. Темка актуальная и набирает обороты.
Появляются новые магазинчики по продаже мобильных прокси. Но как правило их единицы. И pool адресов не так широк по гео локациям как хотелось бы, да и мы всегда хотим всё таки свое решение.
Мы сейчас говорим о домашнем решении, которое подойдёт для бытовых нужд ))) Если у вас завалялся модемчик или парочку.
Мы не будем сравнивать свой способ поднятия с проф решениями, которые использую магазы по продаже мобильных прокси. У них промышленные радио терминалы, антенные блоки по городам , серверы в Дата центрах ,а так же лицензии на ПО и т.д.
Одним из таких магазинов является airsocks.in
Не буду отрицать то что моё решение не идеальное, но это первый шаг в этом направлении. Дальше будет больше. Начнём с 1 модема. Подключим к ПК и поднимем на нём прокси, который можно будет юзать из локальной сети вместе с вашим основным инетом. Так же есть решение использовать мобильные прокси удалённо, этот способ тоже рассмотрим в продолжении статьи. Настроим рекконнект модема и смену IP адреса на свистке.
Для облегчения решения будем поднимать мобильные прокси на виртуальной машине с установленной ОС Centos7, а не на реальном железе, так как у многих его просто нет (подойдёт и старый нетбук-уже практиковал такое решение).
Рассмотрим детально процесс установки Centos7 на VirtualBox , настройку модема, установку прокси и настройку маршрутизации .
Что касается модемов. Тут точно не могу сказать подойдёт ли ваш. Я использую те модемы, которые при подключение создают новый интерфейс. В процессе мы дойдём до этого шага и поймёте подойдёт ли ваш модем для этих целей. Я использую модемы модели Мегафон М-150-1, Мегафон М-150-2, МТС 423S и т.п.
Установка Centos7 на VirtualBox
Для этих целей я использую образ iso минимальный пакет. Скачайте его по ссылке здесь или по ссылки с яндекс диска. VirtualBox качайте с оф сайта.
Запускаем VirtualBox и создаём новую вирт машину. Указываем любое имя а так же выбираем тип и версию как на скрине ниже
Указываем объём ОЗУ , в зависимости сколько у вас , но 1024 Мб вполне хватит
Создаём новый вирт жёский диск с 4-8 Г памяти.
Выбираем тип жёсткого диска
Динамический вирт жёсткий диск
И создаём вирт жесткий диск.
Настроим нашу вирт машину.
И выставляем все настройки как на скринах ниже
Сохраняем изменения и запускаем вирт машину.
Устанавливаем Linux
Чтобы освободить мышку от вирт машины, нажмите правый Ctrl
Подтвердите автоматическое разбиение дисков, для этого выберете «Расположение установки» и нажмите готово.
Перейдите в «Сеть и имя узла»
Включите интерфейс , в моём случае это wi-fi. Если вы подключениы к ПК витой парой то там будет другой интерфейс. В случае подключения к ПК провода от оптики , мобильные прокси будут доступны извне , а не только локально.
Переходим наконец то к установки. Думаю вы уже наигрались правым Ctrl-ом )))
Нажимаем «Начать установку»
После создадите пароль к Root пользователю, дождётесь полной установки и перезагрузите вирт машину.
Настройка виртуальной машины и поднятие прокси
Запускаем наш виртуальный сервер с установленной ОС Centos7.
Вводим имя пользователя «root»
Тапаем Enter и вводим пароль от root что задавали ранее (ввод пароля невиден, так что не пугайтесь).
Всё мы залогинились. Первым делом посмотрим наши интерфейсы и наши ip адреса. Для этого вводим команду
ip a
Видим свой интерфейс enp0s8 и его ip , в моём случае локальный 192.168.0.104
Если у вас возникли проблемы и нет ip адреса , то проверьте раздел настройки вирт машины «сеть» и перезагрузите вирт машину.
Теперь мы можем залогинится к своему серверу по ssh со своего компа , узнав ip сервера. Я использую Bitvise SSH клиент.
Открываем Bitvise SSH и вводим ip 192.168.0.104, порт ssh 22 по умолчанию , логин root и пароль что вы уже знаете.
Логинимся !
Сворачиваем лишние окна. Нам нужна командная строка от сервера.
Первая команда- обновляем систему
yum update
Enter, если требует подтверждение действия, то набираем «y» и жмём ещё раз Enter.
Подключаем репозитории и устанавливаем необходимые дополнения
yum -y install wget nano minicom epel-release net-tools
Отключаем фаервол
systemctl stop firewalld && systemctl disable firewalld
Обязательная утилита для сборки программ
yum -y groupinstall "Development Tools"
Всё самое необходимое установили. Переходим к самому интересному — подключению 3g/4g модема к ПК и проброс USB на наш вирт сервер.
Подключаем модем к ПК, обязательно с сим картой и активированным тарифом под инет. После подключения переходим в виртуал бокс к настройкам нашей вирт машины. Переходим к настройкам USB и добавляем наш модем , в моём случае у меня хайвей и сохраняем.
Передёргиваем наш модем, чтобы он пробросился именно на вирт машину.
Ждём немного пока модем загрузится и проверяем командой
ip a
появился ли новый интерфейс.
Как видим у меня появился новый интерфейс wwp0s6u1i2
В данный момент модем мигает синим индикатором, что говорит о том что 3g сигнал есть, но пока модем не подключился к сети. Так же у модема ещё нет ip адреса. Мы это исправим.
Для начала подключимся к сети через свисток. Для этого сначала посмотрим какие устройства определились на этом USB.
Вводим команду
ls /dev/ttyUSB*
И видим что у меня определилось 2 устройства ttyUSB0 ttyUSB1. Какое то из них отвечает за 3g модем . Нужно определить какое именно. В большинстве случаев ttyUSB0
Для этого попробуем подключиться через устройство ttyUSB0
echo -en 'AT^NDISDUP=1,1,"internet"\r\n' > /dev/ttyUSB0
где, «internet» это точка доступа оператора мегафон.
Если после команды индикатор модема мигает то пробуем
echo -en 'AT^NDISDUP=1,1,"internet"\r\n' > /dev/ttyUSB1
В моём случае модем подключился по ttyUSB1 и индикатор загорелся.
Узнаем наш ip
wget -qO- eth0.me
Видим что ip на данный момент от нашего основного интернета что раздаётся по локальной сети.
Для того чтобы инет был от модема нам нужно поднять интерфейс от модема и присвоить ему ip. Можно воспользоваться dhcp-клиентом, но мы лучше пропишем получение ip адреса по dhcp в настройках интерфейса.
Создаём интерфейс через редактор nano , nano /etc/sysconfig/network-scripts/ifcfg-*****, вместо ***** указываем имя вашего интерфейса от 3g модема.
nano /etc/sysconfig/network-scripts/ifcfg-wwp0s6u1i2
Я решил модем воткнуть не напрямую к ПК, а через активный USB хаб с доп питанием от розетки.
Вот так выглядит у меня модемы подключённые к хабу.
Именно с доп питанием от 220В, так как при подключении большого кол-ва модемов через обычный хаб , модемы будут отваливаться. Им просто не будет хватать питания. Так же лучше подключать хаб именно в тот USB который ближе всего расположен к сетевой карте, на нетбуках это usb порт рядом со входом Ethernet, куда вы подключаете провод от интеренета.
Думаю подойдёт любой usb хаб с активным питанием. А вот мой :
Ладно , отвлеклись немного мы. Сейчас подключаем 1 модем и нам он не пригодится пока.
В дальнейшем , при подключении 2-х и более модемов, он нам пригодится.
И так открыли новый тестовый док nano /etc/sysconfig/network-scripts/ifcfg-wwp0s6u1i2, в который нужно прописать следующее:
DEVICE="wwp0s6u1i2" NAME="wwp0s6u1i2" TYPE="Ethernet" ONBOOT="no" BOOTPROTO="dhcp" HWADDR="XX:XX:XX:XX:XX:XX" NM_CONTROLLED="no" NOZEROCONF="yes" IPV4_FAILURE_FATAL="no" IPV6INIT="no" ZONE="external" PEERDNS="yes"
Поменяйте значения DEVICE, NAME, HWADDR на свои.
DEVICE, NAME вы уже знаете, а вот
HWADDR (мак адрес) можете узнать из команды
ip a
Вот что получилось у меня:
Сохраняем док, нажатием кнопок последовательно Ctrl+O, Enter, Ctrl+X
Поднимаем наш интерфейс. Не забываем , что модем уже подключился к сети и горит постоянно индикатор на модеме.
ifup wwp0s6u1i2
Проверяем и смотрим ip на модеме
ifconfig
И видим то что интерфейс получил ip адрес
10.215.198.64 это наш локальный ip (серый) от NAT сети оператора Мегафон.
Мы получили серый ip от оператора.
Проверим наш белый ip , который виден всем. Тот что мы можем получить на сайте 2ip.
wget -qO- eth0.me
И видим что ip поменялся. Мы получаем наш ip от оператора Мегафон.
Немного отклонюсь от темы и расскажу почему мобильные прокси стабильны к баннам со стороны соц сетей. Ответ прост. Если вы загуглите что такое NAT, то узнаете почему))) . Я скажу своими словами.
Так как устройств много на планете земля и каждому нужен свой ip, придумали такую технологию как NAT. Как раз серый ip , что мы получили в интерфейсе это и есть ip промежуточного звена (маршрутизатора оператора) , к которому в свою очередь подключаются очень много мобильных устройств. И уже каждому устройству присваивается белый ip , что мы видим, при переходе на сайт например 2ip. Как вы уже догадались соц сети не могут заблокировать именно ip NAT, тем самым поставив блок 1000000 пользователей.
Поехали дальше.
Для поднятия 1 прокси на 1 модеме 3g не нужно настраивать маршрутизацию. А вот если мы подключим 2 и более модемов на 1 сервер, то вот тут уже нам понадобится создавать таблицы маршрутизации. Мы это рассмотрим в следующей моей статье.
Установка прокси сервера 3Proxy
Устанавливаем прокси сервер 3proxy. Откроем FTP клиент, которое свернули в начале и перенесём на сервер в директорию root архив 3proxy
Разархивируем 3proxy.gz
tar zxfv 3proxy.gz
Открываем директорию 3proxy-0.8.8
cd 3proxy-0.8.8/
Компилируем
make -f Makefile.Linux
Создаём директорию
mkdir /usr/local/3proxy
Копируем бинарник
cp src/3proxy /usr/local/3proxy/
Делаем полные права пользователя
chmod +x /usr/local/3proxy/3proxy
Создаём главный конфигуратор 3proxy.cfg
nano /usr/local/3proxy/3proxy.cfg
И вставляем следующее содержимое:
monitor /usr/local/3proxy/3proxy.cfg daemon timeouts 1 5 30 60 180 1800 15 60 maxconn 5000 nscache 65535 log /dev/null flush proxy -n -a -p8000 -i192.168.0.104 -e100.67.106.102
где 192.168.0.104 это ip адрес от вашей локальной сети или оптоволокна, а 100.67.106.102 это ip от оператора Мегафон, 8000 это порт (можете указать тут любой от 2000 до 65000)
Строчка monitor /usr/local/3proxy/3proxy.cfg будет подхватывать наши изменения на литу , если их будем вносить, что очень удобно. Думаю адреса ip вы поняли где брать ))
Ещё раз покажу скрин со своими ip (не смотрите на о что у меня разные ip при написании статьи, я не однократно ребутал сервер, дабы всё проработать)
Надеюсь вы уже вкурили и понимаете что да как.
Осталось запустить наши прокси командой:
/usr/local/3proxy/3proxy /usr/local/3proxy/3proxy.cfg
Можно проверять ваш прокси на валидность. Для этого воспользуемся браузером мазила. В настройках забиваем ip и порт.
Переходим на сайт 2ip
Вот что отобразилось у меня
Проверим на определение прокси. Жмём на Прокси: не используется «уточнить» на сайте 2ip
При этом конечно же должен быть отключён банально flash плеер
И видим прекрасную картину . Всё как и положено, даже DNS от мегафона. Временные зоны определяются таким образом и на обычном подключении через 3g модем.
На этом статью подвожу к завершению. В следующей статье рассмотрим процесс рекконекта модема, подгрузу и влючение прокси автоматом при загрузке сервера. А так же рассмотрим подключение 2-х и более модемов на 1 сервер и поднятие на них прокси 3G. На этом всем пока, пока!
Реконнект 3g/4g модема и смена динамического ip
Для того чтобы менялся Ip адрес на модеме, нужно отключить соединение и включить. При этом поменяется белый ip адрес, что по мне не акти какое решение. И я перезагружаю модем полностью, можно по питанию рубануть модем, отключив питание на шине. Но мне это показалось немного геморойно. И я использую мне понравившиеся AT команды.
Для того чтобы ребутнуть модем, введите следующую команду:
echo -e "AT^RESET\r\n" >/dev/ttyUSB1
При этом модем перезагрузится, время перезагрузки составляет 20 секунд, что вполне годно для работы.
После нужно заново подключиться к сети с модема и поднять интерфейс. Так же поменять ip адрес в конфиге 3proxy.
Чтобы не делать это всё вручную напишем простой bash скрипт.
nano proksik3g.sh
содержимое скрипта
#!/bin/bash PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin echo -e "AT^RESET\r\n" >/dev/ttyUSB1 killall 3proxy sleep 20 echo -en 'AT^NDISDUP=1,1,"internet"\r\n' > /dev/ttyUSB1 ifdown wwp0s6u1i2 ifup wwp0s6u1i2 IP=`ip addr list wwp0s6u1i2 | grep " inet " | head -n 1 | cut -d " " -f 6 | cut -d / -f 1` echo "" > /usr/local/3proxy/3proxy.cfg cat > /usr/local/3proxy/3proxy.cfg << END monitor /usr/local/3proxy/3proxy.cfg daemon timeouts 1 5 30 60 180 1800 15 60 maxconn 5000 nscache 65535 log /dev/null flush proxy -n -a -p8000 -i192.168.0.104 -e$IP END /usr/local/3proxy/3proxy /usr/local/3proxy/3proxy.cfg
В данном скрипте wwp0s6u1i2 это название интерфейса. IP получаем автоматически , командой grep
Можете скачать скрипт по ссылке
Закачайте скрипт на сервер в паку root
и предоставьте права на выполнение
chmod +x proksik3g.sh
И кстати установите psmisc для того чтобы срабатывала команда killall 3proxy, что находится в скрипте
yum install psmisc
После уже можете запустить скрипт для реконнекта модема
bash proksik3g.sh
Если вы сделали всё правильно, то модем перезагрузится и поменяется ip.
В продолжении статьи мы рассмотрим подключение 2-го модема и поднятие прокси на 2-х модемов на 1 сервере.
У кого возникли вопросы . Можете спросить в комментарии. Всем удачи!
Управление реконнектом 3g/4g модема через зеннопостер
В продолжении статьи решил написать в начале о процессе автоматизации смены ip на модеме по средствам маленького шаблона зеннопостера на сишарпе.
Чтобы в процессе выполнения какого либо проекта , в определённое время у вас происходила смена ip адреса.
Что делает шаблон- он подключается по SSH к нашему виртуальному серверу и запускает bash скрипт для реконнекта модема. Как вы уже догадались всё очень просто.
Шаблон состоит из 1 блока С#
Этот блок можете вставить куда угодно в вашем проекте.
Из входящих настроек всего 3 переменные: ip вирт сервера, имя пользователя root и пароль от вирт сервера.
Скачать шаблон можете по ссылке.
Вскоре сниму видео обзор по работе шаблона , а так же продемонстрирую смену ip.
Уже скоро буду подключать 2-ва модема и более. Будьте на связи!
Видео о работе шаблона по автоматизации реконнекта модема и смена ip адреса
Давненько не писал продолжение статьи. Сегодня хочу Вам рассказать о том как сделать доступ к мобильным проксям удалённо. Например Вы сидите на работе, а модем у вас дома и надо использовать его удалённо, хоть из другого города.
Немного поигравшись с вирт машиной- всё таки решил поднимать моб прокси на отдельном сервер с Linux на борту (Centos7). Завалялся старый нетбук. Почему бы им и не воспользоваться. С вирт машиной возникают проблемы при пробрасывании USB, не всегда получается пробросить несколько модемов. Другое дело сервер на базе компьютера , в данном случае нетбука.
Как вы уже поняли на небуке стоит Centos7. К нетбуку подключен инет по проводу от провайдера Ростелеком с динамическим ip и что самое главное нет NAT, т.е наш ip в настройках сети совпадает с тем ip что отображается на сайте 2ip.ru например.
Так же к нетбуку подключён разлоченный 4g модем с симкой от мегафона.
Забегу немного вперёд и скажу как устроен механизм удалённого доступа к моб ip адресу.
Т.к ip мобильного оператора за NAT -ом , то он не доступен к подключению из инета. Соответственно подключаемся мы к ip от провайдера Ростелеком, (в моём случае) это будет входящее соединение, а исходящее соединение уже по ip от Мегафона.
Мы подняли ip на интерфейсе wwan1 от Мегафона. Так же у нас имеется интерфейс enp7s0 от проводного инета и интерфейс wlp5s0 от wi-fi
ip как видим уже доступны на интерфейсах.
Так как у меня дома стоит wi-fi роутер, который раздаёт инет всем устройством, то основной провод от инета Ростелеком подключен к самому роутеру WAN. От роутера уже выходит через LAN 2 провода , один на мой стационарный комп, другой уже к нетбуку.
Чтобы мы получили не локальный ip адрес на нетбуке нужно в настройках роутера пробросить мост на том LAN где подключен сам нетбук.
У меня это выглядит вот так
Можно воспользоваться конечно же свитчем. Кому как проще.
Так мы получили тем самым ip адрес на нетбуке , такой же если бы мы подключили провод от провайдера непосредственно в сам нетбук. Но так как мен нужен wi-fi то я пробросил мост на LAN4.
где
lAN1 -мой стационарный комп
LAN4- сервер linux на базе нетбука
WAN- сам инет от оператора Ростелеком
Немного разобрались как и что подключено.
Теперь настало время настройки маршрутизации. Чтобы наша схема работала и у нас был доступ к моб прокси из вне — нам нужно настроить так чтобы на сервере было 2 активных подключения. Основной и дополнительный.
Для этого создаём таблицу маршрутизации
echo "101 T1" >> /etc/iproute2/rt_tables
Теперь нам нужно настроить саму маршрутицацию
ip route add $NETWORK dev wwan1 src $IP table T1 ip route add default via $DEFAULT table T1 ip route add $NETWORK dev wwan1 src $IP ip rule add from $IP table T1
, где
NETWORK — сеть от оператора мегафон
IP — сам адрес от мегафон
DEFAULT -шлюз от мегафон
Для того чтобы нам вручную после реконета каждый раз не узнавать эти значения и по новой не настраивать маршрутизацию , я написал маленький bash скрипт 4G.sh, расположенный в директории root
#!/bin/bash # Copyright # Boris O. Baktashev # https://kak-podnyat-proksi-ipv6.ru # 2016 echo -e "AT^RESET\r\n" >/dev/ttyUSB1 #рестарт модема 4g killall 3proxy #убиваем все процессы 3proxy sleep 20 #ждём 20 секунд, пока загрузится модем echo -en 'AT^NDISDUP=1,1,"internet"\r\n' > /dev/ttyUSB1 #подключаемся к интеренету от Мегафон ifdown wwan1 #выключаем интерфейс от 4G модема ifup wwan1 #включаем интерфейс от 4G модема IP=`ip addr list wwan1 | grep " inet " | head -n 1 | cut -d " " -f 6 | cut -d / -f 1` #узнаём адрес мегафон DEFAULT=`ip route list table unspec | grep "default via" | head -n 1 | cut -d " " -f 3` #узнаём шлюз мегафон NETWORK=`ip route list table unspec | grep "dev wwan1 proto kernel scope link src" | head -n 1 | cut -d " " -f 1 | cut -d / -f 1` # узнаём адрес сети мегафон dhclient -r enp7s0 #отключаем интерфейс от проводного интернета dhclient enp7s0 #включаем интерфейс от проводного интернета killall noip2 #убиваем процесс динамического ДНС /usr/local/bin/noip2 #запускаем динамич ДНС IPv4=`ip addr list enp7s0 | grep " inet " | head -n 1 | cut -d " " -f 6 | cut -d / -f 1` #узнаём адрес от провайдера проводного интернета ip route add $NETWORK dev wwan1 src $IP table T1 ip route add default via $DEFAULT table T1 ip route add $NETWORK dev wwan1 src $IP ip rule add from $IP table T1 echo "" > /etc/3proxy.cfg #чистием конфиг 3proxy cat > /etc/3proxy.cfg << END #создаём новый конфиг 3proxy daemon timeouts 1 5 30 60 180 1800 15 60 maxconn 5000 nscache 65535 log /dev/null proxy -n -a -p8000 -i$IPv4 -e$IP END /usr/bin/3proxy /etc/3proxy.cfg #запускаем прокси
При запуске скрипта командой
bash 4G.sh
Будет произведён рекконект модема, настройка маршрутизации и поднятие мобильного прокси на новом ip от мегафон.
Т.к у нас ip от провайдера ростелеком динамический, то соответственно он также меняется.
Для этого я подключил Динамический ДНС от noip.com
Что даёт нам DDNS- в независимости от нашего ip адреса который будет меняться, мы сможем обращаться к нему по домену. Т.е. Поменялся ip и нам не нужно его даже узнавать. Потому что можем обратиться к домену , который уже получил информацию о нашем новом ip адресе. Тем самым у нас имеется статический домен.
Как настроить DDNS на Linux в этой статье я не буду рассматривать.
Так как подключение от 4G модема не стабильно, нам нужно написать скрипт который будет проверять на наличие интренета на интерфесе от мегафона и в том случае если нет сигнала — поднимать инет и производить все настройки и поднятие прокси. В дальнейшем мы положим скрипт в крон , который будет проверять доступность инета со свистка каждые 5 минут.
Для этого пишем скрипт watchdog, взятый за основу с сайта habrahabr.ru и немного видоизмененный
#!/bin/bash export PATH="$PATH:/usr/sbin" SN="$(basename "$0")" IP=`ip addr list wwan1 | grep " inet " | head -n 1 | cut -d " " -f 6 | cut -d / -f 1` function print_help() { printf "\n" printf "Использование: %s options...\n" "$SN" printf "Параметры:\n" printf " -s Проверяемый ресурс.\n" printf " -i Имя сетевого интерфейса.\n" printf " -d Шина и порт модема lsusb -t.\n" printf " -n Число ошибочных пингов.\n" printf " -m Маркер модема, из команды lsusb.\n" printf " -h Справка.\n" printf "\n" } # Если скрипт запущен без аргументов, открываем справку. if [[ $# = 0 ]]; then print_help && exit 1 fi while getopts ":s:i:d:n:m:h" opt ; do case $opt in s) SITE=$OPTARG; ;; i) IF=$OPTARG; ;; d) DEV=$OPTARG; ;; n) EP=$OPTARG; ;; m) MM=$OPTARG; ;; h) print_help exit 1 ;; *) printf "Неправильный параметр\n"; printf "Для вызова справки запустите %s -h\n" "$SN"; exit 1 ;; esac done if [[ "$SITE" == "" ]] || [[ "$IF" == "" ]] || [[ "$DEV" == "" ]] || [[ "$EP" == "" ]] || [[ "$MM" == "" ]] ; then printf "\n" printf "Одна или несколько опций не указаны.\n" printf "Для справки наберите: %s -h\n" "$SN" printf "\n" exit 1 fi M="$(lsusb | grep -w "$MM")" #строка модема из lsusb if [[ "$M" != "" ]]; then #если модем выбран, можно проверять пинги if grep -w -q "$IF" /proc/net/dev; then #проверяем наличие сетевого интерфейса printf "\n" printf "Проверка доступности %s через интерфейс %s\n" "$SITE" "$IF" printf "\n" if [[ "$EP" -ge 6 ]]; then printf "Число ошибочных пингов должно быть меньше или равно 5\n" exit 1 else printf "Делаем пинги...\n" flag="0" for i in {1..5}; do #делаем 5 пингов до сервера timeout -k 2 -s TERM 16 ping -w 14 -s 8 -c 1 -I "$IP" "$SITE" || flag=$((flag+1)) && printf "пинг:%s/5 (ошибок:%s)\n" "$i" "$flag" #пинг не прошел - инкрементируем счетчик if (("$flag" >= "$EP")); then break else read -r -t 1 > /dev/null fi done printf "потерь пакетов: %s из %s\n" "$flag" "$i" printf "\n" if (("$flag" >= "$EP")); then #если потерь пакетов больше 2х M="$(lsusb | grep "$MM")" #на всякий случай снова глянем - вдруг модем выдернули printf "Будет сброшен модем:\n" ifdown "$IF" #деактивируем интерфейс bash 4G.sh fi fi fi else printf "\n" printf "Интерфейс %s не существует\n" "$IF" printf "\n" exit 1 fi else printf "Модем %s не найден.\n" "$MM" fi
Ложем скрипт в крон
crontab -e
*/5 * * * * /usr/local/bin/watchdog -m Huawei -s ya.ru -i wwan1 -n 3 -d 1-1 > /dev/null 2>&1
Скрипт каждые 5 минут будет проверять наличие соединения и если его нет — производить все настройки.
а наш прокси в не зависимости от ip будет доступен по адресу
***.sytes.net:8000 (в нашем случае порт 8000, прокси без авторизации)
Если нам нужен рекконект модема, то скрипт 4G.sh так же можете положить в крон.
Рекконект можема занимает по времени ориентировочно 40 сек.
Проверяем скорость и пинг нашего моб прокси.
На этом пока всё. ПОКА ВСЁ…)