Применение Windows Embedded в SCADA системах

Павел Белевский

Журнал ИСУП

№ 4`2011

Введение

При автоматизации технологических и любых других процессов, связанных с постоянной обработкой данных о состоянии оборудования в целях оповещения и принятия решения при управлении этим оборудованием, широко используются специализированные системы сбора данных и мониторинга - SCADA-системы. И чем сложнее процесс, больше параметров, которые необходимо отслеживать, более технологично оборудование - тем более востребованным становится использование таких систем. В общем случае любая SCADA-система состоит из трех ключевых компонентов: устройств опроса и управления оборудованием, инфраструктуры для сбора и обработки данных и интерфейсной части для наглядного представления процесса в целом. В ходе реализации указанные компоненты фактически проецируются на комплекс устройств различной сложности, где самыми простыми, пожалуй, являются интерфейсные устройства. Поскольку практически все современные устройства, начиная с блока управления оборудованием и заканчивая сервером баз данных, обладают мощной вычислительной базой, то вполне остро встает вопрос выбора операционной системы. ОС в данном случае является тем важным звеном, которое позволяет быстро разворачивать компоненты доступных на рынке SCADA-систем на широком спектре коммерческого оборудования без каких-либо серьезных ограничений, что в свою очередь означает снижение затрат на разработку, внедрение и особенно обслуживание, по сравнению со случаем использования узкоспециализированного оборудования. В этой статье рассматриваются сценарии применения линейки встраиваемых ОС Windows Embedded, специализированных ОС компании Microsoft для устройств при развертывании SCADA-систем. Также описываются их возможностях и отличительных особенностях, которые могут быть востребованы в данной сфере.

Интерфейсные устройства

Интерфейсные устройства предоставляют некоторый человеко-машинный интерфейс (HMI) для оператора. Фактически такой интерфейс представляет собой запущенное на устройстве приложение, являющееся клиентской частью SCADA-системы. В подавляющем большинстве доступных на рынке SCADA-систем клиентская часть ориентирована на Windows-платформу. Таким образом, интерфейсные устройства строятся обычно на базе настольных ОС компании Microsoft. В ряде случаев такое решение будет неоправданным расточительством, а в других может поставить под угрозу безопасность и надежность устройства и всей системы в целом. Собственно, в целях расширения возможностей классических ОС Windows и повышения их производительности и надежности компанией Microsoft были выпущены специальные встраиваемые версии. На текущий момент это линейка ОС Windows Embedded Standard, состоящая из 2-х ключевых продуктов: Windows Embedded Standard 2009 и Windows Embedded Standard 7. Первая из них является компонентной версией Windows XP Professional SP3, вторая – Windows 7 SP1. Благодаря компонентности данных систем разработчик устройства, в нашем конкретном случае интерфейсного устройства для оператора SCADA-системы, может выбрать только тот функционал, который необходим для работы клиентского приложения SCADA, и тем самым сразу уменьшить количество потенциальных уязвимых мест. А следуя принципу «меньше функций - меньше используемых ресурсов», повысить производительности и надежность устройства. Несмотря на то что данные ОС являются компонентными, они полностью совместимы с настольными аналогами, что позволяет использовать все доступные драйвера и приложения. Кроме того, есть целый набор вспомогательных средств для встраивания в устройства, таких, как загрузка с USB, фильтры защиты от записи и подавления нежелательных сообщений, замена оболочки. В комплексе данные средства позволяют создавать законченные интерфейсные устройства, в которых можно будет полностью исключить движущиеся части за счет использования недорогих USB-носителей, обеспечить дополнительную отказоустойчивость и надежность с помощью фильтров защиты от записи и запуск устройства сразу в собственную оболочку или клиентское приложение SCADA, что также повышает надежность устройства, делая его закрытым от несанкционированного доступа через служебные функции ОС.

Если же проблема безопасности и отказоустойчивости стоит особенно остро, то здесь будет востребовано совместное использование встраиваемых ОС с последними достижениями в области виртуализации и новой версии протокола удаленного рабочего стола RDP 7.1. При использовании данных средств интерфейсные устройства представляют собой терминальные станции для доступа к терминальному серверу, на котором запускается сессия для работы с клиентской частью SCADA-системы и, возможно, выполнения каких-либо вспомогательных действий. Таким образом, за счет того, что оператор фактически работает в защищенной сессии на сервере, повышается безопасность, поскольку гораздо проще обеспечить безопасность сервера или пула серверов, чем большого количества отдельных клиентских систем, имеющих прямой доступ к инфраструктуре SCADA. При использовании данного подхода также повышается отказоустойчивость, так как в случае отказа отдельного интерфейсного устройства достаточно заново подключиться с любого другого устройства к запущенной ранее на сервере сессии без потери данных. Дополнительным преимуществом использования терминальных станций в качестве интерфейсных устройств является возможность существенного снижения требований к аппаратной части таких устройств, наращивание мощности при необходимости производится исключительно на стороне сервера. При использовании последней версии RDP-протокола, RDP 7.1, с поддержкой ускорения графики на стороне сервера и доступа к локальной USB-периферии непосредственно из сессии удаленного рабочего стола, возможности создаваемых интерфейсных устройств практически не уступают возможностях обычных систем. Поддержка протокола RDP7.1 реализована в Windows Embedded Standard 7 SP1 и в последней версии компактной ОС Windows Embedded Compact 7. Для запуска терминальной сессии вторая из перечисленных ОС является, пожалуй, наиболее интересным решением, поскольку предъявляет крайне низкие требования к аппаратной части разрабатываемого устройства и не ограничивает выбор лишь x86-архитектурой – это также может процессор ARM или MIPS. В результате устройство становится компактным, потребляющим чрезвычайно мало электроэнергии и при этом не требующее активной системы охлаждения, а значит, его можно встроить практически куда угодно: в монитор, в стол или стену.

Устройства опроса и управления оборудованием

Или, как их ещё иногда называют, оконечные устройства подключены непосредственно к оборудованию, выполняют сбор и передачу данных в SCADA о состоянии отдельного узла в общей цепочке контролируемого процесса, а также осуществляют управление данным узлом в соответствии с заложенным алгоритмом и, возможно, дополнительной информацией от SCADA-системы. Поскольку не всегда возможно обеспечить удаленное управление критическими узлами с требуемой задержкой, то первоочередной ролью SCADA в таких случаях является мониторинг. В соответствие с этим оконечные устройства должны обеспечивать управление подконтрольными узлами, в том числе и в автономном режиме, когда отсутствует связь с серверами SCADA-системы. Также на оконечные устройства накладываются определенные требования по работе в режиме реального времени, с тем чтобы обеспечить безотказное функционирование оборудования. На заре появления SCADA-систем оконечные устройства содержали достаточно простые микроконтроллеры, что не в последнюю очередь было обусловлено уровнем развития микропроцессорной индустрии на тот момент времени. Разработка таких устройств являлась достаточно затратным занятием, поскольку требовались дорогостоящие специализированные средства разработки и тестирования. Свойственное тому времени использование проприетарных протоколов для соединения со SCADA-системой отрицательно сказывалось на совместимости устройств различных производителей и поддержке со стороны SCADA-систем. Сейчас ситуация сильно изменилась благодаря широкому распространению недорогих производительных 32-х разрядных микропроцессоров и использованию операционных систем, что позволяет быстро разрабатывать многофункциональные универсальные оконечные устройства. Одними из таких систем являются встраиваемые ОС семейства Windows Embedded Compact, ключевой особенностью которых, помимо мультиплатформенности и компактности, является поддержка работы в режиме жесткого реального времени – неотъемлемое требование по управлению оборудованием в любом современном технологическом процессе. Богатый функционал данных компактных ОС, который практически не уступает по возможностям функционалу настольных систем, предоставляет широкие возможности для создания устройств любой сложности. Для состыковки оконечных устройств со SCADA-системой наиболее популярным на данный момент является интерфейс OPC DA. В Windows Embedded CE 6.0 есть компоненты удаленного DCOM, которые необходимы для реализации данного интерфейса, что позволяет на её базе разрабатывать OPC-сервера совместимые со всеми популярными SCADA-системами. В ОС семейства Windows Embedded Compact также есть все необходимые средства для реализации универсального интерфейса, основанного на XML, OPC UA. Если в устройстве требуется поддержка промышленных протоколов связи, например протокола Modbus, то есть достаточно широкий выбор готовых драйверов сторонних фирм, что способствует быстрому внедрению данных протоколов в устройстве.

Серверная инфраструктура и лицензирование

Последний неотъемлемый компонент любой SCADA-системы – это набор серверных приложений сбора данных с их последующей обработкой и хранением, а также возможность предоставления информации для приложений, реализующих клиентскую часть SCADA. Здесь, как и в случае с интерфейсными устройствами, востребованы ОС общего назначения. Если в качестве кандидатов рассматриваются серверные продукты компании Microsoft, то имеет смысл принять во внимание и встраиваемые версии. В линейке Windows Embedded доступны практически все системы, которые есть в стане классических серверных ОС. Функционал встраиваемых серверных ОС, за исключением нескольких специализированных продуктов, полностью идентичен функционалу соответствующих классических продуктов, а отличают их в основном условия лицензирования. Суть этих условий заключается в том, что встраиваемые ОС не могут быть использованы для построения универсальных систем, не имеющих четкой функциональной направленности. Например, их можно использовать для развертывания сервера баз данных SCADA, но нельзя на этом же сервере запускать такие, не имеющие отношение к SCADA сервисы, как публикация Web-сайта компании. Справедливо заметить, что подобные требования накладываются на все ОС Windows Embedded, тем самым подчеркивая их целевое назначение - построение устройств.

Резюме

Благодаря общим подходам к разработке, наличию специальных средств для встраивания в устройства и гибкой политике лицензирования встраиваемые ОС Windows Embedded являются отличным базисом при развертывании SCADA-систем. Windows Embedded Standard – это полная совместимость с настольными ОС со специальными возможностями для встраивания. Для компактных устройств с требованием работы в режиме реального времени и расширенной поддержкой коммуникаций - Windows Embedded Compact. И наконец, в решениях, где востребованы серверные технологии компании Microsoft, – линейка серверных ОС Windows Embedded Server.

Полный текст статьи

П.В. Белевский, ведущий специалист отдела исследований и разработок,

Департамент встраиваемых систем,

ООО «Кварта Технологии», г. Москва

info@quarta.ru

 

 


Подписка на новости