Mashup (гибрид веб-приложений) - Mashup (web application hybrid)

А МЭШ-ап (компьютерная промышленность жаргон ), в Веб-разработка, это страница в Интернете или же веб приложение который использует контент из более чем одного источника для создания единой новой службы, отображаемой в едином графическом интерфейсе. Например, пользователь может объединить адреса и фотографии филиалов своей библиотеки с картой Google для создания гибридного приложения.[1] Этот термин подразумевает простую и быструю интеграцию с частым использованием открытых интерфейсов прикладного программирования (открытый API ) и источники данных для получения расширенных результатов, которые не обязательно были исходной причиной создания необработанных исходных данных. Термин mashup первоначально происходит от создания чего-либо путем объединения элементов из двух или более источников. [2] В недавнем английском языке это может относиться к музыке, где люди легко комбинируют звук одной песни с вокальной дорожкой другой, тем самым объединяя их вместе, чтобы создать что-то новое.

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

В прошлые годы[когда? ], все больше и больше веб-приложений публикуют API-интерфейсы, которые позволяют разработчикам программного обеспечения легко интегрировать данные и функции SOA способом, вместо того, чтобы строить их сами по себе. Можно считать, что гибридные приложения играют активную роль в эволюции социальное программное обеспечение и Веб 2.0. Инструменты составления мэшапов обычно достаточно просты для использования конечными пользователями. Как правило, они не требуют навыков программирования и скорее поддерживают визуальное подключение Виджеты GUI, сервисы и компоненты вместе. Таким образом, эти инструменты способствуют новому видению Интернет, где пользователи могут внести свой вклад.[требуется разъяснение ]

Термин «мэшап» формально не определяется ни одним органом по стандартизации.[3]

История

Более широкий контекст истории Интернета обеспечивает основу для разработки гибридных приложений. Под Веб 1.0 модель, организации хранят данные о потребителях порталы и регулярно их обновлял. Они контролировали все данные о потребителях, и потребитель должен был использовать их продукты и услуги для получения информации.[нужна цитата ]

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

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

Типы мэшапов

Существует много типов гибридных приложений, таких как гибридные бизнес-приложения, клиентские гибридные веб-приложения и гибридные веб-приложения.[5] Самый распространенный вид гибридных приложений - это потребительские гибридные приложения, ориентированные на широкую публику.

  • Бизнес (или же предприятие) гибридные приложения определять приложения, которые объединяют свои собственные ресурсы, приложение и данные с другими внешними Веб-сервисы.[4] Они объединяют данные в единую презентацию и позволяют сотрудничать предприятиям и разработчикам. Это хорошо работает для гибкое развитие проект, который требует сотрудничества между разработчиками и заказчиком (или доверенным лицом клиента, обычно менеджером по продукту) для определения и реализации бизнес-требований. Корпоративные гибридные веб-приложения - это безопасные, визуально насыщенные веб-приложения, которые предоставляют полезную информацию из различных внутренних и внешних источников информации.
  • Потребительские гибридные приложения объединять данные из нескольких общедоступных источников в браузере и систематизировать их с помощью простого пользовательского интерфейса браузера.[6] (например.: Wikipediavision сочетает в себе Google Map и Wikipedia API)
  • Мэшапы данныхв отличие от клиентских гибридных приложений, объединяет похожие типы носителей и информацию из нескольких источников в единое представление. Сочетание всех этих ресурсов создает новый и особый веб-сервис который изначально не был предоставлен ни одним из источников.

По типу API

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

Типы данных

Функции

Активатор гибридных приложений

В технологии активатор гибридных приложений - это инструмент для преобразования несовместимых ИТ-ресурсов в форму, позволяющую их легко комбинировать для создания гибридного приложения. Средства поддержки Mashup позволяют применять мощные методы и инструменты (такие как платформы mashup) для комбинирования данных и сервисов с новыми видами ресурсов. Примером активатора гибридных приложений является инструмент для создания RSS канал из электронной таблицы (которую нелегко использовать для создания гибридных приложений). Многие редакторы mashup включают средства поддержки mashup, например, Presto Mashup Connectors, Convertigo Web Integrator или Мост Каспио.

Возможности создания гибридных приложений также называются «поставщиками услуг и инструментов, [sic] которые делают возможными гибридные приложения».[нужна цитата ]

История

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

Редакторы гибридных веб-приложений значительно упростили создание гибридных веб-приложений, значительно повысив продуктивность разработчиков гибридных веб-приложений и даже открыв разработку гибридных веб-приложений конечным пользователям и не ИТ-специалистам. Стандартные компоненты и соединители позволяют дизайнерам легко комбинировать ресурсы гибридных приложений самыми разными способами. Однако гибридные платформы мало что сделали для расширения объема ресурсов, доступных для гибридных приложений, и не освободили гибридные веб-приложения от их зависимости от хорошо структурированных данных и открытых библиотек (RSS каналы и паблик API ).

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

Интернет-ресурсы

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

Проблемы интеграции данных

При интеграции данных из разных источников необходимо решить ряд проблем. Проблемы можно разделить на четыре группы: несоответствие текста и данных, несоответствие идентификаторов объектов и схемы, несоответствие уровня абстракции, точность данных.[7]

Несоответствие текста и данных

Большая часть данных описана в тексте. Человеческий язык часто неоднозначен - одна и та же компания может упоминаться в нескольких вариантах (например, IBM, International Business Machines и Big Blue). Неопределенность затрудняет создание перекрестных ссылок со структурированными данными. Кроме того, данные, выраженные на человеческом языке, трудно обрабатывать с помощью программного обеспечения. Одна из функций интеграция данных Система предназначена для преодоления несоответствия между документами и данными.[7]

Идентичность объекта и отдельные схемы

Структурированные данные доступны во множестве форматов. Таким образом, перевод данных в общий формат данных является первым шагом. Но даже если все данные доступны в едином формате, на практике источники различаются по тому, как они констатируют один и тот же факт. Различия существуют как на уровне отдельных объектов, так и на уровне схемы. В качестве примера несоответствия на уровне объекта рассмотрим следующее: SEC использует так называемый центральный индексный ключ (CIK) для идентификации людей (генеральных директоров, финансовых директоров), компаний и финансовых инструментов, в то время как другие источники, такие как DBpedia ( версия Википедии со структурированными данными), используйте URI для идентификации сущностей. Кроме того, каждый источник обычно использует свою собственную схему и особенности для констатации одного и того же факта. Таким образом, должны существовать методы для согласования различных представлений объектов и схем.

Уровни абстракции

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

Качество данных

Качество данных является общей проблемой при автоматической интеграции данных из автономных источников. В открытой среде агрегатор данных практически не влияет на публикатора данных. Данные часто ошибочны, и объединение данных часто усугубляет проблему. Ошибочные данные, особенно при выполнении рассуждений (автоматического вывода новых данных из существующих), могут иметь разрушительное влияние на общее качество результирующего набора данных. Следовательно, проблема заключается в том, как издатели данных могут координировать свои действия для устранения проблем с данными или сайтами черных списков, которые не предоставляют надежные данные. Методы и приемы необходимы для: проверки целостности и точности; выделить, идентифицировать и подтвердить доказательства; оценить вероятность того, что данное утверждение верно; уравнять весовые различия между секторами рынка или компаниями; создать клиринговые центры для возбуждения и урегулирования споров между конкурирующими (и, возможно, конфликтующими) поставщиками данных; и взаимодействовать с беспорядочными ошибочными веб-данными потенциально сомнительного происхождения и качества. Таким образом, ошибки в обозначениях, количестве, маркировке и классификации могут серьезно затруднить использование систем, работающих с такими данными.

Мэшапы против порталов

Мэшапы и порталы оба агрегирование контента технологии. Порталы - это более старая технология, разработанная как расширение традиционных динамические веб-приложения, в котором процесс преобразования содержимого данных в размеченные веб-страницы делится на два этапа: создание «фрагментов» разметки и объединение фрагментов в страницы. Каждый фрагмент разметки создается с помощью символа "портлет ", и портал объединяет их в одну веб-страницу. Портлеты могут размещаться локально на сервере портала или удаленно на отдельном сервере.

Технология портала определяет полную модель событий, охватывающую чтения и обновления. Запрос на объединенную страницу на портале преобразуется в отдельные операции чтения для всех портлетов, образующих страницу ("оказывать"операции на местных, JSR 168 портлеты или "getMarkup"операции на удаленном, WSRP портлеты). Если на любом портлете на странице портала нажимается кнопка отправки, она преобразуется в операцию обновления только для этого портлета (processAction на локальном портлете или выполнитьBlockingInteraction на удаленном портлете WSRP). После обновления сразу же следует чтение все портлеты на странице.

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

Мэшапы отличаются от порталов следующим образом:

ПорталМЭШ-ап
КлассификацияСтарая технология, расширение традиционной модели веб-сервера с использованием четко определенного подходаИспользует новые, нечетко определенные методы "Web 2.0".
Философия / подходПодходит к агрегированию, разделяя роль веб-сервера на два этапа: создание разметки и агрегация фрагментов разметки.Использует API-интерфейсы, предоставляемые разными информационными сайтами, для агрегирования и повторного использования содержимого другим способом.
Зависимости контентаАгрегирует фрагменты разметки, ориентированные на представление (HTML, WML, VoiceXML и т. Д.)Может работать с чистым XML-контентом, а также с презентационно-ориентированным контентом (например, HTML)
Зависимости от местоположенияТрадиционно агрегация контента происходит на сервере.Агрегация контента может происходить как на сервере, так и на клиенте.
Стиль агрегации"Салат-бар "стиль: агрегированный контент отображается" бок о бок "без наложений."Плавильный котел "style - индивидуальный контент можно комбинировать любым способом, в результате чего получается произвольно структурированный гибридный контент.
Модель событийМодели событий чтения и обновления определяются через специальный API портлета.CRUD операции основаны на ОТДЫХ архитектурные принципы, но формального API не существует
Соответствующие стандартыПоведение портлета регулируется стандартами JSR 168, JSR 286 и WSRP, хотя макет страницы портала и функциональность портала не определены и зависят от поставщикаБазовые стандарты XML заменяются как ОТДЫХ или веб-службы. RSS и Атом обычно используются. Более конкретные стандарты гибридных приложений, такие как EMML появляются.

Модель портала существует дольше и требует больших инвестиций и исследований продукта. Таким образом, портальная технология является более стандартизированной и зрелой. Со временем возрастающая зрелость и стандартизация технологии mashup, вероятно, сделают ее более популярной, чем технология порталов, поскольку она более тесно связана с Web 2.0, а в последнее время Сервис-ориентированные архитектуры (SOA).[8] Ожидается, что в новых версиях продуктов портала в конечном итоге будет добавлена ​​поддержка гибридных приложений, но при этом будут поддерживаться устаревшие приложения с портлетами. В отличие от этого не ожидается, что технологии Mashup будут поддерживать стандарты порталов.

Мэшапы для бизнеса

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

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

Многие поставщики технологий гибридных бизнес-приложений добавили SOA Особенности.

Архитектурные аспекты гибридных приложений

Архитектура мэшапа разделена на три уровня:

Архитектурно существует два стиля гибридных приложений: веб-интерфейс и серверный. В то время как веб-гибридные приложения обычно используют пользовательский веб-браузер для объединения и переформатирования данных серверные гибридные приложения анализируют и переформатируют данные на удаленном компьютере. сервер и передать данные в браузер пользователя в окончательном виде.[10]

Мэшапы кажутся разновидностью узор фасада.[11] То есть: шаблон проектирования программной инженерии, который обеспечивает упрощенный интерфейс для большей части кода (в данном случае кода для агрегирования различных каналов с разными API ).

Мэшапы можно использовать с программным обеспечением, предоставляемым как услуга (SaaS ).

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

Смотрите также

Рекомендации

  1. ^ Фихтер Дарлин, Что такое мэшап?http://books.infotoday.com/books/Engard/Engard-Sample-Chapter.pdf (Проверено 12 августа 2013 г.)
  2. ^ "МЭШ-ап". merriam-webster.com.
  3. ^ «Корпоративные гибридные приложения: новое лицо вашей SOA». http://soa.sys-con.com/: МИРОВОЙ ЖУРНАЛ SOA. Получено 2010-03-03. Термин mashup не подлежит формальному определению ни одним органом по стандартизации.
  4. ^ а б Кларкин, Ларри; Холмс, Джош. «Корпоративные мэшапы». Журнал архитектуры MSDN. Центр архитектуры MSDN.
  5. ^ Сунилкумар Пеникал (2009). «Мэшапы и предприятие» (PDF). MphasiS - HP. Архивировано из оригинал (PDF) на 2013-06-02. Получено 2010-02-27.
  6. ^ «Корпоративные гибридные приложения: новое лицо вашей SOA». http://soa.sys-con.com/: МИРОВОЙ ЖУРНАЛ SOA. Получено 2010-03-03. Мэшап для потребителей - это приложение, которое объединяет данные из нескольких общедоступных источников в браузере и организует их с помощью простого пользовательского интерфейса браузера.
  7. ^ а б Э. Карри, А. Харт и С. О'Райен, «Проблемы, стоящие перед конвергенцией финансовых данных», В архиве 2012-07-18 в Archive.today в материалах семинара XBRL / W3C по улучшению доступа к финансовым данным в сети, 2009 г.
  8. ^ Дигна, Ларри (2007). «Gartner: будущее порталов - это гибридные приложения, SOA и агрегация». ZDNET.
  9. ^ Холт, Адамс (2009). «Исполнительный ИТ-архитектор, бизнес-сценарии и шаблоны Mashup». IBM DeveloperWorks.
  10. ^ Болим, Майкл (2005). "Программирование для конечных пользователей в Интернете, диссертация MIT MS, 2,91 МБ PDF" (PDF). С. 22–23.
  11. ^ Паттерны проектирования: элементы объектно-ориентированного программного обеспечения многократного использования (ISBN  0-201-63361-2) Эрих Гамма, Ричард Хелм, Ральф Джонсон и Джон Влиссидес

дальнейшее чтение