Что такое широковещательная передача сообщений
Перейти к содержимому

Что такое широковещательная передача сообщений

  • автор:

Cell Broadcast (CB — Широковещательная передача сообщений)

Cell Broadcast (CB — Широковещательная передача сообщений в соте) – массовая рассылка SMS-сообщений в сотовой связи стандартов GSM (Global System For Mobile Communications), UMTS (Universal Mobile Telecommunications System) и др. Cell Broadcast предназначен для незамедлительной доставки каких либо сообщений в определенной географической области. Впервые эта технология была продемонстрирована в Париже в 1997 году и была реализована на базе сети стандарта GSM (Global System For Mobile Communications).

Принципы реализации услуги Cell Broadcast

Технология Cell Broadcast реализована не во всех сетях сотовых операторах. Кроме того, до сих пор не все телефонные аппараты поддерживают данную услугу. Главным образом CB применяется для рассылки новостной информации регионального или местного значения, прогноза погоды, оповещения абонентов о новых услугах, акциях. Причем пользователи в большинстве случаев могут самостоятельно включать или отключать прием широковещательных сообщений. Cell Broadcast очень хорошо подходит для оповещения населения о возникновении каких либо чрезвычайных ситуаций. В первую очередь это объясняется возможностью выбрать территорию рассылки, время и частоту оповещения сразу для всех абонентов. Кроме того, широковещательные сообщения не создают дополнительную нагрузку на сеть. Это очень важный момент, т.к. обычно во время возникновения чрезвычайных ситуаций сети операторов перегружаются через несколько минут после возникновения.

Для реализации данной технологии на сети оператора необходима установка нового элемента Cell Broadcast Centre (CBC) – центр широковещательной рассылки. Он предназначен для управления рассылкой сообщений (выбора области рассылки, времени, частоты повторений и т. п.). Также он хранит информацию о существующих сотах и их географической привязки. CBC не принадлежит ни одной из систем сети сотовой связи (NSS (Network Switching System) или BSS (Base Station System), CN (Core Network) или UTRAN (UMTS Terrestrial radio access network)) и является отдельно стоящим элементом. Введение технологии Cell Broadcast ни как не сказывается на системе коммутации. CBC подключается к одному или нескольким контроллерам базовых станций (BSC (Base Station Controller) или RNC (Radio Network Controller)). При рассылке широковещательных сообщений не требуется подтверждение о доставке, что значительно упрощает общую схему организации технологии Cell Broadcast. Таким образом, в случае возникновения необходимости отправки какого-либо сообщения в какую-то область CBC, сверяется с имеющейся у него базой данный и отправляет сообщение только к нужным контроллерам базовых станций, которые в свою очередь перенаправляют это сообщение к нужным сотам. Причем к каждому контроллеру идет не пачка сообщений, а лишь одно, которое потом дублируется по базовым станциям, которые в свою очередь отправляют их по сотам. Таким образом, обеспечивается минимальная загрузка ресурсов сети.

При использовании материалов ссылка на сайт обязательна

—С автором сайта можно связаться по e-mail: ipleto@gmail.com

Широковещательный канал

Широковещательный канал, широковещание (англ. broadcasting ) — метод передачи данных в компьютерных и социальных сетях, при котором поток данных (каждый переданный пакет в случае пакетной передачи) предназначен для приёма всеми участниками сети.

Широковещание в IP-сетях

broadcast

п ·TCP/IP широковещание (broadcast) возможно только в пределах одного сегмента сети (L2 или L3). Однако пакеты данных могут быть посланы из-за пределов сегмента, в который будет осуществлено широковещание (например, передача пакета на широковещательный IP-адрес через маршрутизатор из-за пределов сети). Нагрузка на сеть в случае широковещания не отличается от обычной передачи данных одному адресату, поскольку пакеты данных не размножаются (в отличие от групповой передачи, multicast).

Примером широковещания является определение MAC-адреса, соответствующего определенному IP-адресу (например, с помощью протокола ARP). В этом случае отправляется широковещательный пакет с запросом, который достигает все подключенные к данному L3-сегменту сети устройства. Устройство с искомым IP-адресом отправляет в ответ пакет, содержащий требуемый MAC-адрес.

Широковещание в социальных сетях

См. также

  • Широковещательный шторм
  • Широковещательный домен
  • Маршрутизация

Broadcast (Широковещательные сообщения)

Практическая часть показана в отдельной статье.

Иногда для правильной работы приложению следует знать о текущем заряде батареи или наличии интернета. Если делать проверку самостоятельно на постоянной основе, то на систему идёт большая нагрузка. Но в этом нет нужды, система сама следит за подобными вещами и готова поделиться со всеми нуждающимися своими сообщениями. Ваша задача — реализовать у себя широковещательный приёмник (Broadcast Receiver). Получатель трансляции всегда будет получать уведомления, независимо от состояния вашего приложения — работает ли ваше приложение в фоновом режиме или вообще не работает в данный момент.

Широковещательные сообщения делают приложение более открытым; передавая события, использующие сообщения, вы открываете компоненты своего приложения для сторонних приложений, и сторонние разработчики реагируют на события без необходимости изменять ваше оригинальное приложение. В своём приложении вы можете прослушивать широковещательные сообщения других приложений, заменить или улучшить функциональность собственного (или стороннего) приложения или реагировать на системные изменения и события приложений.

Вы тоже можете организовать отправку широковещательных сообщений, а другие приложения могут обзавестись приёмниками для обработки ваших сообщений.

Приёмник широковещательных сообщений — это компонент для получения внешних событий и реакции на них. Инициализировать передачи могут:

  • другие приложения или службы
  • сама система
  • ваше собственное приложение

Широковещательные сообщения можно разделить на две группы:

  • Неявная широковещательная трансляция (implicit broadcast) — сообщения рассылаются всем желающим, а не конкретно вашему приложению. Вам нужно только зарегистрироваться для получения этих сообщений через фильтр IntentFilter в манифесте. Система просматривает все объявленные фильтры намерений в вашем манифесте и проверяет, есть ли совпадение. Из-за этого поведения неявные широковещательные сообщения не имеют целевого атрибута
  • Явная трансляция (explicit broadcast) предназначена для конкретных приложений. В атрибуте target указывают имя пакета приложения или имя класса компонента, по которому можно найти получателя

Класс BroadcastReceiver является базовым для класса, в котором должны происходить получение и обработка сообщений, посылаемых клиентским приложением с помощью вызова метода sendBroadcast().

Зарегистрировать экземпляр класса BroadcastReceiver можно динамически в коде или статически в манифесте.

Для статической регистрации в файле манифеста в секции application следует создать секцию receiver и указать класс приёмника. Атрибут android:exported=»true» сообщает получателю, что он может принимать широковещательные сообщения вне области приложения. Внутри секции указывается фильтр намерений в виде строки, чтобы определить, какие сообщения приёмник должен прослушивать.

Если регистрация была сделана через манифест, приложение не обязано работать, чтобы ваш приёмник среагировал на трансляцию намерения. Приложение запустится автоматически, когда подходящие намерение будет транслировано. Система сама сканирует содержимое манифеста всех приложений и делает за нас всю работу. Это хорошее решение, позволяющее экономить ресурсы. Такой подход позволяет создавать приложения, способные реагировать на события даже после завершения или принудительного завершения.

Динамическая регистрация происходит с помощью метода Context.registerReceiver().

 this.registerReceiver(mTimeBroadCastReceiver, new IntentFilter( "android.intent.action.TIME_TICK")); 

Перед этим создаётся класс, расширяющий базовый класс BroadcastReceiver и реализуется метод обратного вызова onReceive() обработчика событий.

 public class TimeBroadcastReceiver extends BroadcastReceiver < public TimeBroadcastReceiver() < >@Override public void onReceive(Context context, Intent intent) < . >> 

Метод onReceive() будет выполнен при получении широковещательного намерения, если полученное намерение соответствует фильтру. Приложения с зарегистрированными приёмниками широковещательных намерений будут запущены автоматически при получении соответствующего намерения. Метод должен быть завершён в течение пяти секунд, иначе появится диалоговое окно о принудительном закрытии.

Когда широковещательное сообщение прибывает для получателя сообщения, Android вызывает его методом onReceive() и передаёт в него объект Intent, содержащий сообщение. Приёмник широковещательных сообщений является активным только во время выполнения этого метода. Процесс, который в настоящее время выполняет BroadcastReceiver, т. е. выполняющийся в настоящее время код в методе обратного вызова onReceive(), как полагает система, является приоритетным процессом и будет сохранён, кроме случаев критического недостатка памяти в системе.

Когда программа возвращается из метода onReceive(), приёмник становится неактивным и система полагает, что работа объекта BroadcastReceiver закончена. Процесс с активным широковещательным получателем защищён от уничтожения системой. Однако процесс, содержащий неактивные компоненты, может быть уничтожен системой в любое время, когда память, которую он потребляет, будет необходима другим процессам.

Это представляет проблему, когда ответ на широковещательное сообщение занимает длительное время. Если метод onReceive() порождает отдельный поток, а затем возвращает управление, то полный процесс, включая и порождённый поток, система Android считает неактивным (если другие компоненты приложения не активны в процессе), и считает этот процесс кандидатом на уничтожение.

В частности, вы не можете отобразить диалог или осуществить связывание со службой внутри экземпляра BroadcastReceiver. Для первого случая необходимо вместо этого использовать методы класса NotificationManager. Во втором случае можно использовать вызов метода Context.startService(), чтобы послать команду для запуска службы.

Решение этой проблемы возможно, если запустить в методе onReceive() отдельную службу вместе с BroadcastReceiver и позволить службе выполнять задание, чтобы сохранить содержание процесса активным в течение всего времени вашей операции.

Также можно зарегистрировать широковещательный приёмник не через манифест, а программно. Приёмник, зарегистрированный таким способом, будет отвечать на поступающие намерения только в том случае, если компонент приложения, которому он принадлежит, выполняется в этот момент.

Это может быть полезным, когда приёмник используется для обновления элементов пользовательского интерфейса внутри активности, запуска служб или уведомления через NotificationManager. В таких случаях вы можете отменять регистрацию широковещательного приёмника, если активность не отображается на экране или находится в неактивном состоянии.

В коде программы можете написать приблизительно такой код (обычно используют метод onResume()):

 // Создаём и регистрируем широковещательный приёмник IntentFilter filter = new IntentFilter(NEW_CAT_DETECTED); CatDetectedBroadcastReceiver receiver = new CatDetectedBroadcastReceiver(receiver, filter); 

Для отмены регистрации используется метод unregisterReceiver() в контексте приложения, передавая ему в качестве параметра экземпляр широковещательного приёмника (обычно в методе onPause()):

 unregisterReceiver(receiver); 

Для объекта BroadcastReceiver нет никаких возможностей видеть или фиксировать намерения, используемые в методе startActivity(). Аналогично, когда вы передали намерение для запуска активности через объект BroadcastReceiver, вы не сможете найти или запустить требуемую активность. Эти две операции семантически полностью различаются: запуск активности через намерение является приоритетной операцией для системы, изменяющей содержимое экрана устройства, с которым в настоящее время взаимодействует пользователь. Передача широковещательных сообщений для системы является фоновой работой, о которой обычно не знает пользователь и которая, соответственно, имеет более низкий приоритет.

Приёмники системных событий

Android использует широковещательные сообщения для системных событий, таких как уровень зарядки батареи, сетевые подключения, входящие звонки, изменения часового пояса, состояние подключения данных, входящие сообщения SMS или обращения по телефону. Вы можете использовать эти сообщения, чтобы добавлять к вашим собственным проектам новые функциональные возможности, основанные на системных событиях.

Следующий список показывает некоторые из встроенных действий, представленных как константы в классе Intent, которые используются для того, чтобы проследить изменения состояния устройства:

  • ACTION_BOOT_COMPLETED — передаётся один раз, когда устройство завершило свою загрузку. Требует разрешения RECEIVE_BOOT_COMPLETED
  • ACTION_CAMERA_BUTTON — передаётся при нажатии пользователем клавиши Camera
  • ACTION_DATE_CHANGED и ACTION_TIME_CHANGED — запускаются при изменении даты или времени на устройстве вручную пользователем
  • ACTION_SCREEN_OFF и ACTiON_SCREEN_ON — передаются, когда экран выключается или включается
  • ACTION_TIMEZONE_CHANGED — передаётся при изменении текущего часового пояса

Типы трансляций

Есть три способа отправки трансляций

  • Порядковые сообщения о намерениях (Ordered broadcasts), которые посылаются методом Context.sendOrderedBroadcast(). Эти сообщения посылаются только одному получателю за один раз. Поскольку каждое полученное сообщение выполняется по очереди, он может в случае необходимости полностью прервать сообщение, чтобы его не успели передать другим приёмникам. Приёмниками сообщений можно управлять с помощью атрибута android:priority фильтра сообщений; приёмники сообщений, имеющие одинаковый приоритет, будут выполнены в произвольном порядке.
  • Нормальные сообщения о намерениях (Normal broadcasts) — посылаемые вызовом метода context.sendBroadcast() и являющиеся полностью асинхронными. Все широковещательные приёмники получают сообщение и не зависят друг от друга. Это более эффективно, но означает, что получатели не могут использовать результат или прервать сообщение;
  • Метод LocalBroadcastManager.sendBroadcast() отправляет широковещательные сообщения только получателям, определённым в вашем приложении, и не выходит за рамки вашего приложения

Если важно, чтобы приёмники получали намерения в определённом порядке или могли влиять на транслируемое намерение, можно использовать метод sendOrderedBroadcast():

 String requiredPermission = "ru.alexanderklimov.MY_BROADCAST_PERMISSION"; sendOrderedBroadcast(intent, requiredPermission); 

С помощью этого метода ваше намерение дойдёт до всех зарегистрированных приёмников, обладающих необходимым доступом (если он был указан), в порядке их приоритета. Приоритет задаётся с помощью атрибута android:priority внутри узла фильтра намерений в манифесте. Чем больше значение, тем выше приоритет.

Производить упорядоченные трансляции с использованием приоритетов рекомендуется только для тех приёмников, которым необходим конкретный порядок приёма сообщений.

Ограничения в Android 8.0 Oreo (API 26)

Часть неявных (implicit) широковещательных сообщений, задаваемых через манифест, запретили. Теперь нужно регистрировать их программно. Существует список исключений, которые будут работать как прежде без ограничений.

В качестве замены для некоторых случаев подойдёт JobScheduler.

Примерами устаревшего способа работы с приёмником является android.net.conn.CONNECTIVITY_CHANGE, ACTION_POWER_CONNECTED и др.

Ограничения в Android 9.0 Pie (API 28)

Стало доступно меньше информации, получаемой при трансляции системы Wi-Fi и Network_State_Changed_Action.

Портал о современных технологиях мобильной и беспроводной связи

Портал о современных технологиях мобильной и беспроводной связи

MBMS – режим широковещательной передачи мультимедийных данных (Multimedia Broadcast Service). MBMS позволяет UTRAN контролировать пользовательские данные и управлять ими. В зависимости от числа пользователей выделяются два режима MBMS: двухточечный режим и широковещательный режим («точка-многоточка»). В первом случае передача мультимедийных данных (потоковое видео и аудио, загрузка файлов, повторные передачи по запросу) осуществляется для одного пользователя или для небольшой группы пользователей. Во втором случае осуществляется широковещательная трансляция этих данных. Скорость передачи данных при этом составляет 64 кбит/с. Пример реализации MBMS в UTRAN показан на рис.

Широковещательная передача данных MBMS

Рис. Широковещательная передача данных MBMS (a — unicast, b — broadcast/multicast)

Каналом трансляции данных при двухточечной передаче служит физический канал передачи трафика DPDCH, а при передаче «точка-многоточка» – вторичный общий физический канал управления S-CCPCH.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *