Java на производстве
Современным технологиям естественно присущ потенциал совершенствования того, что было сделано до их появления. В этой статье речь пойдет о введении в 1995 г компанией Sun Microsystems программного обеспечения и языка программирования, что сопровождалось такими усовершенствованиями, как независимость от платформы/операционной системы, возможность многократного использования программных приложений, поддержка связи Web-узлов и опора на промышленные стандарты.
За этим последовали довольно скромные успехи, несмотря на то, что произошло поразительное по масштабу развертывание Интернет и Web-коммуникаций в промышленности. Именно это в настоящее время определяет привлекательность технологии Java для передачи информации внутри сети между производственным участком и системой управления предприятием. Но для того, чтобы технология Java была более успешной, необходимо решить ряд проблем, связанных с реальным временем и детерминизмом.
Программное обеспечение, основанное на технологии Java, имеет ряд преимуществ для пользователей в промышленности. Поль Беннисон, отвечающий за вопросы развития предприятия в компании Schneider Electric-IAC Services, на первое место ставит независимость от аппаратной платформы и операционной системы. В этой связи он отмечает совместимость Java с платформами Microsoft Windows/Intel и другими широко распространенными альтернативами, такими как ARM и процессор AMD 64-bit Opteron, а также операционные системы Linux и VxWorks. Далее он поясняет, что ”врожденная поддержка” технологией Java таких ИТ стандартов передачи информации внутри предприятия как SQL, XML, Web-службы, открытые каналы связи БД и т.д. также помогают перекинуть мост между производством и руководством предприятия.
В качестве еще одного преимущества Беннисон отмечает „масштабируемую, модульную модель развертывания” Java. Так, например, она может улучшить возможность существующей системы ПЛК фиксировать и передавать данные о процессе/производстве на управляемое оборудование. „Кроме того, эта информация сразу доступна как локальным, так и удаленным пользователям. Это позволяет своевременно осуществлять поддержку решений, которые визуально представляются оператору на портативный браузер или как предупреждение по электронной почте, или непосредственно на удаленную систему диспетчерского управления предприятием”, – отмечает Беннисон.
Он также добавляет: „В 1996 г. компания Schneider Electric была одним из первых поставщиков средств промышленной автоматизации, который сделал программное обеспечение Java, Ethernet и Web-службы основными функциональными возможностями, встроенными в уровень управления архитектуры автоматизации, называемый теперь Transparent Ready”. На сегодняшний день во все оборудование автоматизации и управления, произведенное компанией, встроены агенты диагностики Java для удаленного мониторинга приборов. Таким образом, как утверждают в компании Schneider, любой пользователь на предприятии может получить информацию через HTTP, диагностику через разрешающий браузер Java и определяемые пользователем Web-страницы, если он находится в зоне ограничения межсетевого экрана компании и конфигурации обеспечения ИТ безопасности.
Объединяем оборудование предприятия
По утверждению доктора Бернарда Трэверсета, старшего технического руководителя в компании Sun Microsystems, среди новых разработок создателя Java Sun Microsystems можно назвать платформу Java 2 Enterprise Edition (J2EE), включающую Java Connector Architecture (JCA). Она расширила возможности интеграции программного обеспечения с оборудованием предприятия на основе различных протоколов на основе TCP/IP. Раньше приложения J2EE давали пользователям интерфейс на основе Web через HTML и HTTP, однако слишком общий интерфейс с браузером „тонкого” клиента был недостаточно надежным для типичной производственной среды. „Теперь, с использованием Java Server Faces, J2EE может гарантировать более мощные интерфейсы на основе той же технологии „тонкого” клиента”, – говорит доктор Трэверсет.
Он также отмечает, что протоколы Web-служб представляют развивающийся стандарт связи B2B, которому должны соответствовать серверы приложения J2EE для того, чтобы гарантировать возможность взаимодействия сетей. Более того, Web-службы (WS) и их принципы совместимы с распределенными архитектурами типичного промышленного оборудования. Таким образом, WS становятся эффективной моделью связи между цехами и управлением предприятия для выполнения таких задач, как графики/состояние производства, требования к материалам, информация о качестве и материально-техническое обеспечение.
Трэверсет также упоминает версию 5.0 J2SE (Standard Edition) компании Sun и её библиотеку новых утилит взаимосовместимости. С её помощью совершенствуются „структурные компоненты потока” Java с целью более эффективного использования технологии Java в алгоритмах управления комплексными процессами, моделирования и автоматизации. J2SE 5.0 также способствует повышению качества функционирования и масштабируемости Java, так как сокращает время запуска и использование памяти. Эти особенности, по словам Трэверсета, „повышают жизнеспособность Java на небольших компьютерах, которые обычно применяются на производстве”.
Джон Бэйер, руководитель подразделения архитектуры программного обеспечения в компании Rockwell Automation, считает J2EE несомненным достижением в технологии Java в большей степени благодаря тому, что она упрощает создание интерфейсов Web-служб, жизненно необходимых для разработки распределенных производственных приложений. Наряду с таким преимуществом как популярность Java в качестве языка интеграции для MES-приложений, Бэйер называет переносимость Java на различные платформы, что позволяет применять один и тот же код в различных конфигурациях. Он также отмечает такую особенность технологии Java, как возможность её установки в небольших устройствах (и портативных вычислительных блоках), которые полезны на производстве.
По мнению Бенни Энгера, вице-президента подразделения по разработке программного обеспечения в компании GE Fanuc Automation, преимущества технологии Java (и схем XML) являются ключевыми для стратегии взаимодействия с бизнес-системами и мобильными устройствами. Выгода, которую получают пользователи, заключается в том, что снижаются издержки на интеграцию, расширяется функциональность и сокращается время отклика. Энгер объясняет это тем, что пользователи могут получать, анализировать и реагировать на события с самых разных устройств. В этом заключается расширение стратегии Proficy в GE Fanuc.
Энгер утверждает, что новое программное обеспечение, которое будет разработано GE Fanuc, позволит, например, загружать рабочие наряд-заказы на телефоны с двухсторонней связью, поддерживаемые Java. Это свяжет пользователей с рабочими нарядами и позволит обновить состояние сервера Proficy.
Майк Хьюстон, разработчик приложений компании Visiprise Inc., поставщика программного обеспечения управления производством, согласен с тем, что независимость от платформы, совместимая прикладная среда J2EE и поддержка стандартов дополняют список новых полезных возможностей технологии Java. Независимость от платформы дает пользователям возможность выбора оборудования и операционной системы по их желанию, в то время как J2EE предлагает рабочую среду с программным интерфейсом приложения (API) и общим языком разработки.
„Большая часть серверов J2EE, использующихся в промышленности, создают условия для быстрой и надежной работы производственных программ, – отмечает Хьюстон. – Java представляет собой открытую базовую платформу со встроенной поддержкой многих стандартов”. Серверы приложений обычно поддерживают такие стандарты как XML, HTTP, WS и др. для того, чтобы облегчить интеграцию с системами управления станками, ERP и другими системами. Visiprise Manufacturing, MES-программа компании на основе J2EE, предназначена для того, чтобы служить инструментом связи между системами цеха и предприятия.
В Visiprise также отмечают, что настройка и поддержка модулей программы, написанных на языке Java, легче по сравнению с менее открытой средой. „Работа с кодом Java идет быстрее и, в большинстве случаев, она более экономична”, – добавляет к сказанному Хьюстон.
Работа в реальном времени, безопасность
При внедрении в производство системы управления немаловажным вопросом является вопрос работы в реальном масштабе времени (RT). Самое простое объяснение реального времени сводится к тому, что для выполнения этого требования реакция системы управления должна обязательно быть получена в точных временных границах, установленных приложением.
Бэйер из компании Rockwell говорит о развитии приложений реального времени с использованием технологии Java, однако он советует особое внимание уделять процессу. При этом он называет две основные проблемы, которые вызывают беспокойство. Во-первых, с целью ускорения работы в приложениях реального времени часто используется компилированная Java. В этом случае надежные коды Java должны быть написаны так, чтобы они были ближе к операционной системе, поскольку, как объясняет Бэйер, интерпретацию виртуальной машины Java (JVM) нельзя использовать в RT части программы. Во-вторых, для функции управления памятью Java (сборка мусора) может потребоваться добавление слоя реального времени, который предоставляется поставщиками программного обеспечения (см. приложение „Основы Java” для получения дополнительной информации по вопросам JVM и „сборки мусора”). „Для работы в реальном времени необходимо рассмотреть полностью всю среду прикладной системы. Проблемы с языком представляют только часть общей картины”, – добавляет Бэйер.
В плане предложений Java для приложений реального времени компания Sun Microsystems сосредоточивает основное внимание на надежной обработке децентрализованных данных, что чрезвычайно важно для производственного процесса, и дополняет характеристики датчиков разнообразными усовершенствованными функциями, такими как синхронизация времени до субмикросекундного уровня. API Распределенный сбор данных и управление Java (Java Distributed Data Acquisition and Control – JDDAC) из программы Java System RFID компании Sun „действительно связывает любой датчик” с администратором событий RFID (RFID Event Manager). Трэверсет отмечает: „JDDAC гарантирует, что датчики и исполнительные устройства обладают такой характеристикой как самоописание и легко поддерживаются как объединенные в сеть объекты”.
В процессе решения проблем работы в режиме реального времени экспертная группа производителей программ от организации Java Community Process (JCP) разрабатывает спецификации Real-Time для Java (RTSJ), которые наряду с другими свойствами включают RT-потоки и асинхронные события. Компания Sun Microsystems недавно выпустила реализацию RTSJ. И все же в настоящее время необходима доработка RT-приложений для работы в режиме реального времени, особенно для встроенных систем. Примером может служить детерминированная сборка мусора. Другой организацией, которая активно занимается разработками в области RT Java, является Open Group.
Хотя внутрицеховая сеть менее доступна и более защищена, чем сети предприятия, она все же подвержена кибератакам. Для защиты от несанкционированного доступа, как поясняет Беннисон из компании Schneider Electric, требуется многочисленные средства, к ним относятся цифровая сертификация, шифрование на уровне защищенного сокета (SSL) и, конечно, соответствующие уровни доступа законного пользователя. В этом могут оказать помощь характеристики технологии Java.
По словам Беннисона „платформа Java позволяет встроить защиту на уровне модульности отдельного устройства управления. Встроенный сервер Java и Virtual Machine (или защищенный шлюз) ограничивают доступ к источнику информации”. Поскольку весь трафик проходит через защищенный шлюз, то отсутствует прямой доступ к отдельному устройству управления. Информация поступает от безопасных Web-серверов, доступных при соответствующих правах доступа. Беннисон утверждает, что представления Web-страницы обеспечивают доступ, разрешая вмешательство оператора с полной записью изменений.
Он выделяет три уровня масштабируемой конфигурации безопасности технологии Java. Безопасный означает использование безопасного шлюза, ограничивающего трафик, невозможность прямого доступа к устройству, невозможность доступа без авторизации и регистрацию всего доступа. Открыты только необходимые порты; все неиспользуемые порты защищены. „Модель „песочницы” Java (защищенной среды исполнения) гарантирует, что не произойдет загрузки вредоносного кода, переполнения буфера и тому подобных событий”, – добавляет к сказанному Беннисон.
Более безопасный уровень относится к модели „Web-служб”, в которой доступ осуществляется с помощью одного протокола (HTTP), ограничивающего варианты атаки. Модель „песочницы” работает так же, как и описанная выше. Управление внесением исправлений необходимо только в очень редких случаях. Самый безопасный уровень означает, что применяется зашифрованный доступ к любой части системы. Могут использоваться безопасный HTTP, физическая/биометрическая идентификация, отпечатки пальцев и другие методы.
В компании Sun полагают, что охват соединениями всего предприятия и производство по жесткому графику делают завод уязвимым и, соответственно, влекут за собой необходимость расширения мер безопасности и обеспечения связи. Трэверсет предлагает несколько возможных вариантов решения этой проблемы. Явное ограничение возможностей исполнения программы Java в соответствии с требуемым профилем („песочницей”) помогает ограничить потенциальное повреждение вычислительной системы. Неукоснительная аутентификация пользователей и систематический контроль их доступа к специфическим функциям и данным – это еще один шаг, так же, как и тщательное ведение контрольного журнала. Введение API для всех основных каналов, а также методов шифрования на основе сообщений повышают уровень защиты данных во время их передачи.
Продукты, приложения
Для развития современной технологии необходимо сотрудничество. Партнер Sun, компания Mitsubishi Electric Corp. из Японии, в сотрудничестве с технологической компанией Cyberonix Inc. из США создала контроллер автоматизации на основе технологии Java (JAC). Производимый в настоящее время JAC использует драйверы связи/адаптеры, написанные на языке Java, для соединения различных автоматических устройств в цехе и связи цеха и отдела обработки документации или для других приложений восходящего потока данных. Один порт Ethernet 10/100 Мбит/с осуществляет передачу восходящего потока, в то время как четыре последовательных порта (3 – для RS-232, 1 – для RS-485) обеспечивают прохождение нисходящего потока данных. Для передачи сообщений используется XML или другие общие форматы. На первом фото в этой статье представлена демонстрационная версия интеграции Java в производственную цепочку поставок. Здесь JAC работает как встроенный информационный шлюз реального времени, обеспечивающий пополнение истощившихся запасов компакт-дисков и связь с роботом Mitsubushi RV-1A, регуляторами Q-Platform, серворегуляторами J2 и устройствами передачи восходящего потока данных.
В компании Schneider Electric отмечают удачное решение в области технологии Java, которое используется в компании Heinkel USA (производитель центрифуг для фармации, работающих под регулирующим воздействием). Сообщается, что встроенные ПЛК-модули Quantum с JVM увеличивают эксплуатационный ресурс одноузловой SCADA-системы производства компании Heinkel до 10 лет по сравнению с максимальным сроком службы традиционной SCADA-системы, не превышающим 3 – 5 лет. Замена подтвержденного приложения SCADA предполагает большие затраты. „Надежное Web-приложение снижает стоимость подтверждения и продлевает срок службы приложения SCADA. Таким образом, затраты на обеспечение работы и обслуживания центрифуги снижаются на всем протяжении ее жизненного цикла”, – утверждают в компании Schneider.
Несколько лет назад технология Java получила известность в результате большой рекламной кампании производственных приложений. В последнее время на производственном фронте все довольно спокойно, или, возможно, Java ушла в тень. Благодаря новым разработкам в области технологии Java и творческому подходу к решению проблем работы в реальном времени, Java вскоре снова может выйти на авансцену.
Первое знакомство с основами технологии Java Технология Java представляет собой многопоточную, ориентированную на применение и развитие среду, в которой используется объектно-ориентированный язык, сходный по синтаксису с C или C++, однако она упрощает и совершенствует характеристики этих языков. Программы, написанные на Java, являются масштабируемыми и переносимыми на различные аппаратные платформы и операционные системы. Конструкция Java поддерживает распределенную архитектуру, основанную на использовании Web и Интернета. Она, в основном, работает как сервер, загружающий приложения по запросу клиента. Java также поддерживает различные протоколы шифрования и аутентификации. Отличительной особенностью Java является то, что программы не запускаются напрямую на собственной операционной системе (ОС). Вместо этого Виртуальная машина Java (JVM) располагается между платформой и ОС как „интерпретатор”, что позволяет программам исполняться на любой компьютерной системе, имеющей специфическую JVM. Компилятор Java сначала переводит программу в байтовый код, а затем JVM интерпретирует ее в соответствии со специфической платформой. Эта особенность является одной из мер укрепления безопасности системы, поскольку прежде чем поступить на центральный процессор, апплеты Java отображаются в защищенной области памяти или „песочнице”. Для повышения эффективности таких приложений, как системы реального времени (RT), возможен обход JVM. В этом случае JIT-компилятор (компилятор реального времени) переводит программы в машинный код непосредственно во время работы приложения. Однако это происходит за счет снижения переносимости. Другой специфической чертой технологии Java является автоматическая „сборка мусора” (GC) или управление памятью, когда учитывается любая область памяти, не задействованная программой. С одной стороны это освобождает разработчиков от решения этой немаловажной задачи, но с другой – вносит неопределенность в приложения реального времени, так как невозможно предсказать продолжительность циклов алгоритмов GC. Для поддержки приложений реального времени используются различные динамические и детерминированные методы сборки мусора, планирование потоков и другие методы очистки . |
ребят, вышел очень классный инструментарий для разработке на Java LogicMonitor. он будет помогать выявлять ошибки. серьезно облегчит работу. почитайте здесь http://www.issoft.by/reliz-besplatnogo-instrumentariya-ot-logicmonitor/ прикольная штуа. может, и на ваших лекциях пригодится.
Спасибо за информацию. Может быть, Вы напишете для нас статью по данной теме?