Диссертация (1148251), страница 23
Текст из файла (страница 23)
ПЕРЕОПРЕДЕЛЕНИЕ В АСПЕКТЕ МЕТОДА ЗАПУСКА ПРИЛОЖЕНИЯ APPLICATION.RUN()СредстваАОП-программирования,втомчислеиAspect.NET,предоставляют механизмы замены вызова целевого метода на действие аспекта.Дляподменысозданияклассазамещающегонаследникамыэтимивоспользовались, однако, в вышеупомянутом случае ситуация осложняется тем,что “целевым” является весь блок using.
Для таких ситуаций предназначен нашмеханизм замены целевого класса замещающим наследником. Результирующийкод аспекта в сокращенном виде приведен ниже:[AspectDotNet.ReplaceBaseClass]public partial class AspectMain : Main {private RetryManager retryManager;public AspectMain(RetryManager retryManager) {this.retryManager = retryManager;}private void ExecuteQueryButton_Click(object sender, EventArgs e) {//...try {using (var connection = newSqlConnection(ConfigurationManager.ConnectionStrings["Northwind"].ConnectionString)) {connection.Open();var command = new SqlCommand("dbo.GetProductDetails",connection){ CommandType = CommandType.StoredProcedure };// …Заполнение параметров command…var policy = this.retryManager.GetRetryPolicy<HolSqlTransientErrorDetectionStrategy>("HOL Strategy");policy.Retrying += (s, a) = >Log.Invoke(this, new object [] {“Попытка новогосоединения…”});policy.ExecuteAction(() = > {using (var reader = command.ExecuteReader()) {while (reader.Read()) {//…Обрабатываем результат успешного запроса}}});}} catch (Exception ex) {//… }}}ЛИСТИНГ 58.
ЗАМЕЩАЮЩИЙ АСПЕКТНЫЙ НАСЛЕДНИК ДЛЯ ОБРАБОТКИ ИСКЛЮЧЕНИЙ1286.5 Выводы по главеВ данной главе представлены основные принципы бесшовного расширенияфункциональности облачных веб-приложений с помощью Aspect.NET исторонних библиотек. В результате разрывается зависимость между целевымприложением, применяемой АОП-системой и сторонней библиотекой, чтопозволяет заменить их в любой момент прозрачно для целевого приложения. Приэтом сторонняя библиотека предоставляет классы для реализации сквознойфункциональности, а Aspect.NET средства для их интеграции в целевоеприложение. В качестве сторонней библиотеки выбрана Microsoft EnterpriseLibrary Integration Pack, функциональные блоки которой позволили бесшовновнедрить в веб-приложение сквозную функциональность протоколирования,автоматического масштабирования нагрузки и динамически конфигурируемойстратегии реакции на исключения.Для бесшовной интеграции сквозной функциональности в ряде случаевдостаточно основных средств Aspect.NET, а именно замещающего аспектногонаследника и %instead, %after, %before-действий.
Но иногда замещающийаспектный наследник должен вызывать закрытый метод своего базового класса. Вэтом случае необходимо использовать рефлексию .NET. В том случае, когдапроисходит несколько таких вызовов, оптимальным будет сохранение ссылок наметаданные соответствующего закрытого метода в полях аспектного наследникаи их инициализация в конструкторе.В том случае, когда замещающий аспектный наследник должен иметьконструкторы отличные от базового класса (например, для инициализациизависимостей от Microsoft Enterprise Library), необходимо %instead-действиямизаменить и вызовы всех его конструкторов в целевом коде.В результате для бесшовной интеграции Microsoft Enterprise Library вцелевое веб-приложение достаточно создать новый проект с аспектом, установитьMicrosoft Enterprise Library в него с помощью менеджера расширений Nuget,написать код аспекта и в свойствах проекта задать события пред-компиляции дляслияния XML-настроек и пост-компиляции для слияния с целевой сборкой.129ЗаключениеОблачныетехнологиипозволяютразрабатыватьнадежные,производительные и безопасные веб-приложения.
По мере того как облачныепровайдеры снижают стоимость своих услуг, всё большее число приложенийадаптируются для выполнения на облачных серверах. Платформа Microsoft Azureявляется одним из технологических лидеров на этом рынке, её выбирают тепрограммисты, которые привыкли к экосистеме Microsoft и её продуктам: VisualStudio, .NET, Windows, SQL Server, ASP.NET, Node.JS и другим технологиямсоздания веб-приложений. В рамках Microsoft Azure предлагается множествосервисов, реализующих такую функциональность как: распределенный кэш,мониторинг и автоматическое масштабирование на основе собранной статистики,авторизация и т.п.
Использовать эти сервисы может любое приложение, однакопри этом возникает проблема “сквозной функциональности”, когда кодобращения к соответствующим компонентам распределен по всей системе. Этоприводит к размытию ответственности классов и нарушению принциповслабосвязанной архитектуры. При этом бизнес-логика перемешивается снефункциональными требованиями, система теряет гибкость и затрудняется еёсопровождение. Традиционно для улучшения дизайна системы программистыприменяют рефакторинг, паттерны ООП и IoC-контейнеры, однако в случаесквознойфункциональностиэффективнымиоказываютсятолькоАОП-технологии.В диссертации произведен тщательный анализ и сравнение существующихсовременных облачных сервисов и платформ.
Выявлено, что платформа MicrosoftAzure является наиболее перспективной из них. Далее в данной работепредлагается (и реализуются в виде библиотек) ряд идей, позволяющих сделатьнаписание и сопровождение программного кода Microsoft Azure удобнее,качественнее, безопаснее и быстрее.130В ходе диссертационного исследования, проведены эксперименты сзамером коэффициента сопровождаемости [118] как на тестовых программах, таки на программе, решающей крупную промышленную задачу.ПредложенспособинтеграциикомпоновщикааспектовAspect.NETв Microsoft Visual Studio для обеспечения возможности публикации, а такжелокальной и удаленной отладки в облаке Azure АОП-программ.Длявозможностипредложенаконцепциябесшовногоприменения“замещающего”аспектоваспектноговAspect.NETнаследника,которыйпозволяет перехватывать обратные вызовы методов от инфраструктуры MicrosoftAzure.Такжепредложенораздельноехранениецелевойиаспектнойконфигурации, а для этого разработан алгоритм по их слиянию при компиляцииаспектного проекта.
Данные предложения реализованы в программном комплексеAspect.NET.Разработанадля расширенияиреализованаоблачныхбиблиотекавеб-приложенийаспектовAzureLibraryследующимивидамифункциональности: перенаправление протоколирования в хранилище отладочнойинформации Microsoft Azure, кэширование в распределенном облачном кэшеинформации, получаемой из SQL Azure, и обработки исключений. ПрименениеAzureLibrary и Aspect.NET приводит к добавлению новой функциональностибез какой-либо модификации целевого проекта.Разработана методика бесшовной интеграции сквозной функциональностибиблиотеки Microsoft Enterprise Library Integration Pack for Azure в целевоеприложение на примере аспектов логгирования (Logging Application Block),автоматическогомасштабированияоблачногоприложения(AutoscalingApplication Block), реакции на исключительные ситуации (Transient FaultHandling).
Данные аспекты также реализованы в рамках библиотеки AzureLibrary;Разработана методика улучшения индекса сопровождаемости (MaintanabilityIndex) целевых классов с помощью проведения их АОП-рефакторинга.Спроектирован набор из 5 аспектно-ориентированных рефакторинговна основе Aspect.NET для классов облачных веб-приложений.
Проведенные131эксперименты над типичными веб-приложениями (N2CMS и Orchard CMS)показали улучшение индекса сопровождаемости целевых классов на значения от 2до 25%.Все полученные результаты являются новыми. Разработанные авторомпрограммные инструменты успешно протестированы, внедрены в работупредприятий и используются в настоящее время, что подтверждается актами овнедрении (см.
Приложение). Зафиксирован существенный технический эффектиспользованияпредложенныхалгоритмовиметодовпринаписанииисопровождении программных продуктов.РазработаннаяавторомбиблиотекааспектовнаосновеAspect.NET(AzureLibrary), впервые позволила расширить функциональность облачных вебприложений, не затрагивая их исходный код, конфигурационные файлы илинастройки проекта.
В свою очередь предложенные принципы АОП-рефакторингана основе Aspect.NET позволяют разрабатывать слабосвязанные компоненты,характеризующиеся высокой степенью повторного использования. В результатеполучаются веб-приложения с высокой производительностью, которые легкосопровождать, и они не привязаны к конкретному АОП-инструменту.Таким образом, в данном исследовании применен принципиально новыйподход к разработке облачных веб-приложений на платформе Microsoft Azure.Его преимуществами является бесшовное добавление функциональности к вебприложениям, высокая производительность, улучшение качества исходного кодаивозможность использованиясуществующихстороннихэффективной реализации сквозной функциональности.библиотекдля132Список литературы1.1cloud, home page [Electronic resource].
–– URL:https://1cloud.ru/product/panel-upravleniya (online; accessed: 2016-05-20).2.Ahmadi, R. Aspect Oriented Programming Using C# and PostSharp [Electronicresource]//MSDN magazine. — 2014. — С. 10 URL:http://www.codeproject.com/Articles/337564/Aspect-Oriented-ProgrammingUsing-Csharp-and-PostS (online; accessed: 2016-05-20).3.Alves, P. Avoiding code pitfalls in aspect-oriented programming [Text] /AlvesP., Figueiredo E., Ferrari F. //Programming Languages. – Springer InternationalPublishing, 2014. – P. 31-46.4.Amazon EC2 Container Service, home page [Electronic resource].