Переключение функций - Википедия - Feature toggle
А переключение функций (также переключатель функций, флаг функции, функция флиппер, условный признаки т. д.) - это техника в разработка программного обеспечения который пытается предоставить альтернативу поддержанию нескольких ветви в исходный код (известные как ветви функций), так что функция программного обеспечения возможно проверено еще до того, как он будет завершен и готов к релиз. Переключатель функций используется, чтобы скрыть, включить или отключить функцию во время время выполнения. Например, в процессе разработки разработчик может включить функцию для тестирования и отключить ее для других пользователей.[1] Таким образом, флаги функций могут использоваться для реализации целевого развертывания функций для определенных подмножеств пользователей - практика, известная как стробирование функций.[2]
Непрерывный выпуск и непрерывное развертывание оперативно предоставлять разработчикам отзывы об их кодировании. Это требует внесения изменений в их код как можно раньше. Ветви функций позволяют обходить этот процесс.[3] Переключение функций - важный метод, используемый для реализации непрерывная доставка.
Этот метод позволяет разработчикам выпускать версия продукта с незавершенными функциями. Эти незавершенные функции скрыты (переключаются), поэтому они не отображаются в пользовательский интерфейс. Это позволяет использовать множество небольших инкрементных версий программного обеспечения доставляться без затрат на постоянное разветвление и слияние. Переключение функций может сократить циклы интеграции программного обеспечения.[4] Команда, работающая над проектом, может использовать переключатель функций, чтобы ускорить процесс разработки, который также может включать неполный код.
Выполнение
Эта секция нужны дополнительные цитаты для проверка.Октябрь 2016) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
Переключатели функций - это, по сути, переменные, которые используются внутри условных операторов. Следовательно, блоки внутри этих условных операторов могут быть включены или выключены в зависимости от значения переключателей функций. Блок кода, который был отключен, похож на закомментированный. Это позволяет разработчикам контролировать поток своего программного обеспечения и обходить функции, которые не готовы к развертыванию.
Основное использование переключателей функций - избежать конфликта, который может возникнуть при слиянии изменений в программном обеспечении в последний момент перед выпуском, хотя это может привести к переключить долг. Задолженность переключения возникает из-за наличия мертвого кода в программном обеспечении после того, как функция была постоянно включена, и вызывает накладные расходы. Эта часть кода должна быть удалена осторожно, чтобы не мешать другим частям кода.
Есть два основных типа переключения функций. Один из них - переключатель выпуска, который разработчик решает сохранить или удалить перед выпуском продукта в зависимости от его работы. Другой - это бизнес-переключатель, который сохраняется, потому что его использование отличается от использования старого кода.
Переключатели функций можно использовать в следующих сценариях:[1]
- Добавление новой функции в приложение.
- Улучшение существующей функции в приложении.
- Скрытие или отключение функции.
- Расширение интерфейса.
Переключатели функций могут быть сохранены как:[5]
- Записи строк в базе данных.
- Свойство в файле конфигурации.
- Запись во внешней службе флага функции.
Группы функций
Группы функций состоят из переключателей функций, которые работают вместе. Это позволяет разработчику легко управлять набором связанных переключателей.[6]
Канарейка
Еще одно преимущество флагов функций - канареечные запуски. Канареечный выпуск (или канареечный запуск, или канареечное развертывание) позволяет разработчикам постепенно тестировать функции небольшой группой пользователей. Если производительность функции неудовлетворительна, ее можно откатить без каких-либо побочных эффектов.[7]
Мартин Фаулер утверждает, что переключение функций «должно быть вашим последним выбором, когда вы имеете дело с вводом функций в производство». Вместо этого лучше разбить функцию на более мелкие части, каждая из которых может быть реализована и безопасно введена в выпущенный продукт, не вызывая других проблем.[8]
Переключение функций используется на многих крупных веб-сайтах, включая Flickr,[9] Disqus,[10] Etsy,[11] Reddit[12] Gmail[13] и Netflix, [14] а также программное обеспечение, такое как Google Chrome Canary.
Смотрите также
- Управление конфигурацией программного обеспечения
- Линия программных продуктов
- Сравнение программного обеспечения для управления конфигурацией с открытым исходным кодом
Рекомендации
- ^ а б «Рейнджеры ALM - Разработка программного обеспечения с переключателями функций». msdn.microsoft.com.
- ^ «Флаги функций (также известные как переключатели функций)». optimizely.com. Получено 14 июля 2020.
- ^ «Флаги функций для мобильных приложений - Apptimize». apptimize.com. Архивировано из оригинал 18 сентября 2016 г.. Получено 9 января 2017.
- ^ Программирование приложений JavaScript. Архивировано из оригинал на 2016-09-15. Получено 2016-09-14.
- ^ Эчагуэ, Пато (2014). Управление флагами функций. O'Reilly Media. ISBN 9781492028598 - через https://www.oreilly.com/library/view/managing-feature-flags/9781492028598.
- ^ Эллиот, Эрик (2018). Программирование приложений JavaScript. O'Reilly Media.
- ^ «Канарские запуски - как и зачем выпускать канарейки». launchdarkly.com. 7 апреля 2015 г.. Получено 9 января 2017.
- ^ Мартин Фаулер, 29 октября 2010 г. (2010-10-29). "FeatureToggle". Martinfowler.com. Получено 2013-09-27.
- ^ Хармс, Росс. "Вытягивание - code.flickr.com". flickr.net. Получено 9 января 2017.
- ^ dcramer (9 июля 2010 г.). «Частичное развертывание с переключением функций». Архивировано из оригинал на 2013-11-05. Получено 2013-10-10.
- ^ «Как Etsy управляет разработкой и операциями?». codeascraft.com. 4 февраля 2011 г.. Получено 9 января 2017.
- ^ "Reddit / Reddit". github.com. Получено 9 января 2017.
- ^ «Разработка нового внешнего вида Gmail». googleblog.com. Получено 9 января 2017.
- ^ «Подготовка Netflix API к развертыванию». netflix.com. Получено 9 января 2017.