it-swarm-ru.tech

Причины не создавать свою собственную систему отслеживания ошибок

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

Аргументы, которые я услышал в пользу, обычно звучат так:

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

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

54
Matt Sheppard

Сначала посмотрите на эти Ohloh показатели:

    Trac:  44 KLoC, 10 Person Years,   $577,003
Bugzilla:  54 KLoC, 13 Person Years,   $714,437
 Redmine: 171 KLoC, 44 Person Years, $2,400,723
  Mantis: 182 KLoC, 47 Person Years, $2,562,978

Что мы узнаем из этих чисел? Мы узнаем, что создание еще одного отслеживателя ошибок - отличный способ тратить ресурсы!

Вот мои причины для создания собственной внутренней системы отслеживания ошибок:

  1. Вы должны нейтрализовать все бозокодеры в течение десяти или двух лет.
  2. Чтобы избежать сокращения бюджета в следующем году, вам необходимо собрать немного денег.

В противном случае нет.

79
Constantin

Я хотел бы перевернуть вопрос. ПОЧЕМУ на земле вы хотите построить свой собственный?
Если вам нужны дополнительные поля, используйте существующий пакет, который можно изменить.
Специальный репортаж? Нажмите на базу данных и сделайте это.

Полагая, что это не сложно? Попробуй тогда. Уточните это, и вы увидите список возможностей и часов. Затем, после того как список заполнен, попробуйте найти существующий пакет, который можно изменить, прежде чем реализовывать свой собственный.

Короче говоря, не изобретайте велосипед, когда другому просто нужно немного подстроиться.

39
Lars Mæhlum

Программисты любят создавать свою собственную систему тикетов, потому что, увидев и использовав десятки из них, они знают об этом все. Таким образом, они могут оставаться в зоне комфорта.

Это похоже на посещение нового ресторана: это может быть полезным, но это сопряжено с риском. Лучше заказать пиццу еще раз.

Там также есть большой факт принятия решений: всегда есть две причины что-то делать: хорошая и правильная. Мы принимаем решение ("Создай свое"), затем оправдываем его ("нам нужен полный контроль"). Большинство людей даже не знают об их истинной мотивации.

Чтобы изменить их мнение, вы должны атаковать реальную причину, а не оправдание.

19
MattW.

Не придуманный здесь синдром!

Создать свой собственный баг-трекер? Почему бы не создать свой собственный почтовый клиент, инструмент управления проектами и т.д.

Как Омер ван Клоэтен говорит в другом месте, заплати сейчас или заплати позже.

14
Stu Thompson

Есть третий вариант, ни купить, ни построить. Там куча хороших бесплатных. Например:

Использование собственного трекера ошибок для любого использования, кроме обучения, не является хорошим расходом времени.

Другие ссылки:

12
Anthony

Я бы просто сказал, что это вопрос денег - покупка готового продукта, который, как вы знаете, полезен для вас (а иногда даже не покупка, если он бесплатный), лучше, чем необходимость идти и разрабатывать его самостоятельно. Это простая игра заплати сейчас против заплати позже.

10
Omer van Kloeten

Во-первых, против аргументов в пользу построения собственного:

Желая "съесть собственную собачью еду" с точки зрения какой-то внутренней веб-инфраструктуры

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

Хорошо, если они должны построить структуру, пусть она будет органично развиваться из процесса создания фактического программного обеспечения, которое ваш бизнес использует, чтобы зарабатывать деньги.

Требуется какой-то узкоспециализированный отчет или возможность настраивать некоторые функции каким-то якобы уникальным способом

Как уже говорили другие, возьмите один из множества прекрасных трекеров с открытым исходным кодом и настройте его.

Полагая, что не сложно построить систему отслеживания ошибок

Итак, я написал первую версию своего BugTracker.NET всего за пару недель, не имея предварительных знаний C #. Но сейчас, спустя 6 лет и пару тысяч часов, все еще есть большой список отмененных запросов на функции, поэтому все зависит от того, что вы хотите, чтобы система отслеживания ошибок делала. Сколько стоит интеграция с электронной почтой, контроль исходного кода, разрешения, рабочий процесс, отслеживание времени, оценка расписания и т.д. Отслеживание ошибок может быть основным, основным приложением.

Какие аргументы вы могли бы использовать для поддержки покупки существующей системы отслеживания ошибок?

Не нужно покупать. Слишком много хороших программ с открытым исходным кодом: Trac , Mantis_Bug_Tracker , мой собственный BugTracker.NET, чтобы назвать несколько.

В частности, какие функции кажутся простыми, но трудно реализуемыми или сложными и важными, но часто упускаются из виду?

Если вы создаете это только для себя, то вы можете использовать множество ярлыков, потому что вы можете делать жесткие выводы. Если вы создаете его для большого количества разных пользователей, в разных сценариях, то поддержка конфигурации очень сложна. Настраиваемый рабочий процесс, настраиваемые поля и разрешения.

Я думаю, что две функции, которые должен иметь хороший баг-трекер, и обе ( FogBugz и BugTracker.NET имеют) 1) интеграция как входящей, так и исходящей электронной почты, так что весь разговор об ошибке связан с ошибкой, а не с отдельной веткой электронной почты, и 2) утилита для превращения скриншота в сообщение об ошибке всего за пару кликов.

8
Corey Trager

Самым основным аргументом для меня будет потеря времени. Я сомневаюсь, что это может быть завершено менее чем через месяц или два. Зачем тратить время, когда есть так много хороших систем отслеживания ошибок? Дайте мне пример функции, которую вы должны настроить, и которая недоступна.

Я думаю, что хорошая система отслеживания ошибок должна отражать ваш процесс разработки. Весьма нестандартный процесс разработки по своей сути вреден для компании/команды. Большинство гибких практик предпочитают Scrum или подобные вещи, и большинство систем отслеживания ошибок соответствуют таким предложениям и методам. Не слишком бюрократизируйся по этому поводу.

6
Slavo

Система отслеживания ошибок может быть отличным проектом для начинающих разработчиков. Это довольно простая система, которую вы можете использовать для обучения их вашим правилам кодирования и так далее. Заставить младших разработчиков создать такую ​​систему сравнительно дешево, и они могут ошибиться в том, что клиент не увидит.

Если это мусор, вы можете просто выбросить его, но вы можете дать им ощущение того, что работа там уже важна для компании, если она используется. Вы не можете заплатить начинающему разработчику, который сможет испытать полный жизненный цикл и все возможности для передачи знаний, которые принесет такой проект.

5
Garry Shutler

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

Сейчас мы снова рассматриваем системы отслеживания ошибок и серьезно подумываем о переходе на Mantis и использовании Mantis Connect для добавления собственных собственных дополнительных функций. Количество усилий при развертывании нашей собственной системы слишком велико.

Я думаю, что мы также должны смотреть на FogBugz :-)

5
dcraggs

Самое главное, где вы будете отправлять сообщения об ошибках для вашего баг-трекера до его завершения?

Но серьезно. Инструменты уже существуют, нет необходимости изобретать велосипед. Модификация инструментов отслеживания для добавления определенных специфических функций - это одно (я уже модифицировал Trac ) ... переписывать один просто глупо.

Самая важная вещь, на которую вы можете обратить внимание, это то, что если все, что они хотят сделать, это добавить пару специализированных отчетов, то для этого не требуется базового решения. И, кроме того, последнее место, в котором "ваше домашнее решение" имеет значение, предназначено для внутренних инструментов. Кого волнует, что вы используете внутри, если оно выполняет работу так, как вам нужно?

5
Loren Segal

Будучи программистом, работающим над и без того критической (или, по меньшей мере, важной) задачей, не следует позволять себе отклоняться, пытаясь разработать что-то, что уже доступно на рынке (открытый или коммерческий).

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

Сначала: 1. Выберите платформу, на которой будет работать ваша система ошибок (Java, PHP, Windows, Linux и т.д.) 2. Попробуйте найти инструменты с открытым исходным кодом, которые доступны (под открытым исходным кодом, я имею в виду как коммерческие, так и бесплатные инструменты) на платформе Вы выбрали 3. Потратьте минимальное время, чтобы попытаться настроить в соответствии с вашими потребностями. Если возможно, не тратьте время на настройку

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

4
Ram Prasad

Основываясь на том, что сказали другие люди, а не просто скачать бесплатно/с открытым исходным кодом. Как насчет загрузки, а затем полностью изменить его для ваших собственных нужд? Я знаю, что был обязан сделать это в прошлом. Я взял установку Bugzilla, а затем изменил ее для поддержки регрессионного тестирования и отчетов о тестировании (это было много лет назад).

Не изобретайте колесо, если вы не уверены, что можете построить колесо более круглое.

3
Mark Ingram

Я был на обеих сторонах этой дискуссии, поэтому позвольте мне быть немного двое здесь.

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

Теперь, когда я стал старше и снова столкнулся с тем же вопросом, я просто решил пойти с FogBugz. Это делает 99% от того, что нам нужно, и затраты в основном равны 0. Кроме того, Джоэл отправит вам личные письма, чтобы вы чувствовали себя особенным. И в конце концов, разве не проблема, ваши разработчики думают, что это сделает их особенными?

2
Jonathan Beerhalter

Большинство разработчиков считают, что у них есть уникальные возможности, которых нет ни у кого, и поэтому они могут создать систему, которая в некотором роде уникальна.

99% из них не правы.

Каковы шансы, что в вашей компании есть сотрудники в 1%?

2
LepardUK

Я бы сказал, что одним из самых больших камней преткновения будет мука над моделью данных/рабочим процессом. Я предполагаю, что это займет долгое время и потребует много аргументов о том, что должно произойти с ошибкой при определенных обстоятельствах, что действительно является ошибкой и т.д. Вместо того, чтобы тратить месяцы на споры "туда-сюда", если вам нужно было просто развернуть предварительно созданную систему, большинство людей научатся ее использовать и извлекать из нее максимум пользы, независимо от того, какие решения уже исправлены. Выберите что-нибудь с открытым исходным кодом, и вы всегда сможете настроить его позже, если это будет необходимо - это будет намного быстрее, чем раскручивать свой собственный с нуля.

2
Bobby Jack

На этом этапе, без большого нового направления в отслеживании ошибок/продаже билетов, было бы просто заново изобретать колесо. Который, кажется, является тем, что все остальные думают, вообще.

2
Tony Pitale

Ваши обсуждения начнутся с того, что представляет собой ошибку, и перейдут к тому, какой рабочий процесс применить, и закончатся массивным спором о том, как управлять проектами разработки программного обеспечения. Вы действительно этого хотите? :-) Нет, подумал - иди и купи один!

2
Rikalous

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

В противном случае, если вы пытаетесь продемонстрировать рамки, все хорошо. Просто убедитесь, что вставили соответствующие оговорки.

Людям, которые считают, что систему отслеживания ошибок несложно построить, строго соблюдайте SDLC. Получить все требования заранее. Это, безусловно, поможет им понять сложность. Как правило, это те же люди, которые говорят, что поисковую систему не так сложно построить. Просто текстовое поле, кнопка "поиск" и кнопка "Мне повезет", а кнопка "Мне повезет" можно выполнить на втором этапе.

1
Kinjal Dixit

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

Это почти наверняка не стоит затрат (с точки зрения времени разработчика). Просто купите JIRA .

Если вам нужны дополнительные отчеты для вашей системы отслеживания ошибок, вы можете добавить их, даже если вам придется делать это, напрямую обращаясь к основной базе данных.

1
Dan Dyer

Вопрос в том, что ваша компания платит вам? Это писать программы, которые будут использовать только вы? Очевидно нет. Таким образом, единственный способ оправдать затраты времени и средств на создание системы отслеживания ошибок, если она стоит меньше затрат, связанных с использованием даже бесплатной системы отслеживания ошибок.

Там вполне могут быть случаи, когда это имеет смысл. Вам нужно интегрироваться с существующей системой? (Отслеживание времени, оценка, требования, QA, автоматизированное тестирование)? У вас есть какие-то уникальные требования в вашей организации, связанные с соответствием SOX, которые требуют определенных элементов данных, которые было бы трудно собрать?

Вы находитесь в крайне мрачной обстановке, которая приводит к значительному простою между проектами?

Если ответ на эти типы вопросов положительный, то во всех отношениях аргумент "купить" против построения скажет "построить".

1
fuzzbone

Потому что Trac существует.

И потому, что вам придется обучать новых сотрудников на вашем заказном программном обеспечении, когда они, скорее всего, будут иметь опыт работы с другими системами, которые вы можете построить, а не выбрасывать.

1
Marc Gear

Я согласен со всеми причинами, чтобы НЕ. Мы пытались какое-то время использовать то, что есть, и все равно писали свои. Зачем? Главным образом потому, что большинство из них слишком громоздки, чтобы привлечь кого-либо, кроме технических специалистов. Мы даже попробовали basecamp (который, конечно, не предназначен для этого и потерпел неудачу в этом отношении).

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

Но это определенно заняло много часов, чтобы закодировать; стал БОЛЬШИМ любимым проектом; много выходных.

Если вы хотите проверить это: http://www.archerfishonline.com

Хотелось бы получить некоторые отзывы.

1
Rich Goidel

Потому что это не оплачиваемое время или даже очень полезное, если вы не собираетесь его продавать.

Есть совершенно хорошие системы отслеживания ошибок, например, FogBugz .

1
pro

Я работал в стартапе в течение нескольких лет, когда мы начали с GNATS , инструмента с открытым исходным кодом, и по сути построили нашу собственную сложную систему отслеживания ошибок. Аргумент состоял в том, что мы избежим тратить много денег на коммерческую систему, и мы получим систему отслеживания ошибок, точно соответствующую нашим потребностям.

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

1
Rangachari Anand

Используйте программное обеспечение с открытым исходным кодом как есть. Наверняка есть ошибки, и вам понадобится то, чего еще нет или ожидается исправление ошибки. Это происходит все время. :)

Если вы расширяете/настраиваете версию с открытым исходным кодом, вы должны поддерживать ее. Теперь приложение, которое должно помочь вам в тестировании приложения для зарабатывания денег, станет бременем для поддержки.

1
maestroQC

Мы сделали это ... несколько раз. Единственная причина, по которой мы построили нашу собственную, состоит в том, что это было пять лет назад, и не было очень много хороших альтернатив. но сейчас есть множество альтернатив. Главное, что мы узнали при создании нашего собственного инструмента, это то, что вы потратите много времени на его работу. И это время, которое вы могли бы выставлять счета за свое время. Как малый бизнес, гораздо разумнее платить ежемесячную плату, которую вы можете легко окупить за один или два оплачиваемых часа, чем тратить все это время на свои собственные. Конечно, вам придется пойти на некоторые уступки, но в конечном итоге вам будет намного лучше.

Что касается нас, мы решили сделать наше приложение доступным для других разработчиков. Проверьте это на http://www.myintervals.com

1
jjriv

Я думаю, что причина, по которой люди пишут свои собственные системы отслеживания ошибок (по моему опыту):

  1. Они не хотят платить за систему, которую, по их мнению, относительно легко построить.
  2. Программист эго
  3. Общее недовольство опытом и решениями существующих систем.
  4. Они продают это как продукт :)

На мой взгляд, главная причина, по которой большинство систем отслеживания ошибок не работали, заключалась в том, что они не обеспечивали оптимального взаимодействия с пользователем, и работа с системой, в которой вы используете LOT, может быть очень болезненной, если она не оптимизирована для удобства использования.

Я думаю, что другая причина такая же, как и то, почему почти каждый из нас (программистов) когда-то создавал свои собственные CMS или CMS-фреймворки (виновные по обвинению). Просто потому что ты можешь!

1
Sarat

Я не думаю, что создание собственной системы отслеживания сравнительно легко построить, и, конечно, она не будет соответствовать платному или открытому решению. В большинстве случаев я бы выбрал "программистское эго" или просто наличие ИТ-отдела, который действительно не может использовать стороннее программное обеспечение и должен создавать буквально каждый используемый программный продукт.

Однажды я работал в телекоммуникационной компании, которая имела собственную собственную систему контроля версий , и это было довольно во, но вся команда была занята. ..

0
t3mujin

Не пишите свое собственное программное обеспечение только для того, чтобы вы могли "есть свой собственный корм для собак" Вы просто создаете больше работы, когда вы, вероятно, можете купить программное обеспечение, которое делает то же самое (и лучше) за меньшее время и потраченные деньги.

0
Chris Pietschmann

Я построил свои собственные системы отслеживания ошибок. Я тоже подумал: "Как это может быть сложно, это просто система отслеживания ошибок" ERR - НЕПРАВИЛЬНО * - потребовалось шесть месяцев, чтобы ее кодировать.

Основная причина, по которой я испекла свою собственную, состояла в том, чтобы получить именно то, что я хотел. Другая причина была в хобби-проекте.

Я бы сказал, что это единственный раз, когда оправданно создавать свой собственный, если это хобби-проект. Ни одна компания не должна тратить свое время на это.

Мое программное обеспечение называется Bugweb кстати.

0
louism

Предположим, завтра (в следующем году), если они решат ввести популярный коммерческий инструмент с открытым исходным кодом для ВСЕХ систем отслеживания ошибок в компании, как этот инструмент сможет экспортировать все свои билеты на ошибки в другой инструмент?

Пока существует реальная потребность в специальной системе отслеживания ошибок и ответы на такие вопросы, я бы не стал беспокоиться слишком сильно.

0
anjanb

Там уже так много великих, зачем тратить время на то, чтобы заново изобрести колесо?

Просто используйте FogBugz .

0
Miles

Я согласен с большинством людей здесь. Бесполезно что-то перестраивать, когда доступно много инструментов (даже бесплатных). Если вы хотите что-то настроить, большинство бесплатных инструментов дают вам код, поиграйте с ним.

Если вы делаете новую разработку, вы не должны делать это только для себя.

0
quadri

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

0
Andy Dent