Разработка программного обеспечения с открытым исходным кодом - Open-source software development

Разработка программного обеспечения с открытым исходным кодом это процесс, посредством которого программное обеспечение с открытым исходным кодом, или аналогичное программное обеспечение, чье исходный код общедоступен, разработан проект программного обеспечения с открытым исходным кодом. Это программные продукты, доступные с исходным кодом под лицензия с открытым исходным кодом изучать, изменять и улучшать его дизайн. Примеры некоторых популярных программных продуктов с открытым исходным кодом: Mozilla Firefox, Google Chromium, Android, LibreOffice и Медиаплеер VLC.

История

В 1997 г. Эрик С. Раймонд написал Собор и базар.[1] В этой книге Раймонд проводит различие между двумя видами разработки программного обеспечения. Первый - это обычная разработка с закрытым кодом. По словам Раймонда, такой метод развития похож на строительство собора; централизованное планирование, четкая организация и единый процесс от начала до конца. Вторая - это прогрессивная разработка с открытым исходным кодом, которая больше похожа на «большой болтливый базар различных программ и подходов, из которого последовательная и стабильная система могла бы, казалось бы, возникнуть только в результате череды чудес». Последняя аналогия указывает на дискуссию, связанную с процессом разработки с открытым исходным кодом.

Различия между двумя стилями разработки, по словам Бара и Фогеля, заключаются в общем в обработке (и создании) отчетов об ошибках и запросах функций, а также в ограничениях, с которыми работают программисты.[2] При разработке программного обеспечения с закрытым исходным кодом программисты часто тратят много времени на создание отчетов об ошибках, а также на обработку запросов функций. Это время уходит на создание и определение приоритетов дальнейших планов развития. Это приводит к тому, что часть команды разработчиков тратит много времени на эти вопросы, а не на саму разработку. Кроме того, в проектах с закрытым исходным кодом команды разработчиков часто должны работать в условиях ограничений, связанных с управлением (таких как сроки, бюджеты и т. Д.), Которые мешают техническим вопросам программного обеспечения. При разработке программного обеспечения с открытым исходным кодом эти проблемы решаются путем интеграции пользователей программного обеспечения в процесс разработки или даже предоставления этим пользователям возможности самостоятельно создавать систему.[нужна цитата ]

Модель

Модель данных процесса для разработки программного обеспечения с открытым исходным кодом

Разработка программного обеспечения с открытым исходным кодом можно разделить на несколько этапов. Указанные здесь фазы получены из Шарма и др..[3] Диаграмма, отображающая структуру данных процесса разработки программного обеспечения с открытым исходным кодом, показана справа. На этом рисунке показаны этапы разработки программного обеспечения с открытым исходным кодом вместе с соответствующими элементами данных. Эта диаграмма сделана с использованием мета-моделирование и моделирование метапроцессов техники.

Запуск проекта с открытым исходным кодом

Есть несколько способов начать работу над проектом с открытым исходным кодом:

  1. Человек, который ощущает необходимость в проекте, публично объявляет о намерении разработать проект.
  2. Разработчик, работающий над ограниченной, но работающей базой кода, публикует ее как первую версию программы с открытым исходным кодом.
  3. Исходный код зрелого проекта публикуется.
  4. Хорошо зарекомендовавший себя проект с открытым исходным кодом можно раздвоенный заинтересованной сторонней стороной.

Эрик Раймонд заметил в своем эссе Собор и базар что объявление о намерении по проекту обычно хуже, чем опубликование работающего проекта.

Распространенная ошибка - начинать проект, когда участие в существующем аналогичном проекте было бы более эффективным (Синдром NIH )[нужна цитата ]. Чтобы начать успешный проект, очень важно изучить то, что уже есть. Процесс начинается с выбора между принятием существующего проекта или началом нового проекта. Если запускается новый проект, процесс переходит в фазу инициации. Если существующий проект принят, процесс переходит непосредственно к этапу выполнения.[оригинальное исследование? ]

Типы open-source проектов

Существует несколько типов проектов с открытым исходным кодом. Во-первых, существует множество программ и библиотек, состоящих из отдельных фрагментов кода. Некоторые могут даже зависеть от других проектов с открытым исходным кодом. Эти проекты служат определенной цели и удовлетворяют определенную потребность. Примеры этого типа проекта включают Ядро Linux, веб-браузер Firefox и офисный набор инструментов LibreOffice.

Дистрибутивы - это еще один тип проектов с открытым исходным кодом. Дистрибутивы - это коллекции программного обеспечения, которые публикуются из одного источника с общей целью. Наиболее ярким примером «дистрибутива» является операционная система. Есть много Linux дистрибутивы (например, Debian, Fedora Core, Mandriva, Slackware, Ubuntu и т.д.), которые поставляют ядро ​​Linux вместе со многими пользовательскими компонентами. Есть и другие дистрибутивы, например ActivePerl, то Язык программирования Perl для различных операционных систем, и Cygwin дистрибутивы программ с открытым исходным кодом для Майкрософт Виндоус.

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

Наконец, есть книга или отдельный документный проект. Эти элементы обычно не поставляются как часть пакета программного обеспечения с открытым исходным кодом. Проект документации Linux содержит множество таких проектов, которые документируют различные аспекты операционной системы GNU / Linux. Есть много других примеров этого типа проектов с открытым исходным кодом.

Методы

Трудно запустить проект с открытым исходным кодом, следуя более традиционному методу разработки программного обеспечения, например модель водопада, потому что в этих традиционных методах нельзя вернуться к предыдущей фазе. При разработке программного обеспечения с открытым исходным кодом требования редко собираются до начала проекта; вместо этого они основаны на ранних версиях программного продукта, как описывает Роббинс.[4] Помимо требований, часто привлекаются волонтеры для помощи в разработке программного продукта на основе ранних выпусков программного обеспечения. По мнению Абрахамссона и др., Этот сетевой эффект очень важен: «если представленный прототип привлечет достаточно внимания, он постепенно начнет привлекать все больше и больше разработчиков». Однако Абрахамссон и др. также отметьте, что сообщество очень сурово, очень похоже на деловой мир программного обеспечения с закрытым исходным кодом: «если вы найдете клиентов, вы выживете, но без клиентов вы погибнете».[5]

Fuggetta[6] утверждает, что «быстрое прототипирование, инкрементальная и эволюционная разработка, спиральный жизненный цикл, быстрая разработка приложений и, в последнее время, экстремальное программирование и гибкий программный процесс могут в равной степени применяться к проприетарному программному обеспечению и программному обеспечению с открытым исходным кодом». Он также указывает Экстремальное программирование как чрезвычайно полезный метод разработки программного обеспечения с открытым исходным кодом. В общем, все Гибкое программирование методы применимы к разработке программного обеспечения с открытым исходным кодом из-за их итеративного и инкрементного характера. Другие методы Agile одинаково полезны для разработки программного обеспечения как с открытым, так и с закрытым кодом:Интернет-скорость развития, например, подходит для разработки программного обеспечения с открытым исходным кодом из-за принятого в нем принципа распределенной разработки. Internet-Speed ​​Development использует географически распределенные группы для «круглосуточной работы». Этот метод, в основном используемый крупными фирмами с закрытым кодом (потому что они единственные, у которых есть центры разработки в разных часовых поясах), одинаково хорошо работает в проектах с открытым исходным кодом, потому что программное обеспечение, разработанное большой группой добровольцев, естественно, чтобы разработчики работали во всех часовых поясах.

Инструменты

Каналы связи

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

Системы контроля версий

В разработке OSS участники, которые в основном добровольцы, распределены по разным географическим регионам, поэтому необходимы инструменты, которые помогут участникам сотрудничать в разработке исходного кода.

В начале 2000-х гг. Система одновременных версий (CVS) был ярким примером инструмента совместной работы над исходным кодом, используемого в проектах OSS. CVS помогает управлять файлами и кодами проекта, когда над проектом одновременно работают несколько человек. CVS позволяет нескольким людям работать над одним файлом одновременно. Это делается путем перемещения файла в каталоги пользователей и последующего объединения файлов, когда пользователи закончат. CVS также позволяет легко получить предыдущую версию файла. В середине 2000-х гг. Система контроля версий Subversion (SVN) был создан для замены CVS. Это быстро завоевывает популярность как система контроля версий проекта OSS.[7]

Многие проекты с открытым исходным кодом сейчас используют распределенные системы контроля версий, которые масштабируются лучше, чем централизованные репозитории, такие как SVN и CVS. Популярные примеры: мерзавец, используемый Ядро Linux, и Mercurial, используемый Python язык программирования.[нужна цитата ]

Трекеры ошибок и списки задач

Для большинства крупномасштабных проектов требуется система отслеживания ошибок, чтобы отслеживать статус различных проблем в процессе разработки проекта. Некоторые средства отслеживания ошибок включают:

  • Bugzilla - веб-трекер ошибок от Mozilla.
  • Отслеживание ошибок Mantis - веб-трекер ошибок PHP / MySQL.
  • Trac - интеграция системы отслеживания ошибок с вики и интерфейса к системе контроля версий Subversion.
  • Redmine - написан на Ruby, объединяет отслеживание проблем, вики, форум, новости, дорожную карту, планирование проектов Ганта и взаимодействует с каталогом пользователей LDAP.
  • Запросить трекер - написано на Perl. По умолчанию задано CPAN модули - см. rt.cpan.org.
  • SourceForge и его форки предоставляют трекер ошибок как часть своих услуг. В результате многие проекты, размещенные на SourceForge.net и подобных сервисах, по умолчанию используют его.
  • JIRA - Веб-инструмент управления проектами и отслеживания проблем от Атласский.

Инструменты тестирования и отладки

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

А отладчик - это компьютерная программа, которая используется для отладки (а иногда и тестирования или оптимизации) других программ. Отладчик GNU (GDB) - пример отладчика, используемого при разработке программного обеспечения с открытым исходным кодом. Этот отладчик предлагает удаленную отладку, что делает его особенно применимым для разработки программного обеспечения с открытым исходным кодом.[нужна цитата ]

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

Управление пакетами

А система управления пакетами представляет собой набор инструментов для автоматизации процесса установки, обновления, настройки и удаления пакетов программного обеспечения с компьютера. В Менеджер пакетов Red Hat (Об / мин) для .rpm и Расширенный инструмент упаковки (APT) для .deb формат файла, это системы управления пакетами, используемые в ряде дистрибутивов Linux.[нужна цитата ]

Публикация проекта

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

  1. В Каталог бесплатных программ

Статьи:

  1. Еженедельные новости Linux
  2. IBM developerWorks

Смотрите также

Рекомендации

  1. ^ Раймонд, Э. (1999). Собор и базар. О'Рейли Получено из http://www.catb.org/~esr/writings/cat Cathedral-bazaar/. Смотрите также: Собор и базар.
  2. ^ Бар М. и Фогель К. (2003). Разработка с открытым исходным кодом с помощью CVS, 3-е издание. Paraglyph Press. (ISBN  1-932111-81-6)
  3. ^ Шарма, С., Сугумаран, В. и Раджагопалан, Б. (2002). Фреймворк для создания сообществ гибридного программного обеспечения с открытым исходным кодом. Информационные системы журнал 12 (1), 7 - 25.
  4. ^ Роббинс, Дж. Э. (2003). Принятие практики разработки программного обеспечения с открытым исходным кодом (OSSE) путем принятия инструментов OSSE. Осмысление базара: перспективы открытого исходного кода и свободного программного обеспечения, осень 2003 г.
  5. ^ Абрахамссон, П., Сало, О. и Варста, Дж. (2002). Методы гибкой разработки программного обеспечения: обзор и анализ. Публикации VTT.
  6. ^ Фуггетта, А. (2003). Программное обеспечение с открытым исходным кодом - оценка, Журнал систем и программного обеспечения, 66, 77 - 90.
  7. ^ а б c «Тим Бернерс-Ли в Интернете, 25 лет: прошлое, настоящее и будущее». Проводная Великобритания.

внешние ссылки