Modem-stretch/en: различия между версиями

Материал из Wiren Board
(Новая страница: «==== Quick setup of automatic Internet access ====»)
(Новая страница: «In the standard software set of the Wiren Board controller connection settings in ppp protocol for MTS, MegaFon and Beeline mobile operators are included. If yo…»)
Строка 98: Строка 98:
==== Quick setup of automatic Internet access ====
==== Quick setup of automatic Internet access ====


В стандартное ПО Wiren Board входят настройки подключения для операторов МТС, Мегафон и Билайн по протоколу ppp. Если вы пользуетесь одним из них, для запуска подключения выполните команду
In the standard software  set of the Wiren Board controller connection settings in ppp protocol for MTS, MegaFon and Beeline mobile operators  are included. If you are using one of them, run the following command to start the connection
<syntaxhighlight lang="bash">
<syntaxhighlight lang="bash">
pon mts # можно заменить mts на megafon или beeline
pon mts # you can replace mts with megafon or beeline
</syntaxhighlight>
</syntaxhighlight>
Чтобы отключить подключение, выполните
To disable the connection, run
<syntaxhighlight lang="bash">
<syntaxhighlight lang="bash">
poff mts # можно заменить mts на megafon или beeline
poff mts # you can replace mts with megafon or beeline
</syntaxhighlight>
</syntaxhighlight>
[[File:Etc-network-interfaces.png|300px|thumb|right|Файл ''/etc/network/interfaces'', автоматически запускающий подключение к МТС]]
[[File:Etc-network-interfaces.png|300px|thumb|right|File ''/etc/network/interfaces'', starts connection to MTS automatically]]
Чтобы подключение запускалось автоматически, откройте файл ''/etc/network/interfaces'' и раскомментируйте/отредактируйте следующие строки:
To start the connection automatically, open the ''/etc/network/interfaces'' file and uncomment/edit the following lines:
<syntaxhighlight lang="bash">
<syntaxhighlight lang="bash">
auto ppp0
auto ppp0
iface ppp0 inet ppp
iface ppp0 inet ppp
   provider mts # можно заменить mts на megafon или beeline
   provider mts # you can replace mts with megafon or beeline
</syntaxhighlight>
</syntaxhighlight>
Но если вы хотите, чтобы подключение само восстанавливалось при обрыве, смотрите полную инструкцию ниже.
But if you want the connection to restore itself when it breaks, see the full instructions below.





Версия 13:36, 31 мая 2019

Другие языки:

The Wiren Board controller is equipped with GSM/GPRS-module which can provide the following functions:

  • send/receive SMS
  • connect to the Internet via GPRS

See the module description for the full list of features:

  • 3G modem in Wiren Board 5 and Wiren Board 6: SIM5300E
  • 2G modem in Wiren Board 4, 5 and 6 :SIM800 or M660A;
  • Wiren Board Smart Home 3.5, Wiren Board 4:

SIM900R.


Getting started

Connect the antenna and insert the SIM card before starting the controller. If you have enabled the controller without a SIM card, restart the modem using the wb-gsm utility after installing it (see below).

Modem in Linux

Inside the controller, the modem is connected to the processor in one of two ways:

  • via UART port (device /dev/ttyGSM (previously: /dev/ttyAPP0)) - all modems, including 3G;
  • via USB port (devices /dev/ttyACM0-/dev/ttyACM6) - 3G only.

You can work with the modem at a low level by sending commands to the port /dev/ttyygsm or /dev/ttyACM0, respectively. For 3G-connection port UART is not suitable due to the bandwidth limitations of the UART-channel, you should use ACM-port /dev/ttyACM0.

Modem control pins PWRKEY and RESET are also connected to the processor, you can turn off or restart the modem using them. Usually you do not need to work with them directly - the reboot is performed by the wb-gsm utility (see below), but also direct access to these contacts via GPIO is implemented (read more about GPIO, look for the corresponding names in the table).


Enabling the module

By default, the modem is automatically turned on when the controller boots. Then it can be turned off and reloaded with the wb-gsm utility (the utility is included in the standard image in the wb-utils package).

$ wb-gsm on #  turn on the device
$ wb-gsm off #  turn off the device
$ wb-gsm reset #  reboot the enabled device
$ wb-gsm restart_if_broken #  enable or reboot if the modem is not responding


SIM7000E 2G/NB-IoT modems

The SIM7000E 2G/NB-IoT modem is set to select GSM and LTE networks automatically by default. However, in a network or with aSIM card without NB-IoT support, the modem is not registered in the GSM (GPRS) network. In order for the modem to be able to register in the GSM network, it is necessary to force it into 'GSM only' mode.

In the terminal mode of the modem, for example, in the minicom program (see below section #low-Level work with the module via AT-commands), you must enter the mode selection command:

AT+CNMP=13

Possible values:(command AT+CNMP=?): 2-Automatic,13-GSM Only,38-LTE Only,51-GSM And LTE Only

The mode is remembered and active and after power off, you need to set the mode once.

To return to IoT mode, run the following command:

AT+CNMP=51 


Sending and receiving SMS and USSD

gammu-config

The easiest way to work with SMS is with the help of Gammu program (this is a fork of gnokii utility, which has ceased to be developed).

(here is a brief instruction below, see the full documentation on the project website)

  1. Create a configuration file by running gammu-config
    1. In the Port parameter, specify /dev/ttyGSM
    2. In the Connection parameter, specifyat115200
  2. Command examples
$ gammu networkinfo # view the networkand the base station which you are connected to
$ gammu geteachsms # print all SMS
$ gammu getussd '#100#' # balance request in transliteration on MTS russian GSM mobile operator 
$ gammu sendsms TEXT +79154816102 -unicode -text 'Hi' # send 'Hi' to the number

SMS and USSD in russian(if needed) or different languages

SMS and USSD in Russian in gammu still do not work always properly, so commands can be useful to switch the language of USSD and transcoding incoming and outgoing SMS into transliteration:

Operator USSD SMS
translit Russian translit Russian
МТS *100*6*2# *100*6*1# unknown unknown
Меgafon *105*0# *105*9# unknown unknown
Beeline *111*6*2# *111*6*1# unknown unknown
Тele2 *120# *120*1# unknown unknown


Internet connection

The modem must be turned on before you can access the Internet. To do this manually or in the network interface configuration file (see below), run the following command

wb-gsm restart_if_broken


Quick setup of automatic Internet access

In the standard software set of the Wiren Board controller connection settings in ppp protocol for MTS, MegaFon and Beeline mobile operators are included. If you are using one of them, run the following command to start the connection

pon mts # you can replace mts with megafon or beeline

To disable the connection, run

poff mts # you can replace mts with megafon or beeline
File /etc/network/interfaces, starts connection to MTS automatically

To start the connection automatically, open the /etc/network/interfaces file and uncomment/edit the following lines:

auto ppp0
iface ppp0 inet ppp
  provider mts #  you can replace mts with megafon or beeline

But if you want the connection to restore itself when it breaks, see the full instructions below.


Пошаговая инструкция настройки постоянного GPRS-подключения

  • Подсоедините антенну к разъему GSM
  • СИМ-карту в слот micro SIM 1
  • Включите модем командой wb-gsm restart_if_broken
  • Если ваш контроллер укомплектован 3G-модемом, в файле /etc/ppp/peers/ваш_провайдер_сотовой_связи (в примере — МТС) замените устройство /dev/ttyGSM на /dev/ttyACM0
  • В файле /etc/networks/interfaces закомментируйте раздел, связанный с ppp0 и добавьте следующие строки:
auto ppp0
iface ppp0 inet ppp
provider mts
#рестартуем модем, если он завис
pre-up wb-gsm restart_if_broken  
#Затем ждем, пока он загрузится и найдет сеть.
pre-up sleep 10
  • Выполните команду ifup ppp0 — через 15 секунд интерфейс ppp0 будет доступен.
  • После перезагрузки интерфейс будет автоматически включаться и восстанавливать соединение после обрыва сотовой связи.


Полная инструкция

Выход в интернет через GPRS происходит по протоколу PPP с использованием сервиса pppd. Для его работы нужно создать конфигурационный файл, соответствующий настройкам вашего оператора. Конфигурационные файлы для операторов "большой тройки" уже есть в стандартном образе. Файлы хранятся в директориях /etc/ppp/peers и /etc/chatscripts. Для других операторов или специальных APN создайте свои конфигурационные файлы на основе стандартных. Для этого при помощи утилиты pppconfig (устанавливается командой apt-get install pppconfig) создайте конфигурационный файл подключения с параметрами для вашего оператора (например, МТС). Также можете ориентироваться на инструкцию. Обратите внимание на настройки 115200 nocrtsct, которые должны присутствовать в конфигурационных файлах.

Если подключение к интернету осуществляется в сети 3G, то в конфигурационном файле для вашего оператора следует заменить UART-порт (/dev/ttyGSM (или /dev/ttyAPP0 в старых моделях контроллеров)) на CDC-ACM-порт (/dev/ttyACM0). Это необходимо, чтобы скорость обмена данными не ограничивалась пропускной способностью UART-порта модема:

Файл:GSM-ACM.png


После создания конфигурационного файла запустите подключение, выполнив

pon название_подключения

или отредактировав файл /etc/network/interfaces, как описано выше.

Чтобы подключение само перезапускалось при обрыве, и делало это неограниченное число раз, добавьте в настройки подключения (файл настроек выбранного оператора в директории /etc/ppp/peers) строки:

persist
maxfail 0

если их там нет. В последних версиях контроллеров эти параметры сконфигурированы по умолчанию.

Наиболее полные возможности по контролю за установлением подключения к интернету дает использование настройки интерфейса ppp0 в файле /etc/network/interfaces. Самой востребованной опцией является возможность выполнения команд перед установлением и после включения/отключения интерфейса ppp0.

В файле /etc/network/interfaces для настройки ppp можно использовать стандартные iface-опции pre-up, up, post-up, down, pre-down, post-down. Они задают команды, которые будут выполняться на различных фазах инициализации/деинициализации интерфейса. Подробно особенности их функционирования описаны в man interfaces в разделе IFACE OPTIONS.

Мы же приведем здесь в качестве примера параметры, которые мы рекомендуем использовать при настройке ppp-соединения с мобильными интернет-провайдерами.

auto ppp0
iface ppp0 inet ppp
provider mts
#рестартуем модем, если он завис
pre-up wb-gsm restart_if_broken  
#Затем ждем, пока он загрузится и найдет сеть.
pre-up sleep 10


Для ppp-интерфейсов существуют директории, исполняемые файлы из которых также запускаются на разных фазах установления соединения. Но, если для, например, ethernet-интерфейсов эти скрипты должны находиться в директориях /etc/network/if-down.d, if-post-down.d, if-pre-up.d, if-up.d, то соответствующие директории для ppp-интерфейсов находятся в /etc/ppp/ip-down.d, ip-up.d и т.п (подробнее об их назначении и функционировании можно узнать в документе PPP HOWTO).


Настройки DNS и маршрутизации

Важно! По умолчанию интерфейс ppp0 при инициализации не добавляет нового маршрута по умолчанию через ppp, в случае, если такой маршрут существует и настроен, скажем, через eth0. Если это требуется, то изменение таблицы маршрутизации можно выполнять через скрипты в директориях ip-down.d, ip-up.d. В простейшем случае, можно назначать шлюзам по умолчанию разные метрики, чтобы в случае падения одного начинал бы использоваться второй. Однако ситуация, когда интерфейс функционирует нормально, но трафик не проходит на уровне провайдера, делает такой механизм неработоспособным. Смотрите следующий раздел о том, как использовать ppp-соединение в качестве резервного.

Адреса DNS-серверов заменяются на те, которые были получены от провайдера мобильной связи. При использовании DHCP на ethernet-интерфейсах и интерфейсе ppp0 файл /etc/resolv.conf меняется при установлении соединения через каждый из этих интерфейсов в соответствии с адресами DNS-серверов, полученными от провайдера.

В качестве дополнительной меры повышения надежности при наличии двух соединений можно предложить использование DNS-серверов, не зависящих от провайдера, например GoogleDNS (8.8.8.8, 8.8.4.4) и OpenDNS (208.67.222.222, 208.67.220.220). Очень часто эти сервера используются для определения работоспособности сетевого канала по определенному интерфейсу (ping -c5 -I eth0 8.8.8.8 или ping -c5 -I ppp0 8.8.4.4).

Обратите внимание, что при деинициализации ppp0 интерфейса все созданные маршруты, связанные с ним, будут автоматически удалены.


Использование GPRS в качестве резервного канала

Самый простой способ, обеспечить отказоустойчивость, это задать два маршрута по умолчанию с разными метриками, например: для интерфейса eth0 указать метрику 10:

   auto eth0
   iface eth0 inet dhcp
   pre-up wb-set-mac
   hostname WirenBoard
   metric 10 

а для интерфейса — метрику 100:

   auto ppp0
   iface ppp0 inet ppp
   ## select provider: megafon, mts or beeline below
   provider mts
   metric 100
   pre-up wb-gsm restart_if_broken
   pre-up sleep 10

В этом случае, если подключение через eth0 пропадет (обрыв кабеля, отключение коммутатора и т.п.), то маршрутом по умолчанию становится маршрут через интерфейс ppp0.

Для более сложных случаев, когда физическое соединение на интерфейсе eth0 не пропадает, рекомендуется применять скрипты, которые на основе доступности какого-либо сетевого уздла в интернете через один из интерфейсов переключают маршрут по умолчанию. В интернете предлагается множество решений решений такого рода задачи, можно выбрать одно из них.

Если контроллер обычно подключён к Интернету через Ethernet или Wi-Fi, а GPRS должен использоваться только при неполадках основного канала, такой режим работы называется failover. Обычно он работает так:

  1. Организуется работа через основной канал.
  2. Постоянно проверяется наличие доступа в Интернет через основной канал.
  3. В случае неполадок запускается запасное соединение, меняются настройки default gateway.
  4. Основное соединение постоянно проверяется, и если доступ в Интернет через него восстанавливается, система возвращается к работе через него, изменяя default gateway.

В качестве примера укажем две инструкции по организации такого режима работы:

  1. http://lstein.github.io/Net-ISP-Balance/
  2. https://serverfault.com/questions/360131/ubuntu-failover-from-ethernet-to-adsl-modem-to-usb-3g-dongle?rq=1


Низкоуровневая работа с модулем через AT-команды

Ознакомьтесь с инструкцией - Работа с последовательным портом из Linux. Обратите внимание на настройки: 115200, 8N2, no hardware flow control.

Для интерактивного режима:

  • запускаем minicom с ключём, создающим профиль работы с портом (скорость передачи данных, чётность, и т.д.):
 $ minicom -s /dev/ttyGSM

Настройки Minicom

  • Зайти в настройки (нажать Ctrl+A, затем O), выбрать пункт Serial port setup, там установить порт /dev/ttyGSM, скорость и чётность - 115200, 8N1, Hardware flow control - No, Software flow control - No
  • Сохранить настройки: Save setup as _dev_ttyGSM
  • Далее запускать как minicom /dev/ttyGSM (все параметры будут сразу браться из профиля с названием /dev/ttyGSM, который мы ранее создали)
  • Первой вашей командой должна стать AAAAAAAAAT - с её помощью модуль распознает скорость, с которой мы к нему обращаемся (смотрите SIM900R)
  • Второй командой выполните просто AT. Вам должен прийти ответ OK


Примеры команд

(некоторые команды могут различаться в разных модулях, смотрите подробнее в документации на модуль)

  • Синхронизовать скорость порта (не совсем команда)
AAAAAAAAAAAAAT
  • Список всех сетей
AT+COPS=?
AT+CSQ
  • Звонок на номер +79154816102
ATD+79154816102;
  • Установка baud rate порта в фиксированное значение 115200
AT+IPR=115200
  • Запрос времени со встроенных в модуль часов реального времени (RTC)
AT+CCLK?
AT+CCLK="14/03/19,01:20:29+00"
  • Получить IMEI-код модуля (xxxxxx - уникальный номер)
AT+GSN
86820400xxxxxxY

OK


RTC

Мультиплексирование

Модем поддерживает режим мультиплексирования - создание виртуальных портов, через которые можно одновременно работать с модемом. Например, через один порт можно открыть сессию PPP для GPRS, а через другой получать и отправлять SMS, проверять баланс и т.д. Подробнее смотрите CMUX. Этот режим не поддерживается для 2G-модемов.