Платформа Flexberry с открытым кодом для профессиональной разработки ПО::Журнал СА 10.2018
www.samag.ru
     
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
  Статьи

Дата-центры  

Дата-центры: есть ли опасность утечки данных?

Российские компании уже несколько лет испытывают дефицит вычислительных мощностей. Рост числа проектов,

 Читать далее...

Книжная полка  

Защиты много не бывает

Среди книжных новинок издательства «БХВ» есть несколько изданий, посвященных методам социальной инженерии

 Читать далее...

Событие  

В банке рассола ждет сисадмина с полей фрактал-кукумбер

Читайте впечатления о слете ДСА 2024, рассказанные волонтером и участником слета

 Читать далее...

Организация бесперебойной работы  

Бесперебойная работа ИТ-инфраструктуры в режиме 24/7 Как обеспечить ее в нынешних условиях?

Год назад ИТ-компания «Крок» провела исследование «Ключевые тренды сервисного рынка 2023». Результаты

 Читать далее...

Книжная полка  

Читайте и познавайте мир технологий!

Издательство «БХВ» продолжает радовать выпуском интересных и полезных, к тому же прекрасно

 Читать далее...

СУБД PostgreSQL  

СУБД Postgres Pro

Сертификация по новым требованиям ФСТЭК и роль администратора без доступа к данным

 Читать далее...

Критическая инфраструктура  

КИИ для оператора связи. Готовы ли компании к повышению уровня кибербезопасности?

Похоже, что провайдеры и операторы связи начали забывать о требованиях законодательства

 Читать далее...

Архитектура ПО  

Архитектурные метрики. Качество архитектуры и способность системы к эволюционированию

Обычно соответствие программного продукта требованиям мы проверяем через скоуп вполне себе понятных

 Читать далее...

Как хорошо вы это знаете  

Что вам известно о разработках компании ARinteg?

Компания ARinteg (ООО «АРинтег») – системный интегратор на российском рынке ИБ –

 Читать далее...

Графические редакторы  

Рисование абстрактных гор в стиле Paper Cut

Векторный графический редактор Inkscape – яркий представитель той прослойки open source, с

 Читать далее...

День сисадмина  

Учите матчасть! Или как стать системным администратором

Лето – время не только отпусков, но и хорошая возможность определиться с профессией

 Читать далее...

День сисадмина  

Живой айтишник – это всегда движение. Остановка смерти подобна

Наши авторы рассказывают о своем опыте и дают советы начинающим системным администраторам.

 Читать далее...

Виртуализация  

Рынок решений для виртуализации

По данным «Обзора российского рынка инфраструктурного ПО и перспектив его развития», сделанного

 Читать далее...

Книжная полка  

Как стать креативным и востребованным

Издательский дом «Питер» предлагает новинки компьютерной литературы, а также книги по бизнесу

 Читать далее...

1001 и 1 книга  
19.03.2018г.
Просмотров: 6437
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7132
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4414
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3094
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3891
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3908
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6395
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3240
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3538
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7375
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10731
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12452
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14113
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9202
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7148
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5454
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4688
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3503
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3216
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3454
Комментарии: 0
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3097
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 Платформа Flexberry с открытым кодом для профессиональной разработки ПО

Архив номеров / 2018 / Выпуск №10 (191) / Платформа Flexberry с открытым кодом для профессиональной разработки ПО

Рубрика: Разработка /  Инструменты

Алексей Костарев АЛЕКСЕЙ КОСТАРЕВ, ООО «Новая Платформа», г. Пермь

Игорь Братчиков ИГОРЬ БРАТЧИКОВ, ООО «Новая Платформа», г. Пермь

Платформа Flexberry с открытым кодом
для профессиональной разработки ПО

Платформа Flexberry с открытым кодом для профессиональной разработки ПОВ статье рассматривается разрабатываемая на принципах свободного программного обеспечения платформа Flexberry – платформа для проектирования, разработки и поддержки сложных информационных систем

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

Введение

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

Программная платформа Flexberry вобрала в себя богатый опыт создания информационных систем на протяжении многих лет развития. Платформа предоставляет методику работы проектной команды и технические инструменты для ее реализации.

Основная часть

Типы информационных систем

Информационные системы классифицируются по различным параметрам [1]. Обобщение опыта компаний-партнеров позволило выделить виды информационных систем, которые чаще других создаются компаниями на заказ, именно этивиды информационных систем поддерживаются платформой Flexberry:

  • комплексные учетные системы;
  • автоматизация бизнес-процессов и документооборота;
  • веб-приложения;
  • мобильные приложения;
  • интеграционные информационные системы;
  • аналитические системы;
  • геоинформационные системы.

Дополнительно следует отметить, что платформа базируется на свободном ПО и открытых технологиях. Компоненты платформы также разрабатываются в открытых репозиториях под свободной лицензией. Это позволяет создавать открытые решения с использованием платформы.

Задачи платформы

На основе анализа выполненных проектов был составлен список задач, направленных на оптимизацию процесса проектирования, разработки и сопровождения информационных систем:

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

Основа методики проектирования и разработки

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

  • исходный код программы (подход Code First [2]);
  • структура данных приложения (подход Database First [3]);
  • пользовательский интерфейс (подход UI-First [4]);
  • формализованная каким-либо образом модель приложения (подход Model First [5]).

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

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

Подход Database First позволяет наиболее оптимальным образом приготовить структуру данных под бизнес-процессы. Также в этом случае бизнес-аналитикам, способным понимать SQL или пользоваться инструментами работы с СУБД, становится доступной информация о проектируемой информационной системе.

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

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

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

В основе технологии создания систем на платформе Flexberry лежат подход Model First и архитектура, управляемая моделью

Подход Model First позволяет абстрагироваться от конкретных элементов архитектуры информационной системы (код, база данных, пользовательский интерфейс) и оперировать некоторой абстракцией, предоставляющей необходимый уровень детализации информации по элементам архитектуры. Основное достоинство заключается в том, что модель понятна всем участникам проектной команды, является некоторым универсальным языком общения.

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

В основе технологии создания систем на платформе Flexberry лежат подход Model First и архитектура, управляемая моделью (Model Driven Architecture) [6]. В рамках этой архитектуры сначала с помощью редактора в формате UML или визуального конструктора форм создается модель предметной области проектируемого приложения. По модели создается прототип работающего приложения методом кодогенерации. Данный прототип дорабатывается программистами. Затем эта модель уточняется в ходе развития и поддержки проекта, эти изменения прозрачным образом автоматически переносятся в реализованное приложение.

Процесс разработки с использованием Flexberry включает в себя следующие этапы (см. рис. 1):

  • Анализ и проектирование с построением различных UML-моделей.
  • Генерация на основе созданных моделей базы данных и кода.
  • Подключение готовых функциональных подсистем.
  • Ручная доработка кода.
  • Демонстрация Заказчику прототипа приложения.
  • Детализация требований, постановок.
  • Модификация UML-моделей, перегенерация кода.
  • Выпуск версии продукта, переход к поддержке и сопровождению.

Рисунок 1. Упрощенная схема процесса проектирования и программирования

Рисунок 1. Упрощенная схема процесса проектирования и программирования

Архитектура платформы

Архитектура системы включает в себя (см. рис. 2):

  • инструментарий по проектированию и программированию системы (этап проектирования – Design-Time);
  • набор компонентов для создания информационной системы (этап исполнения программы – Run-Time).

Рисунок 2. Основные архитектурные компоненты платформы

Рисунок 2. Основные архитектурные компоненты платформы

Генераторы кода (см. рис. 3) позволяют на основе модели приложения получать исходный код приложения. Сгенерированное приложение является работоспособным приложением и может быть запущено без необходимых доработок [7].

Рисунок 3. Архитектура инструментария проектирования Flexberry Designer

Рисунок 3. Архитектура инструментария проектирования Flexberry Designer

Платформа включает в себя следующие программные компоненты:

  • Flexberry Designer – CASE-инструмент, реализующий стандартную нотацию UML и визуальный (WYSIWYG) конструктор форм приложения;
  • Flexberry Ember – фреймворк для создания веб- и гибридных мобильных приложений;
  • Flexberry GIS – функциональная подсистема хранения, создания, редактирования, анализа и отображения географической информации;
  • Flexberry Service Bus – сервисная шина – средство интеграции систем посредством обмена сообщениями (docker-образ);
  • Flexberry Analytics – функциональная подсистема отчётности и бизнес-аналитики (docker-образ);
  • Flexberry BPM – технология для быстрой автоматизации рабочих процессов в компании (набор docker-образов)
  • и другие компоненты.

Разработка и координация распределенной группы разработчиков платформы производится в git-репозитории https://github.com/Flexberry. Платформа открыта для подключения новых участников к процессу ее разработки.

Поддержка процесса разворачивания и сопровождения

Разработанный продукт разворачивается в виде стека docker-сервисов, включающего в себя следующие сервисы:

  • Ember-приложение с Odata backend;
  • сервис базы данных Postgres.

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

REST-интерфейс OData позволяет построить микросервисную архитектуру вокруг единой точки предоставления данных.

База данных Postgres является «стандартом de-facto» при создании систем на основе открытого программного обеспечения.

Docker-технология позволяет нам интегрировать данные сервисы в конечное кластерное решение нашей платформы [8, 9].

При необходимости в стек, функционирующий в составе кластера, могут быть включены дополнительные функциональные подсистемы платформы Flexberry в виде docker-сервисов:

  • Flexberry GIS,
  • Flexberry Service Bus,
  • Flexberry Analytics,
  • Flexberry BPM,
  • и другие.

Заключение

Оптимизация процесса проектирования, разработки и сопровождения информационных систем реализуется при помощи программной платформы Flexberry за счет следующих возможностей:

  • подхода Model First и архитектуры управляемой моделью;
  • инструментария визуальной разработки модели приложения, включающего метаданные для хранилища, бизнес-логики и пользовательского интерфейса приложения;
  • инструментария быстрого создания прототипов необходимого программного решения за счет кодогенерации;
  • реализованных готовых программных компонент и готовой архитектуры;
  • поддержка Docker для быстрого разворачивания информационных систем.
  1. Информационная система: [Электронный ресурс] // Википедия. URL: https://ru.wikipedia.org/wiki/Информационная_система (дата обращения: 01.09.2018).
  2. Code First в новой базе данных: [Электронный ресурс] URL: https://docs.microsoft.com/ru-ru/ef/ef6/modeling/code-first/workflows/new-database (дата обращения: 01.09.2018).
  3. Database-First Approach: [Электронный ресурс] URL: https://www.devart.com/entitydeveloper/database-first.html (дата обращения: 01.09.2018).
  4. UI-First Software Development: [Электронный ресурс] URL: https://blog.codinghorror.com/ui-first-software-development/ (дата обращения: 01.09.2018).
  5. Bennedsen, Jens & Caspersen, Michael. (2018). A Model-First Approach to Teaching Object-Orientation.
  6. Архитектура, управляемая моделью: [Электронный ресурс] // Википедия. URL: https://ru.wikipedia.org/wiki/Архитектура,_управляемая_моделью (дата обращения: 01.09.2018).
  7. Шмидт И.А., Архитектура платформы для разработки бизнес-приложений.// «Современные проблемы науки и образования», № 6, 2014 г. – С. 348.
  8. Docker as Platform for Assignments Evaluation, 25th DAAAM International Symposium on Intelligent Manufacturing and Automation, DAAAM 2014
  9. Docker: [Электронный ресурс] URL: https://www.docker.com/ (дата обращения: 01.09.2018).
  10. Технологическая программная платформа Flexberry – http://flexberry.ruhttps://github.com/Flexberry.

Ключевые слова: проектирование, процесс разработки, программная платформа, Model Driven Architecture, кодогенерация, UML-инструментарий.


Комментарии отсутствуют

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

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru