Хочу рассказать о сути Agile кратко и менее формально. Если вам интересны точные детальные ответы, то я написал несколько заметок:
- Что привело к необходимости появления «Манифеста Agile-разработки ПО»?
- История создания «Манифеста Agile-разработки ПО»
- Что такое Agile?
- Ответы на вопрос «Что такое Agile?» в разных источниках
- Как правильно произносить Agile? И как переводится?
- Почему Agile так называется? Были другие варианты?
Если кратко, когда говорят “мы agile”, имеют в виду:
- создание продукта,
- стабильные кросс-функциональные команды,
- итеративность,
- инкрементальность,
- постоянное улучшение процесса работы.
Итеративное инкрементальное создание продукта стабильными кросс-функциональными командами, повышающими свою эффективность.
Теперь немного подробнее.
1. Создание продукта
Команда создаёт, развивает и поддерживает продукт. Внутренний или внешний. Иногда это отдельная ИТ-система, иногда группа системы. Формально это может быть и проект, но зачастую это процесс, с метриками и продукта, и процесса.
Про бизнес часть 1. Что такое agile?
2. Стабильные кросс-функциональные команды
Состав команды стабилен, вся команда занята работой над продуктом 100% своего времени. Иногда могут привлекаться дополнительные специалисты, например, для графического редизайна, для настройки нагрузочного тестирования, для автоматизации сборки и поставки, или для других задач. Однако основаная часть команды стабильная.
Команда кросс-функциональна = в команде в целом представлены все необходимые компетенции для создания продукта от момента идеи до предоставления клиенту. (Видео о том, как проанализировать и развивать компетенции команды с помощью Competence map. Также будет полезно узнать о Т-образных специалистах T-Shape.)
3. Итеративно
Команда работает циклами фиксированной длины — итерациями. Команда или организация выбирают длину цикла, а затем придерживаются его. У итеративного подхода много плюсов: снижение рисков, частая обратная связь, возможность изменения приоритетов, фокусировка на самом важном, непрерывное тестирование, повышение качества, равномерная загрузка, стабильная мотивация, применение опыта предыдущих циклов, понимание статуса. (Подробнее о них написано в одноимённой статье. Также будет полезно узнать о Цикле PDSA.)
4. Инкрементально
В конце каждого цикла у команды есть следующий инкремент продукта. Другими словами — очередная работающая, пригодная к использованию версия. В терминах Скрама – готовый в соответствии с Definition of Done.
Бытовой пример: вместо уборки всей квартиры целиком и последовательно пыль-пылесос-швабра сначала убирается полностью одна комната, затем другая и т. д. У такого подхода тоже много плюсов: снижение рисков, частая обратная связь на реальный продукт, фокусировка на выпуске вместо “быть занятым”, тестирование боем, повышение качества, понимание реального статуса.
Agile — почему он может убить Ваш бизнес?
5. Повышение эффективности
Подразделения любого размера периодически собираются, чтобы проанализировать процесс своей работы и сделать его лучше. Команды из 10 человек обычно собираются раз в 2 недели или месяц, а команды команд по 100 — каждый квартал. Самый популярный способ непрерывных улучшений — ретроспектива.
Резюме
Закрепим рассмотренное. Разработка “по Agile” подразумевает:
Создание инкрементов продукта каждую итерацию силами стабильных кросс-функциональных команд, постоянно повышающих эффективность работы.
Источник: dblinov.medium.com
Что такое Agile: 6 особенностей методологии + пример внедрения в бизнес
Сегодня все чаще можно услышать про некую методологию Agile, которую успешно применяют иностранные компании, но не особо жалуют у нас.
Многие попросту не понимают смысл внедрения новых гибких систем управления проектами, предпочитая работать по-старинке. Таким образом итоговый проект собирается сразу целиком, что затрудняет возможности внесения новых идей прямо в рабочем процессе.
В свою очередь Agile предполагает разбивку процесса на короткие этапы, что позволяет вносить изменения прямо в процессе разработки. Но это если совсем кратко, мы в свою очередь постараемся подробно рассказать о сути данной модели.
«Методология Agile» – не совсем корректная формулировка. В действительности это скорее не методология, а набор разнообразных методик, суть которых сводится к управлению рабочим процессом.
Суть Agile заключается в:
- Упрощении структуры организации рабочего процесса;
- Сокращении циклов;
- Активном использовании обратной связи;
- Фокусировке всего коллектива на текущих проблемах аудитории;
- Выделении дополнительных полномочий сотрудникам;
- Гуманном подходе к моральному состоянию сотрудников.
Стоит отметить тот факт, что в основе Agile лежит гуманистический подход к рабочему процессу и широкие полномочия каждого сотрудника компании. Более того, сама суть технологии заключается в образе мышления и пути к конечной точке, а не в результате как таковом.
Далее рассмотрим каждую особенность Agile в отдельности.
Упрощение структуры организации рабочего процесса
Одной из ключевых особенностей подхода Agile является максимальное упрощение организационной структуры. В соответствии с принципами Agile правила должны быть настолько простыми, насколько это возможно.
Упрощение организационной структуры позволит сотрудникам компании лучше фокусироваться на текущих задачах и на ценностях, которые они несут клиентам. Чрезмерно регламентированная структура управления создает определенные трудности, без которых определенно можно обойтись.
Выглядит это следующим образом: в начале недели в четко регламентированное время составляется план задач на ближайшую итерацию и вывешивается в офисе. А в конце недели происходит обсуждение улучшения рабочего процесса. Текущие задачи и цели, договоренности и прочее для небольшой команды можно легко уместить на паре листов.
Важно понимать, что сложность имеет свойство возрастать в геометрической прогрессии. Таким образом, чем больше структура – тем важнее становится вопрос ее упрощения. Благодаря Agile можно если не свести на нет этот рост, то по крайней мере значительно удержать его.
Короткие циклы
В данном разделе мы разберем, пожалуй, главную мысль Agile – разбивку рабочего процесса на короткие циклы, каждый из которых является хоть и урезанным, но продуктом, которым можно пользоваться.
Долгий производственный цикл предполагает определенные риски. Дело в том, что существует вероятность потери как актуальности, так и интереса со стороны аудитории. Именно поэтому итеративно-инкрементальный подход набирает все большую популярность.
Зачем руководителям нужны Agile и Scrum?
Раньше Agile и Scrum считались методами исключительно для ИТ-сферы — с их помощью айтишники разрабатывали ПО и запускали новые продукты. Но после открытия дома Agile в такой классической организации, как Сбербанк, эти методы стали применять не только все руководители, но даже домохозяйки. Эта статья о том, что такое Agile и Scrum, и как их применять.
1. Что такое Agile?
Agile — это сложно ощутимая вещь. Это образ жизни, идеология. В переводе с английского Agile означает «гибкий», «подвижный», поэтому многие называют Agile гибкой методологией, но я с такой формулировкой не совсем согласен, для меня это образ жизни.
Существует четыре ценности Agile :
1. Люди и коммуникации важнее процессов и инструментов.
2. Рабочий продукт важнее исчерпывающей документации.
3. Взаимодействие с заказчиком важнее проработки деталей контракта.
4. Готовность к изменениям важнее следования плану.
По принципам Аgile может работать не только ИТ-компания, но и любая другая. Не думаю, что если вы в качестве эксперимента сделаете у себя в компании один отдел Аgile, то добьётесь ощутимых результатов. Я считаю, что либо вся компания целиком принимает ценности Аgile, либо никто.
Как отличить Аgile-компанию от не Аgile-компании? Всё дело в целях. Классическая организация ставит цель: побольше заработать денег, а Аgile-организация ставит цель сделать клиента счастливым. Agile – это история про бирюзовость, впрочем, не стоит на это опираться. Факт в том, что бирюзовость хорошо дополняет ценности Agile.
2. Что такое Scrum (Скрам) и чем он отличается от Agile?
Если Аgile — это свод ценностей, образ жизни, то Scrum (Скрам) — это «фреймворк» работы. Это не методология, а структура — определенные этапы, которые нужно проходить. Scrum для меня — высокоэффективный процесс создания востребованных продуктов.
3. Когда нужно применять Scrum?
Scrum хорошо подходит для создания инновационных продуктов за счет своей итеративности. В чем фишка? Если при обыкновенном waterfall подходе продукт разрабатывается годами, то Scrum справляется с задачей быстро и дешево.
Scrum – это не про то, как работать меньше, это про то, как работать эффективнее .
Дело в том, что в обычном waterfall-подходе сначала в течение полугода создаются бизнес-требования, затем год пишется аналитика, а после этого за дело берутся разработчики и кодят по этому документу. Дальше все тестируется и много раз перерабатывается. В финале происходит «адское» внедрение. Все это происходит за деньги бизнес-заказчика, не принося ему ни копейки прибыли, с огромной долей риска невостребованности продукта.
А если поменялись бизнес-требования у проекта? Всё заново. Получается очень дорогой эксперимент длиною в годы. В Scrum у нас есть возможность за очень короткий промежуток времени (1-4 недели) проверить продуктовую гипотезу и иметь необходимую информацию для принятия продуктовых решений. Получить дешёвый продукт, который сразу может начать окупаться.
4. Почему Scrum получил такую широкую популярность?
В Cynefin framework существует четыре вида мира:
- Простой упорядоченный мир.
- Сложный, но упорядоченный мир.
- Сложный неупорядоченный мир.
- Хаос.
«Простой упорядоченный мир» — это когда перед вами стоит задача собрать табуретку, и есть всего лишь один способ её собрать. Если мы не будем пользоваться данной нам инструкцией и начнём собирать детали по-своёму, то это уже не будет табуретка.
Какую процедуру нам нужно выполнить, чтобы прийти к ожидаемым результатам? Нужно воспользоваться опытом другим и сделать то же самое. В «сложном, но упорядоченном мире» существует много процессов, которые могут протекать по-разному. Но тот, кто уже прошёл этот путь, знает, как его проделать лучше. Например, тот, кто уже работал с тендерной заявкой, понимает как всё сделать быстрее.
Но самое интересное происходит, когда мы попадаем в «сложный и запутанный мир», где никто не знает, как правильно действовать. Не знает, окажется ли востребованным продукт.
Тогда нам может пригодиться Scrum. Мы сначала сделаем один маленький дешёвый эксперимент, а потом поймём, как действовать дальше. Более того, вся современная продуктология находится в контексте «сложного и запутанного мира». Не важно, выпускаете ли вы ИТ-продукты, строите дома или производите самолеты, сегодня вы не можете со стопроцентной уверенностью утверждать, что продукт окажется востребованным. Даже если вы провели исследования, где пользователь уверил вас, что продукт ему жизненно необходим, в реальности всё может оказаться по-другому и покупать его он не станет.
Scrum позволяет быстрее и дешевле получить обратную связь о вашем продукте .
Если мы применяем привычную waterfall-методологию, то мы готовим долгую дорогущую итерацию и только по истечении нескольких лет понимаем: а нужно ли это было пользователям? В свою очередь, Scrum позволяет сделать маленький кусочек продукта за короткую итерацию и сразу выкатить его на пользователя – услышать обратную связь. Если пользователям неинтересно то, что мы сделали, мы просто смело убиваем продукт и отчитываемся перед руководством: «проверили гипотезу очень дешево (например, за 2 недели работы 5 человек) и выяснили, что продукт невостребованный. Реализовывать его не нужно, давайте займёмся более полезными вещами». Если продукт пользователям понравился, то начинаем его развивать и зарабатывать на нём.
5. Основные роли в Scrum-команде
Особенностью Scrum (Скрама) является вовлеченность в процесс всех участников команды, причем у каждого участника есть своя определенная роль.
Роли и терминология в Scrum :
- Владелец продукта (Product owner) — человек, который имеет непосредственный интерес в конечном продукте, он понимает, как продукт должен выглядеть/работать. Он имеет право принимать любые решения по продукту и только он несет ответственность за финансовую эффективность продукта. Product-owner должен иметь необходимую экспертизу, понимать продуктологию. Также он должен уметь выделять ценность продукта и быть всегда доступным для команды. В большом бизнесе бизнесмену обычно не до команд и это очень плохо. В продукте есть множество деталей. И если про них постоянно не спрашивать, то в конечном итоге можно получить не тот результат, который ожидают: «Что вы мне сделали? Совсем не то, что нужно!» — «А мы так сделали, потому что ни разу не смогли до тебя достучаться — сделали, как считали нужным».
- Scrum-мастер — человек, который смотрит на все процессы немного со стороны. Со стороны здравого смысла. Он не айтишник и не должен им быть. Если он айтишник, то это, скорее, минус. У меня, например, появилась команда мобильной разработки, но я плохо понимаю особенности мобильной разработки. Я оцениваю решения с точки зрения здравого смысла. Если мне кажется, что что-то идет не так, я задаю вопросы команде. Scrum-мастер — это такой идеальный командный коуч. Он не продавливает свое решение и ценит профессионализм команды. Помогает участникам коллектива быть самостоятельными. Команда сама должна обладать всеми компетенциями для того, чтобы автономно сделать инкремент продукта. Кстати, команда не должна никуда ходить и что-то там согласовывать, сидеть и ждать отмашки. Просто берет и делает.
- Команда разработки — это команда, которая обладает всеми необходимыми компетенциями для превращения элемента бэклога в готовый инкремент продукта.
- Спринт — фиксированный отрезок времени для выполнения определенного (ограниченного) списка задач, который называется спринт-бэклогом. Рекомендуется брать 1-4 недели (длительность определяется всей Sсrum-командой).
- Бэклог (backlog) — это список пользовательских историй, который предстоит реализовать команде. Управляется исключительно product owner’ом.
6. Как это работает в сферах, далеких от ИТ?
Scrum сегодня многие используют в продажах. Также я знаю, что Boeing собирает турбины двигателей по фреймфорку, который похож на Scrum. Например, раз в месяц они проводят демо запуск — реально запускают двигатель, приглашают остальных экспертов, которые собирают самолёт, и смотрят, всё ли в порядке?
Несмотря на то, что сборка двигателя самолёта относится скорее к «миру сложному и упорядоченному», там тоже применяют итеративный подход. Регулярность запуска позволяет сэкономить время обнаружения проблемы сборки и минимизировать риски. Производство самолётов является самым качественным производством в мире и эта модель работы позволяет им держать этот высокий уровень.
7. Есть ли негативные отклики о Scrum?
Конечно, есть. Сколько людей, столько и мнений. Когда распоряжение поступает сверху в административном порядке в духе «С понедельника мы Agile и действуем по Scrum», это не работает, и, конечно, вызывает негатив у людей. Scrum – это не про то, как работать меньше, это про то, как работать эффективно . Люди втягиваются, и им нравится так работать. Просто потому что они любят свой продукт и хотят его сделать реально классным, чтобы их пользователю было приятно им пользоваться, чтобы в AppStore ставили 5 звезд.
Разумеется, проще работать по-старому. Обычно негатив по поводу Scrum идёт от людей, которые не готовы меняться. А вообще, Agile можно только заразить, и он точно должен идти снизу и встретить одобрение сверху, а не наоборот. Стать Agile – это кардинально сменить образ жизни. Agile – это то, что на кончиках пальцев, это просто нужно чувствовать . Применять данный метод можно везде.
И если человек говорит, что Scrum в его продукте не работает, значит, он пока еще не умеет выделять главную ценность своего продукта.
Люди привыкли думать и жить решениями, а нужно учиться жить целями . Если мы хотим построить мост, то мы просто возьмём и построим мост. Если мы захотим построить его по Scrum, то скорее всего в первой итерации это будет рыбацкая лодка, которая перевозит людей. Потому что главная ценность продукта в том, чтобы пользователи (жители) могли оказаться на другой стороне реки.
Цель достигнута, бизнес ценность уже есть, а дальше мы можем развивать продукт, при этом он уже себя окупает. Мост, возможно, мы и не построим. Плохо ли это? Да, если мы просто хотим построить мост. И очень хорошо, если мы хотим помочь людям, которые не могут перебраться на другую сторону реки.
Заключение
Если Аgile (гибкая методология) – это свод ценностей, то Scrum (Скрам) – это «фреймворк» работы. Благодаря Scrum у нас появляется возможность быстро и дёшево запустить продукт и получить обратную связь. Важно понимать, что Scrum не про то, как работать меньше, он про то, как работать эффективно. Применять его можно абсолютно везде. И если сотрудник говорит, что Scrum в его сфере не работает, значит, он пока еще не умеет выделять главную ценность своего продукта.
Источник: dzen.ru