Overview » History » Version 6
Sergey Groshev, 02/05/2010 01:44 PM
1 | 5 | Sergey Groshev | h1. Aspectrace - технология расширяемой аспектно-ориентированной трассировки. |
---|---|---|---|
2 | 1 | Sergey Groshev | |
3 | 5 | Sergey Groshev | {{toc}} |
4 | 1 | Sergey Groshev | |
5 | h2. Назначение проекта |
||
6 | |||
7 | 5 | Sergey Groshev | Инструментарий аспектно-ориентированной трассировки *Aspectrace* предназначен прежде всего для разработчиков и тестировщиков, которым нужны средства мониторинга работы сложных приложений или тестов для них. Система Aspectrace предоставляет возможность собирать в форме *трасс* (логов) *разнородную* и *структурированную* информацию, по мере необходимости расширяя набор собираемой информации, после чего гибко и эффективно выбирать из полученной трассы нужные данные, анализировать их, связывать между собой и строить на их основе разнообразные отчёты. |
8 | 1 | Sergey Groshev | |
9 | 5 | Sergey Groshev | Технология поддерживает расширяемый формат трассы. Для работы с информацией нужного вида клиент подключает соответствующий модуль (называемый _библиотекой аспекта_), который предназначен для работы с ней; аспект определяет собственную модель данных и собственные типы трассируемых сообщений. Различные аспекты могут подключаться приложениями (как генерирующими трассу, так и анализирующими её) независимо друг от друга. |
10 | 1 | Sergey Groshev | |
11 | 5 | Sergey Groshev | Предоставляется компонентная инфраструктура отчётов, позволяющая гибко собирать нужные пользователю генераторы отчётов из компонентов (как готовых библиотечных, так и разработанных под конкретную задачу), анализирующих различные срезы информации. Предоставляются механизмы, облегчающие связывание данных, извлечённых из трассы разными компонентами. |
12 | 4 | Sergey Groshev | |
13 | 1 | Sergey Groshev | Также поддерживаются подключаемые модули, задающие внешние представления и способы хранения трассы. |
14 | |||
15 | h2. Ключевые свойства |
||
16 | |||
17 | # *Универсальность:* |
||
18 | 5 | Sergey Groshev | Технология не привязана к какой-либо предметной области, классу приложений, способу тестирования (если мониторинг совмещён с тестированием), языку программирования, платформе или способу хранения данных. |
19 | # *Структурированность данных:* |
||
20 | Поддерживается сброс в трассу структурированной информации и извлечение её с сохранением структуры. |
||
21 | 1 | Sergey Groshev | # *Расширяемость:* |
22 | 5 | Sergey Groshev | Структура трассы и архитектура системы допускают добавление новых видов информации без дополнительных накладных расходов и без необходимости перекомпиляции старых приложений. Также возможен прозрачный выбор нужных (в зависимости от особенностей целевого приложения и его окружения) способов внешнего хранения и передачи трассы или добавление новых таких способов. |
23 | 1 | Sergey Groshev | # *Модульность:* |
24 | 5 | Sergey Groshev | Приложение, генерирующее трассу, сбрасывает в неё только ту информацию, которую разработчик может собрать и считает существенной. По мере необходимости можно добавлять сброс новых видов информации. |
25 | 1 | Sergey Groshev | Приложение, анализирующее трассу, выбирает из неё только понятную ему и существенную для него информацию, безболезненно (как по ресурсам, так и с точки зрения согласованности данных) игнорируя все остальное. Архитектура системы позволяет легко настраивать, какую информацию брать из трассы, какими способами её обрабатывать и как связывать между собой, что позволяет создавать легко настраиваемые отчёты, собираемые из готовых компонентов. |
26 | # *Простота связывания:* |
||
27 | 5 | Sergey Groshev | Предоставляются средства, обеспечивающие автоматическое связывание разнородной информации при анализе трасс. |
28 | 1 | Sergey Groshev | # *Унификация:* |
29 | Стандартные виды информации, используемые в различных предметных областях, трассируются и обрабатываются в унифицированном виде, что позволяет легко разрабатывать как собственные библиотеки аспектов, так и универсальные анализаторы трассы, обрабатывающие информацию из разных аспектов. |
||
30 | # *Гибкость трассировки и анализа:* |
||
31 | Возможность легко настраивать, что трассировать, а что нет; какую информацию брать из трассы, как её анализировать, как связывать между собой и как представлять. |
||
32 | |||
33 | h2. Архитектура |
||
34 | |||
35 | 4 | Sergey Groshev | !Aspectrace_architecture.gif! |
36 | 1 | Sergey Groshev | |
37 | 6 | Sergey Groshev | На рисунке изображены компоненты и поток информации через них. |
38 | 1 | Sergey Groshev | |
39 | 6 | Sergey Groshev | *Аспектные трассировщики* и *аспектные адаптеры* входят в соответствующие библиотеки аспектов (на рисунке библиотеки разных аспектов обозначены разными текстурами) и подключаются приложениями при необходимости. Сообщения трассы, относящиеся к аспекту, для которого не подключён адаптер (и, соответственно, обработчики), игнорируются поставщиком трассы и не подвергаются дальнейшей обработке. |
40 | |||
41 | *Трассировщик* и *Поставщик трассы* - инфраструктурные компоненты, непосредственно поддерживающие расширяемый формат трассы. Приложения взаимодействуют с ними не напрямую, а через библиотеки аспектов. Также возможно связывание этих двух компонентов (а через них - генераторы и анализаторы трассы) напрямую в одном адресном пространстве, без промежуточных внешних представлений трассы. |
||
42 | 4 | Sergey Groshev | |
43 | 5 | Sergey Groshev | h1. Примеры использования |
44 | 1 | Sergey Groshev | |
45 | source:trunk/src/java/com/unitesk/aspectrace/sampleApp |
||
46 | |||
47 | 4 | Sergey Groshev | MainApp.java - приложение, генерирующее трассу, а потом строящее по ней HTML-отчёт. |
48 | В этом же пакете содержатся примеры компонентов генератора отчётов, обрабатывающие информацию от некоторых аспектов, способные гибко связываться между собой и обмениваться информацией. Эти компоненты используются также в других проектах. |
||
49 | |||
50 | 5 | Sergey Groshev | h1. Ссылки на более подробные документы |
51 | 1 | Sergey Groshev | |
52 | source:trunk/docs/Aspectrace_manual.doc |
||
53 | |||
54 | |||
55 | h1. Ссылки для скачивания |
||
56 | |||
57 | 4 | Sergey Groshev | Файлы поставки можно скачать "здесь":http://forge.ispras.ru/projects/list_files/aspectrace |
58 | 1 | Sergey Groshev | |
59 | 4 | Sergey Groshev | Данный проект зависит от проекта "coverage":http://forge.ispras.ru/projects/show/coverage , файлы поставки которого можно скачать "здесь":http://forge.ispras.ru/projects/list_files/coverage |