Обслуживание программного обеспечения

Модификация программного обеспечения после поставки

Сопровождение программного обеспечения — это модификация программного обеспечения после поставки. [1]

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

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

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

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

История

В начале 1970-х годов компании начали выделять поддержку программного обеспечения в отдельную команду инженеров, чтобы освободить команды разработчиков программного обеспечения от задач поддержки. [2] В 1972 году RG Canning опубликовал «The Maintenance 'Iceberg ' », в котором он утверждал, что поддержка программного обеспечения была расширением разработки программного обеспечения с дополнительным вводом: существующей системой. [2] Дисциплина поддержки программного обеспечения с тех пор мало изменилась. [3] Одним из нововведений двадцать первого века стало то, что компании намеренно выпускали неполное программное обеспечение и планировали завершить его после выпуска. Этот тип изменений и другие, которые расширяют функциональность, часто называют эволюцией программного обеспечения вместо поддержки. [3]

Жизненный цикл программного обеспечения

Схема традиционного жизненного цикла разработки программного обеспечения с 1988 года

Несмотря на тестирование и обеспечение качества , практически все программное обеспечение содержит ошибки , из-за которых система не работает так, как задумано. Послерелизное обслуживание необходимо для устранения этих ошибок, если они обнаружены. [4] Большая часть программного обеспечения представляет собой комбинацию уже существующих коммерческих готовых (COTS) и открытых программных компонентов с индивидуально написанным кодом. COTS и открытое программное обеспечение обычно обновляются с течением времени, что может снизить нагрузку на обслуживание, но изменения в этих программных компонентах необходимо будет скорректировать в конечном продукте. [5] В отличие от разработки программного обеспечения , которая сосредоточена на выполнении определенных требований, обслуживание программного обеспечения обусловлено событиями, такими как запросы пользователей или обнаружение ошибки. [6] Его главная цель — сохранить полезность программного обеспечения, как правило, перед лицом меняющихся требований. [7]

Если рассматривать обслуживание как часть жизненного цикла разработки программного обеспечения , то оно является последней и, как правило, самой продолжительной фазой цикла, [8] [9] составляющей от 80 до 90 процентов стоимости жизненного цикла. [10] Другие модели рассматривают обслуживание отдельно от разработки программного обеспечения, а не как часть жизненного цикла обслуживания программного обеспечения (SMLC). [9] Модели SMLC обычно включают понимание кода, его изменение и повторную проверку. [9]

Переход от выпуска к обслуживанию и окончанию срока службы

Диаграмма, показывающая шаги по выводу программного обеспечения из эксплуатации

Часто программное обеспечение поставляется в незавершенном состоянии. Разработчики будут тестировать продукт до тех пор, пока не закончится время или финансирование, поскольку они сталкиваются с меньшими последствиями за несовершенный продукт, чем при превышении времени или бюджета. [11] Переход от команды разработки к команде поддержки часто неэффективен, без списков известных проблем или проверочных тестов, которые команда поддержки, скорее всего, воссоздаст заново. [12] После выпуска члены команды разработки, скорее всего, будут переназначены или иным образом станут недоступны. Группе поддержки потребуются дополнительные ресурсы в течение первого года после выпуска, как для технической поддержки , так и для исправления дефектов, оставшихся от разработки. [11]

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

Цикл изменений

Первым шагом в цикле изменений является получение запроса на изменение от клиента и его анализ для подтверждения проблемы и принятия решения о том, следует ли внедрять изменение. [14] Для этого может потребоваться участие нескольких отделов; например, маркетинговая команда может помочь оценить, ожидается ли, что изменение принесет больше бизнеса. [15] Оценка усилий по разработке программного обеспечения является сложной проблемой, в том числе для запросов на изменение обслуживания, [16] но запрос, скорее всего, будет отклонен, если он слишком дорог или невыполним. [17] Если принято решение внедрить запрос, его можно назначить на запланированный релиз и внедрить. [17] Хотя гибкая методология не имеет фазы обслуживания, [18] цикл изменений может быть реализован как спринт Scrum . [19]

Понимание существующего кода является важным шагом перед его изменением. [3] Скорость понимания зависит как от кодовой базы, так и от навыков программиста. [20] Соблюдение соглашений о кодировании, таких как использование четких имен функций и переменных, которые соответствуют их назначению, облегчает понимание. [21] Использование условных операторов цикла только в том случае, если код может быть выполнен более одного раза, и исключение кода, который никогда не будет выполнен, также может повысить понятность. [22] Опытным программистам легче понять, что делает код на высоком уровне. [23] Иногда для ускорения этого процесса используется визуализация программного обеспечения . [24]

Модификация кода может происходить любым способом. С одной стороны, обычно бессистемно применяют быстрое исправление, не имея достаточно времени для обновления документации кода . [25] С другой стороны, жестко структурированное итеративное улучшение может начинаться с изменения документа с требованиями верхнего уровня и распространения изменения на более низкие уровни системы. [26] Модификация часто включает в себя рефакторинг кода (улучшение структуры без изменения функциональности) и реструктуризацию (одновременное улучшение структуры и функциональности). [27] В отличие от коммерческого программного обеспечения, циклы изменений бесплатного и открытого программного обеспечения в значительной степени ограничены кодированием и тестированием с минимальной документацией. Проекты программного обеспечения с открытым исходным кодом вместо этого полагаются на списки рассылки и большое количество участников для понимания кодовой базы и эффективного исправления ошибок. [28]

Дополнительная проблема с обслуживанием заключается в том, что почти каждое изменение кода приводит к появлению новых ошибок или неожиданных волновых эффектов , которые требуют еще одного раунда исправлений. [3] Тестирование может потреблять большую часть ресурсов обслуживания для критически важного для безопасности кода из-за необходимости повторной проверки всего программного обеспечения, если вносятся какие-либо изменения. [29] Повторная проверка может включать обзор кода , регрессионное тестирование с подмножеством модульных тестов , интеграционные тесты и системные тесты . [27] Целью тестирования является проверка того, что предыдущая функциональность сохранена, а новая функциональность добавлена. [30]

Категории обслуживания программного обеспечения

Основная цель обслуживания программного обеспечения — обеспечение того, чтобы продукт продолжал соответствовать требованиям удобства использования. Иногда это может означать расширение возможностей продукта за пределы того, что изначально предполагалось. [31]

Согласно спецификации ISO / IEC 14764, обслуживание программного обеспечения можно разделить на четыре типа: [32]

  • Корректирующее обслуживание : модификация программного обеспечения для исправления ошибки или другого несоответствия требованиям, о котором обычно сообщает конечный пользователь. [32] [33]
  • Профилактическое обслуживание : перспективная модификация программного обеспечения после поставки для обеспечения его дальнейшего соответствия требованиям или устранения проблем, которые еще не проявились. [34] [32] Этот тип обслуживания выполняется в первую очередь для систем, которые должны быть высокобезопасными или доступными. [34] Обновление программного обеспечения — одна из форм профилактического обслуживания для очистки состояния и предотвращения будущих проблем. [34]
  • Адаптивное обслуживание: модификация программного обеспечения, выполняемая после поставки, чтобы обеспечить его постоянную пригодность к использованию в измененной или меняющейся среде. [32] [34]
  • Идеальное обслуживание: улучшение программного обеспечения после поставки для улучшения таких качеств, как пользовательский опыт , эффективность обработки и удобство обслуживания . [34] [35] Идеальное обслуживание необходимо, если выполняются другие типы обслуживания, поскольку изменение существующей кодовой базы в противном случае увеличит сложность и приведет к ухудшению существующей структуры. [35] Идеальное обслуживание может включать в себя переписывание документации , рефакторинг кода и настройку производительности. [34]

По некоторым оценкам, усовершенствование (последние две категории) составляет около 80 процентов обслуживания программного обеспечения. [36]

Ремонтопригодность

Поддерживаемость — это качество программного обеспечения, позволяющее легко модифицировать его, не нарушая существующую функциональность. [32] Согласно спецификации ISO/IEC 14764, деятельность по обеспечению поддерживаемости программного обеспечения перед выпуском считается частью поддержки программного обеспечения. [6] Многие организации по разработке программного обеспечения пренебрегают поддерживаемостью, даже если это увеличит долгосрочные расходы. [37] Технический долг возникает, когда программисты, часто из-за лени или срочности, чтобы уложиться в срок, выбирают быстрые и грязные решения вместо того, чтобы встроить поддерживаемость в свой код. [38] Распространенной причиной является недооценка усилий по разработке программного обеспечения , что приводит к недостаточному выделению ресурсов на разработку. [39] Одним из важных аспектов является наличие большого количества автоматизированных тестов программного обеспечения , которые могут обнаружить, скомпрометирована ли существующая функциональность изменением. [32]

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

Рабочая сила

Техническое обслуживание часто считается неблагодарной работой для инженеров-программистов , которые, если их назначают на техническое обслуживание, с большей вероятностью увольняются. [42] [43] Зачастую эта работа оплачивается меньше, чем сопоставимая работа в сфере разработки программного обеспечения. [43] Задание часто поручают временным работникам или менее квалифицированному персоналу, [3] [44] хотя инженеры по техническому обслуживанию также обычно старше разработчиков, отчасти потому, что они должны быть знакомы с устаревшими технологиями. [44] В 2008 году около 900 000 из 1,3 миллиона инженеров-программистов и программистов, работающих в Соединенных Штатах, занимались техническим обслуживанием. [45]

Компании создали отдельные команды для обслуживания, что привело к аутсорсингу этой работы другой компании, а к началу двадцать первого века иногда к офшорингу работы в другую страну — будь то в рамках исходной компании или отдельной организации. [46] [10] Типичными источниками аутсорсинга являются развитые страны, такие как США, Великобритания, Япония и Австралия, в то время как пунктами назначения обычно являются страны с более низкой стоимостью труда, такие как Китай, Индия, Россия и Ирландия. [47] Причины офшоринга включают использование преимуществ более низких затрат на рабочую силу, обеспечение круглосуточной поддержки, снижение давления времени на разработчиков и перемещение поддержки ближе к рынку продукта. [48] Недостатки офшоринга включают коммуникационные барьеры в виде таких факторов, как часовой пояс , организационная разобщенность и культурные различия. [10] Несмотря на то, что многие работодатели считают техническое обслуживание низкоквалифицированной работой, а фазу разработки программного обеспечения наиболее подходящей для офшоринга, [10] [49] она требует тесного общения с заказчиком и быстрого реагирования, и то и другое затрудняется этими трудностями в общении. [10]

Альтернативы обслуживанию

В программной инженерии термин « унаследованная система» не имеет фиксированного значения, но часто относится к старым системам, которые являются большими, сложными для модификации, а также необходимыми для текущих бизнес-нужд. Часто устаревшие системы написаны на устаревших языках программирования , не имеют документации, имеют ухудшающуюся структуру после многих лет изменений и зависят от экспертов, чтобы поддерживать ее в рабочем состоянии. [50] При работе с этими системами в какой-то момент накапливается так много технического долга, что обслуживание становится непрактичным или экономически невыгодным. [13] Другие варианты включают:

  • Заморозка — не выполнять больше никаких работ в устаревшей системе. [51] Этот вариант можно выбрать, если поставщик хочет продолжать получать доход как можно дольше, избегая при этом расходов на обслуживание. [13]
  • Передача функциональности устаревшей системы на аутсорсинг другой компании, особенно если она не считается основной бизнес-функцией. [51]
  • Отказ от существующей устаревшей системы и переработка нового приложения с нуля для выполнения той же цели, что и устаревшая система. [51] Однако этот подход неэффективен из-за отказа от работающей системы, и при таком подходе существует опасность, что новая система не будет соответствовать изменяющимся бизнес-требованиям. [51]
  • Оборачивание устаревшего приложения в слой абстракции для упрощения устаревших интерфейсов. [51] Исходный код не изменяется, но новый интерфейс позволяет новым приложениям получать доступ к проверенному компоненту. Этот подход не решает ни одной из проблем с поддержкой устаревшей системы. [52] Базы данных, функции и целые приложения могут быть обернуты таким образом. [53]
  • Миграция устаревшей системы на новую платформу, которая может сократить расходы на разработку нового программного обеспечения за счет повторного использования реализации, дизайна, спецификации и требований устаревшей системы. [54] Миграция может занять от 5 до 10 лет, но приводит к большей гибкости и долгосрочной экономии на обслуживании программного обеспечения. [55] До 80 процентов расходов приходится на тестирование; то есть на обеспечение того, чтобы новая система имела тот же результат, что и старая система. [56] После завершения новой системы необходимо осуществить переход со старой системы на новую с минимальным нарушением бизнес-функций. [56]

Исследовать

Несмотря на то, что поддержка занимает львиную долю ресурсов разработки программного обеспечения, она является наименее изученной фазой разработки программного обеспечения. [57] [58] Большая часть литературы была сосредоточена на том, как разрабатывать поддерживаемый код с самого начала, при этом меньше внимания уделялось мотивации инженеров сделать поддерживаемость приоритетом. [59] По состоянию на 2020 год [update]автоматизированные решения для рефакторинга кода с целью сокращения усилий по обслуживанию являются активной областью исследований, [60] как и оценка поддерживаемости с помощью машинного обучения . [61]

Ссылки

  1. ^ [IEEE Std 610.12-1990, Глоссарий терминологии программной инженерии IEEE]
  2. ^ ab Tripathy & Naik 2014, стр. 25.
  3. ^ abcdef Оффутт, Джефф (январь 2018 г.). «Обзор обслуживания и эволюции программного обеспечения». Кафедра компьютерных наук Университета Джорджа Мейсона . Получено 5 мая 2024 г.
  4. ^ Трипати и Наик 2014, стр. 4.
  5. ^ Tripathy & Naik 2014, стр. 5–6.
  6. ^ ab Tripathy & Naik 2014, с. 26.
  7. ^ Мадхусудхан и др. 2017, с. 761.
  8. ^ Варга 2018, стр. 3.
  9. ^ abc Tripathy & Naik 2014, с. 7.
  10. ^ abcde Ulziit et al. 2015, с. 764.
  11. ^ ab Reifer 2012, стр. 22.
  12. ^ Рейфер 2012, стр. 21.
  13. ^ abc Tripathy & Naik 2014, с. 89.
  14. ^ Мадхусудхан и др. 2017, с. 763.
  15. ^ Трипатия и Найк 2014, с. 120.
  16. ^ Мадхусудхан и др. 2017, с. 762.
  17. ^ ab Tripathy & Naik 2014, с. 123.
  18. ^ Али и др. 2024, стр. 126.
  19. ^ Али и др. 2024, стр. 130.
  20. ^ Трипатия и Найк 2014, с. 296.
  21. ^ Трипати и Найк 2014, стр. 296–297.
  22. ^ Трипатия и Найк 2014, с. 309.
  23. ^ Трипатия и Найк 2014, с. 297.
  24. ^ Трипати и Найк 2014, стр. 318–319.
  25. ^ Tripathy & Naik 2014, стр. 85–86.
  26. ^ Трипатия и Найк 2014, с. 86.
  27. ^ ab Tripathy & Naik 2014, стр. 94.
  28. ^ Трипатия и Найк 2014, с. 59.
  29. ^ Рейфер 2012, стр. 5.
  30. ^ Трипатия и Найк 2014, с. 98.
  31. ^ Варга 2018, стр. 4.
  32. ^ abcdef Варга 2018, стр. 5.
  33. ^ Tripathy & Naik 2014, стр. 26–27.
  34. ^ abcdef Tripathy & Naik 2014, стр. 27.
  35. ^ ab Varga 2018, стр. 5–6.
  36. ^ Варга 2018, стр. 5 fn 4.
  37. ^ Варга 2018, стр. 12.
  38. ^ Варга 2018, стр. 6–7.
  39. ^ Варга 2018, стр. 7.
  40. ^ Варга 2018, стр. 7–8.
  41. ^ Варга 2018, стр. 9.
  42. ^ Мадхусудхан и др. 2017, с. 764.
  43. ^ ab Reifer 2012, стр. 7.
  44. ^ ab Reifer 2012, стр. 8.
  45. ^ Рейфер 2012, стр. 1.
  46. ^ Рахман и др. 2024, стр. 1.
  47. ^ Рахман и др. 2021, Предпосылки исследования.
  48. ^ Улзиит и др. 2015, стр. 763.
  49. ^ Рейфер 2012, стр. 2.
  50. ^ Tripathy & Naik 2014, стр. 187–188.
  51. ^ abcde Tripathy & Naik 2014, с. 188.
  52. ^ Трипатия и Найк 2014, с. 189.
  53. ^ Трипатия и Найк 2014, с. 191.
  54. ^ Трипати и Найк 2014, стр. 188–189.
  55. ^ Трипатия и Найк 2014, с. 195.
  56. ^ ab Tripathy & Naik 2014, с. 196.
  57. ^ Мадхусудхан и др. 2017, с. 759.
  58. ^ Улзиит и др. 2015, стр. 766.
  59. ^ Рейфер 2012, стр. 4–5.
  60. ^ Бакаис и Альшайеб 2020, стр. 459.
  61. ^ Альсолай и Ропер 2020, стр. 106-214.

Источники

  • Али, Мухаммад; Чима, Сериш Мунавар; Наз, Аммерха; Пирес, Иван Мигель (2024). «SAMSEF: гибкое обслуживание программного обеспечения с использованием Scrum Framework для повышения эффективности и результативности». Передовые практики и новые перспективы в области информационных систем и технологий . Конспект лекций по сетям и системам. Том 989. Springer Nature Switzerland. стр. 126–136. doi :10.1007/978-3-031-60227-6_11. ISBN 978-3-031-60226-9.
  • Альсолай, Хадеел; Ропер, Марк (2020). «Систематический обзор литературы по методам машинного обучения для прогнозирования ремонтопригодности программного обеспечения» (PDF) . Информационные и программные технологии . 119 : 106214. doi :10.1016/j.infsof.2019.106214.
  • Бакаис, Абдулрахман Ахмед Бобакр; Альшайеб, Мохаммад (2020). «Автоматический рефакторинг программного обеспечения: систематический обзор литературы». Журнал качества программного обеспечения . 28 (2): 459–502. doi :10.1007/s11219-019-09477-y.
  • Madhusudhan, V.; Suma, V.; Rao, Jawahar J. (2017). Software Maintenance: From the Perspective of Effort and Cost Requirement . Труды Международной конференции по инжинирингу данных и коммуникационным технологиям. Springer. С. 759–768. ISBN 978-981-10-1678-3.
  • Рахман, Ханиф Ур; да Силва, Альберто Родригес; Альзайед, Асад; Раза, Муштак (2024). «Систематический обзор литературы по решениям об офшоринге обслуживания программного обеспечения». Информационные и программные технологии . 172 : 107475. doi : 10.1016/j.infsof.2024.107475.
  • Рахман, Ханиф Ур; Раза, Муштак; Афсар, Палваша; Хан, Хабиб Улла (2021). «Эмпирическое исследование факторов, влияющих на решение об аутсорсинге приложений». IEEE Access . 9 : 58589–58608. Bibcode : 2021IEEEA...958589R. doi : 10.1109/ACCESS.2021.3073315. hdl : 10576/37687 . ISSN  2169-3536.
  • Рейфер, Дональд Дж. (2012). Рецепты успеха в обслуживании программного обеспечения . CRC Press. ISBN 978-1-4398-5167-8.
  • Трипати, Приядарши; Наик, Кширасагар (2014). Эволюция и сопровождение программного обеспечения: подход практикующего специалиста . Джон Уайли и сыновья. ISBN 978-0-470-60341-3.
  • Ulziit, Bayarbuyan; Warraich, Zeeshan Akhtar; Gencel, Cigdem; Petersen, Kai (2015). «Концептуальная структура проблем и решений для управления глобальным обслуживанием программного обеспечения». Журнал программного обеспечения: эволюция и процесс . 27 (10): 763–792. doi :10.1002/smr.1720.
  • Варга, Эрвин (2018). Распутывание обслуживания и эволюции программного обеспечения: нестандартное мышление . Springer. ISBN 978-3-319-71303-8.


Retrieved from "https://en.wikipedia.org/w/index.php?title=Software_maintenance&oldid=1249783350"