SDLC модели: как выбрать правильный подход к разработке и не завалить проект
В этой статье Вадим Кулага, проектный менеджер EPAM Anywhere, расскажет об основных моделях разработки программного обеспечения (SDLC), их плюсах и минусах, а также о реальных примерах их использования. Обсудить Более половины ИТ-проектов заканчиваются провалом. Одни из самых распространенных причин неудач ИТ-проектов – неправильная интерпретация бизнес-целей, игнорирование клиентов, неправильная расстановка приоритетов. Но у всех у них общий корень проблемы: неправильный подход к разработке программного обеспечения. Методология разработки программного обеспечения (SDLC) представляет собой последовательность действий, которые необходимо выполнить, чтобы получить готовое решение. Проще говоря, это способ создания программного продукта. Проблема в том, что существует множество моделей SDLC, которые используются для разных типов проектов. Как узнать, какой из них подходит для вашего проекта? В статье я перечислил наиболее популярные модели SDLC, их варианты использования, преимущества и недостатки. Это линейная и последовательная модель разработки программного обеспечения, в которой фазы проекта следуют одна за другой и включают: Каскадная модель – хороший вариант, если выполняются эти условия: Всего десять лет назад многие компании использовали каскадную модель для разработки корпоративного программного обеспечения, включая CRM, системы управления цепочками поставок и системы точек продаж. Но сегодня эта модель не может удовлетворить быстро меняющиеся технические потребности. Вот почему компании все чаще обращаются к более современным подходам. V-образная модель – это своего рода другая версия каскада, но в её основе лежит контроль качества каждой фазы. Например, когда группа разработчиков собирает требования к проекту, QA-специалисты пишут приемочные тесты на основе этих сценариев. Точно так же на этапе проектирования системы создаются сценарии тестирования и так далее. После написания кода команда QA проверяет продукт на соответствие заранее написанным тестам (правая часть буквы «V»). V-образная модель может быть чрезвычайно полезна в случаях, когда ошибки могут быть фатальными, и в проектах, где точность имеет решающее значение. Например, это решение, основанное на нормативных требованиях, таких как подача налоговых деклараций. Кроме того, эта модель подходит для проектов в сфере здравоохранения. Например, компания Roche Diagnostics однажды использовала его для разработки системы диагностики рака. Это ещё одна вариация каскада. Пока проект проходит через традиционные фазы, прототип продукта пошагово дорабатывается на основе отзывов клиентов. Как правило, первый прототип не проходит приемочный тест, поэтому модель прототипирования включает в себя несколько прототипов. Только после того, как предложенный дизайн продукта будет полностью принят, команда разработчиков сможет перейти к следующим этапам. Модель эволюционного прототипирования может быть полезна для проектов, которые предполагают взаимодействие с пользователем, используют новые технологии, имеют сложную функциональность или должны учитывать быстро меняющиеся требования, которые трудно или невозможно предсказать. В инкрементальной и итеративной модели решение разрабатывается небольшими частями через серию циклов. Рабочий процесс выглядит следующим образом: Модель будет эффективна в следующих случаях: По словам Алистера Скотта, каждый программный продукт, который хочет оставаться конкурентным на рынке, требует наращивания мощностей. Даже если вы будете использовать каскадную модель для разработки своего решения, к моменту завершения цикла решение уже устареет. Поэтому необходимы дополнительные итерации. Этот подход основан на оценке риска, он сочетает в себе функции каскадной, прототипной, итеративной и инкрементной моделей. Модель похожа на спираль с несколькими кругами. Каждый круг – это фаза, состоящая из четырёх элементов: Затем, на основе отзывов пользователей и заинтересованных сторон, планируется следующая итерация. Как видите, продукт неоднократно проходит через эти этапы, и в конце каждого цикла создаётся и выпускается лучшая версия продукта. И, как и в итеративном подходе, продукт состоит из серии релизов. Спиральная модель подходит для: Microsoft, IBM и Tata Consultancy используют спиральную модель. Вопреки распространённому мнению Agile не является ни структурой, ни методологией. Это философия с набором принципов, ориентированных на ускорение процесса разработки программного обеспечения, обеспечение 100% удовлетворённости клиентов и предоставление высококачественных решений в быстро меняющейся среде. Фактически, существует 12 принципов гибкой разработки, которые сводятся к следующим ценностям: Ценности Agile породили более 50 методологий, из которых Scrum является самой популярной. Скрам-проекты разбиты на спринты. Спринт – это небольшой объём работы, который необходимо выполнить в течение определённого периода времени. Обычно заказчику доставляется часть проекта, которая была завершена во время спринта (инкремент продукта, от англ. increment). Скрам подразумевает активное общение и сотрудничество между всеми участниками проекта. Наряду с ежедневными 15-минутными встречами разработчиков, есть также: Сердце процессов Scrum – это backlog, своего рода список задач, которые необходимо сделать для завершения проекта. По мере того, как проект продвигается, и команда узнаёт о нём больше, они редактируют бэклог продукта, добавляя, удаляя и переупорядочивая его элементы. Тем не менее, нельзя сделать что-то, если этого нет в очереди продукта. Но на самом ли деле всё так гладко и красиво в Agile? Посмотрим на его основные варианты использования, а также на плюсы и минусы. Большинство современных проектов требуют определённого уровня «маневренности», особенно когда: В общем, Agile кажется именно тем, что нужно большинству проектов во времена неопределённости. Неудивительно, что более 70% компаний применяют Agile, включая Microsoft, IBM, Procter & Gamble и другие. И EPAM не исключение. Ни одна из моделей SDLC не является «волшебной пилюлей». Нельзя просто выбрать методологию, которая соответствует потребностям проекта, и слепо следовать ей. В лучшем случае это не улучшит ваш процесс разработки. В худшем вы подвергнете риску проект. Вот почему грамотный подход к выбору и реализации модели разработки программного обеспечения является ключом к тому, чтобы заставить её работать на вас. *** Вот несколько советов как подходить к разработке на примере реального проекта EPAM Anywhere: Основные методологии разработки ПО
Каскадная модель (waterfall)
Плюсы и минусы подхода
Плюсы Минусы Простая в использовании модель. С этой моделью слишком сложно и дорого адаптироваться к изменениям требований. Каждый этап хорошо задокументирован. Документирование каждой фазы проекта занимает много времени. Результат проекта абсолютно предсказуем. Вы не можете ничего предоставить заказчику, пока не завершите весь проект. Этапы и роли четко определены с самого начала. Различные команды (дизайн, разработка, контроль качества и т. д.) изолированы, а взаимодействие между ними ограничено. Минимальное вмешательство клиента. Без обратной связи клиента результат рискует не оправдать ожидания. Каким проектам подходит
V-образная модель SDLC
Плюсы Минусы Легко реализовывать. В V-образной модели внести изменения в середине проекта крайне сложно. Тест-кейсы создаются заранее. При таком большом количестве процедур тестирования остается меньше времени на код. Бюджет и продолжительность проекта предсказуемы. По сравнению с каскадной эта модель требует больше специалистов. У каждого этапа есть свои результаты, и все хорошо задокументировано. Модель не подходит для проектов с быстро меняющимися требованиями. Это структурированный подход с четко определенными ролями и функциями. Не подходит для больших и сложных проектов. Каким проектам подходит
Модель эволюционного прототипирования
Плюсы Минусы Получение отзывов пользователей на ранних этапах. Поскольку прототипы могут развиваться бесконечно, планирование проекта невозможно. Высокие шансы на успех проекта. Разрабатывать несколько прототипов – дорого. Легко адаптироваться к быстро меняющимся требованиям. Каким проектам подходит
Итеративная и инкрементальная модель
Плюсы Минусы Модель инкрементальной и итеративной разработки обеспечивает быструю и регулярную «доставку» работающего программного обеспечения клиентам. Во время интеграции модуля могут возникнуть архитектурные проблемы. Легче и дешевле учесть изменения в требованиях проекта. Несмотря на некоторую гибкость, систему следует планировать с самого начала; в противном случае его нельзя разделить на модули. Обратная связь от клиента на ранней стадии. Участие клиентов может быть проблематичным. Небольшие части программного обеспечения легче тестировать и исправлять. Не всегда можно разбить систему на сегменты. Экономия на издержках. Хотя выпуск одного модуля дешевле, общие затраты на систему будут увеличиваться по мере интеграции новых модулей. Каким проектам подходит
Спиральная модель
Плюсы Минусы Анализ рисков на каждой итерации увеличивает шансы проекта на успех. Требуется опыт управления рисками. Этот метод позволяет создавать стабильные и надёжные системы, поскольку они тщательно тестируются в каждом цикле. Модель подразумевает работу с большим объёмом документации. Можно менять требования между циклами. Нельзя изменить требования в середине цикла. Раннее вовлечение разработчиков помогает согласовать бизнес-требования и технические возможности. Каждый кружок в спирали развития представляет собой «мини-каскад», а это значит, что вы не можете пропускать фазы. Частые выпуски позволяют получать регулярную обратную связь от клиентов даже на ранних этапах цикла. Поскольку ограничений на количество итераций нет, сложно предсказать, сколько кругов потребуется для создания окончательной версии продукта. Каким проектам подходит
Модели гибкой разработки программного обеспечения
Scrum
Плюсы Минусы Не нужно ждать завершения проекта, чтобы внедрить основные функции продукта. Гибкие методологии разработки ПО сложно внедрить. Кросс-функциональные команды регулярно общаются и обмениваются знаниями между собой и владельцами проектов. В Agile проектная документация очень быстро устаревает, поэтому понадобятся дополнительные навыки оперативной работы с ней. Возможность адаптироваться к изменениям на любой стадии проекта. В Agile проектах практически невозможно делать прогнозы и достаточно тяжело с высокой долей точности планировать бюджет. Регулярная обратная связь от пользователей, что позволяет удовлетворить все потребности. Сбор отзывов пользователей может быть сложной задачей. Примеры использования
Резюме
- 31 views
- 0 Comment