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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

От создания сайтов до разработки и реализации API

В издательстве «БХВ» недавно вышли книги, которые будут интересны системным администраторам, создателям

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

Разбор полетов  

Ошибок опыт трудный

Как часто мы легко повторяем, что не надо бояться совершать ошибки, мол,

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

Принципы проектирования  

Dependency Inversion Principle. Принцип инверсии зависимостей в разработке

Мы подошли к последнему принципу проектирования приложений из серии SOLID – Dependency

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

Рынок труда  

Вакансия: Администратор 1С

Администратор 1С – это специалист, который необходим любой организации, где установлены программы

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

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

Книги для профессионалов, студентов и пользователей

Книги издательства «БХВ» вышли книги для тех, кто хочет овладеть самыми востребованными

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

Принципы проектирования  

Interface Segregation Principle. Принцип разделения интерфейсов в проектировании приложений

Эта статья из серии «SOLID» посвящена четвертому принципу проектирования приложений – Interface

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

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

Секрет успешных людей

Книги издательства «БХВ» по ИТ рассчитаны на разные категории читателей: от новичков

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

Учебные центры  

Карьерные мечты нужно воплощать! А мы поможем

Школа Bell Integrator открывает свои двери для всех, кто хочет освоить перспективную

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

Гость номера  

Дмитрий Галов: «Нельзя сказать, что люди становятся доверчивее, скорее эволюционирует ландшафт киберугроз»

Использование мобильных устройств растет. А вместе с ними быстро растет количество мобильных

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

Прошу слова  

Твердая рука в бархатной перчатке: принципы soft skills

Лауреат Нобелевской премии, специалист по рынку труда, профессор Лондонской школы экономики Кристофер

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

1001 и 1 книга  
19.03.2018г.
Просмотров: 11234
Комментарии: 0
Потоковая обработка данных

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

19.03.2018г.
Просмотров: 9482
Комментарии: 0
Релевантный поиск с использованием Elasticsearch и Solr

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

19.03.2018г.
Просмотров: 9536
Комментарии: 0
Конкурентное программирование на SCALA

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

18.12.2013г.
Просмотров: 3337
Комментарии: 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-41
Fax: (499) 277-12-45
E-mail: sa@samag.ru