Привет, Хабр!
Меня зовут Алексей Хрисанфов. В этой статье я хочу рассказать почему и как ваши pet-проекты могут стать ключом к развитию вашей карьеры и почему нельзя недооценивать важность pet-проектов.
Что такое эти ваши pet-проекты?
Pet-проекты есть у многих разработчиков (и не только у них) и чаще всего это что-то для души и в свободное от работы время, когда можно реализовать свои идеи и реализовать их по-своему, а не так, как требует менеджер.
Такие проекты часто используются в качестве тестовых по обкатке новой технологии или же для получения необходимых навыков полного цикла разработки - от идеи до проектирования и готового проекта с подключенным CI, тестами и бекапами. Кто-то так наполняет свое резюме перед устройством на работу.
Но нельзя не упомянуть и бесчисленное количество мемов, связанных с неоконченными проектами. Думаю, это чувство знакомо многим, когда загорелся идеей, спроектировал все в голове, перенес в код и... перегорел, оставив недоделанными 5-10-20%. Или что еще хуже, просто загорелся новой другой идеей и пошла новая итерация и +1 заброшенный pet-проект.
Есть немало случаев, когда pet-проекты все таки доводятся до конца, публикуются и становятся успешными бизнесами.
Например ElasticSearch, который изначально планировался как база и поисковая система для рецептов жены основателя Шей Бэнона. Или Twitter Джека Дорси, прототип которого был написан на хакатоне. К этому списку можно добавить и GitHub и Slack.
К плюсам таких проектов можно отнести полную свободу действий, отсутствие сроков и иных творческих рамок и отличную возможность отвлечься от рабочих и порой рутинных задач.
А вот времени и сил на такие проекты часто не хватает, в силу того, что они, в основном, в свободное от основной работы время.
Со своей же стороны я рекомендую доводить до конца жизнеспособные проекты.
Моя true стори
У меня есть не мало своих pet-проектов, часть из которых благополучно забыта в папке Projects, часть даже не доделана, а часть доведена до production и работает по сей день.
Но начнем сначала. В один из декабрьских вечеров несколько лет назад меня посетила мысль, что я хочу понять, как много времени и на каких сайтах я провожу. Быстрый поиск привел меня к магазину Google Chrome и нескольким расширениям, которые мне не понравились по разных причинам. А не сделать ли свое расширение, подумал я? Мне было интересно, как расширения работают, что у них под капотом и как происходит взаимодействие с браузером. Разберусь и сделаю полезное и удобное (по крайней мере для себя), хоть и не уникальное расширение.
Решение было принято, энтузиазм был, и в течение нескольких недель первая версия была готова и опубликована в магазине Chrome. Регистрация в магазине кстати, что тогда, что сейчас стоит все также 5$.
Далее пойдут некоторые технические детали.
Расширения можно писать на JavaScript (TypeSctipt) и использовать привычные нам фреймворки (Vue, Angular, React, etc). Причем, весь исходный код любого расширения можно увидеть самостоятельно. Да, он чаще всего минифицирован, но открыт. Обфускация запрещена правилами магазина Google Chrome. Для любого расширения должен быть сформирован файл манифеста (текущая версия 3), в котором мы указываем массу параметров нашего приложения и все разрешения, которые пользователь увидит при установке и должен подтвердить, если хочет использовать расширение.
В целом, разработка расширения не сильно отличается от разработки любого фронта, с тем лишь исключением, что мы работаем только внутри контекста браузера. Любое, даже самое незначительное обновление требует времени на одобрение со стороны магазина, поэтому это нужно всегда иметь ввиду. Т.е. когда нашел критический баг и быстро его пофиксил, не получится расширения быстро обновить у всех пользователей.
Добавление новых permission после публикации потребует дополнительного подтверждения от пользователей, а они этого очень не любят, прямо очень. Поэтому все возможные разрешения лучше продумать сразу. Но это уже относится к специфике работы магазина Chrome.
Очень приятной стороной расширений является то, что их можно поставить на любые браузеры. И самое главное, что любой магазин расширения (Edge, Chrome) сразу выполняет некоторую работу по продвижению нашего продукта. Для этого надо указать ключевые слова (только в Edge) и написать SEO оптимальное имя и короткое описание внутри манифеста и большое описание в магазине с указанием всех возможностей нашего приложения. Т.е. пользователи ищут что-то в гугле и он показываем им релевантные ответы со ссылками на наше расширение в магазине. Очень удобно.
Продолжение true стори
В течение нескольких недель я написал первую версию приложения и опубликовал ее в магазине Chrome. Название придумал не слишком хорошее и цепляющее, но потом менять его уже было поздно.
Знакомьтесь, расширение Web Activity Time Tracker. Расширение отслеживает сколько времени вы проверили на любых сайтах, показывает детальную аналитику, позволяет блокировать любые сайты, шлет уведомления в конце дня и еще несколько других полезных функций.
Забрасывать проект я не собирался, поэтому в свободное от работы время занимался его доработкой, развитием и продвижением. Добавил в различные каталоги программ, сделал пост на ProductHunt, рекомендовал на Reddit и т.д. Денег на маркетинг потратил ровно 0. Только время.
Сделал репозиторий сразу open-source. Проект рос органически, получал отзывы, запросы на фичи. На Github люди стали писать issue со своими предложениями, некоторые сами улучшали функционал и отправляли pull request. Я проверял, мы обсуждали варианты решения и после этого публиковал изменения в магазине google. В этом вся прелесть таких открытых проектов, которые дают возможность разработчику поработать вместе с людьми с разных стран над интересным вам проектом.
Спустя какое-то время прикрутил донаты и на мое удивление люди скидывали мне на кофе через BuyMeACoffee. С лихвой покрывал свое хобби с этих денег.
Таким образом проект рос органически, приносил мне моральное удовлетворение от того, что люди пользовались, довольны проектом, и он решает те задачи, которые пользователи хотят решить. Короче, win-win.
Cейчас активных дневных пользователей более 32000 в chrome и около 6000 в edge, есть лэндинг wetracker.online. И очень хороший рейтинг.
Развитие, комьюнити, польза для конечных пользователей, классные рейтинг и много хороших отзывов это конечно хорошо, но вернемся к теме поста, причем здесь новые возможности и развитие карьеры? Почти два года назад меня нашла одна компания из США, которая имеет похожие продукты и которая хотела бы приобрести мой проект, а значит и аудиторию и нанять меня.
После не быстрой переписки, встреч в zoom, согласования всех нюансов, было принято решение. К сожалению, из-за событий 2022 года, проект они не приобрели в силу возможных репутационных рисков, но работу я получил.
Говоря про новые возможности, не могу не отметить работу с многонациональной командой. После работы в российских командах, это определенно новый и интересный опыт и другой подход к сотруднику, к его времени, его работе. Понимаю, выборка ни разу не репрезентативная и это всего лишь одна компания, но определенно заставляет задуматься, что и так можно работать.
Как потом я узнал, мой кейс абсолютно не уникальный случай. Таких примеров можно найти массу, когда люди на своем энтузиазме делают проект, развивают его, причем он не обязательно должен быть коммерческим. А потом приходят большие дяди, покупают проект и нанимают этих же людей.
Лично знаком с ребятами из Турции, которые вдвоем сделали бесплатное приложение для android, развивали его в свободное время, и спустя какое-то время их приложение купили и они получили очень вкусный оффер.
Важно понимать, что нанимают не просто +N сотрудников в компанию, а нанимают заинтересованных с горящими глазами людей, которые готовы и хотят работать и развивать проект, предлагать множество идей и вариантов развития продукта.
Можно возразить, что не все захотят продавать свой продукт большим компаниям, которые могут потом из него сделать непонятно что. Конечно же, и такое возможно. Но здесь речь идет о потенциальных возможностях, которые могут открыться перед разработчиком. А вот упускать их или нет это уже дело каждого.
Кроме вышеописанного варианта, можно просто продать расширение. Мне регулярно поступают такие предложения. А дальше уже идут переговоры по цене.
Еще одна попытка
Год назад я предпринял еще одну попытку создания простого, но полезного инструмента. И тоже не уникального. Буквально за пару дней я написал небольшое расширение Clean YouTube, которое удаляет многие компоненты на страницах YouTube. Например shorts, комментарии, рекомендованные видео (а это просто черная дыра по поглощению времени ?), строку поиска, лайки, подписки и т.д. И как киллер фича сделал режим Clean Mode, когда на странице отображается только видео плеер. Сам этой фичей пользуюсь постоянно и она правда помогает экономить время и не отвлекаться лишний раз на чтение комментариев или просмотр похожих видео.
Совсем недавно этому расширению исполнился год, поэтому можно повести итоги. Это 7к активных пользователей и 4,9 рейтинг. ?
И все пользователи - это только органический поиск через гугл и внутри магазина. В целом, неплохой результат при минимуме усилий.
Буду рад подискутировать на эту тему. И оставлю здесь свой телеграмм канал @releasetomorrow. Там я делюсь своими мыслями о разработке, рассказываю о развитии других своих проектов, один из которых продал в этом году.
Комментарии (21)
Arick2284
29.12.2024 13:37Отличная история, показывающая, что точка роста может быть в любом месте. Главное лишь то, чтобы на зародышах проекта вами движила сама идея, её реализованный в будущем облик. На одном лишь желании заработать, к сожалению, не вывезешь, тут нужна искра азарта, интереса!
AlexStigmat Автор
29.12.2024 13:37Спасибо! Да, когда делаешь проект для заработка, это уже что-то коммерческое, а не пет проект, который часто пишется для души. Но справедливости ради, даже когда делаешь бизнес проект, то без азарта, без энтузиазма, без горящих глаз тоже бывает очень трудно вывести, особенно в тяжелые или кризисные времена.
xSPb
29.12.2024 13:37Хорошая история! В принципе, подобный опыт - это независимое подтверждение личных и профессиональных качеств специалиста, которые гораздо труднее сымититровать, чем опыт, указанный в резюме. Соответственно, вероятность принятия на работу человека, который знает и умеет делать нужные вещи повышается. Это я плюсы со стороны потенциального работодателя описываю.
georgiyozhegov
29.12.2024 13:37В статье вы говорили о пет-проектах связанных с вебом. Как думаете, можно ли развить до того же масштаба проект языка программирования? Вопрос конечно слишком объёмный, но все же.
AlexStigmat Автор
29.12.2024 13:37С языком программирования все очень сильно упирается в комьюнити. Т.е. нужно сначала развивать комьюнити и на его основе и потребностей уже можно смотреть в сторону языка.
kenomimi
29.12.2024 13:37Любой продукт в текущее время - это 10% инженерии (тот самый пет-проект), 10% рандома (попасть в нужное место в нужное время), и 80% маркетинга (заставить ЦА думать, что твоя хрень очень нужна им). Ты можешь быть богом разработки, но без команды талантливых продажников и миллиончиков на раскрутку всё умножается на ноль. А если ты сам, будучи хорошим инженером, еще богат и талантливый продажник... Такой редчайший гений и так уже нашел свое теплое место.
Так что надеятся вывести свой пет-проект в прод глупо. Но вот для резюме и трудоустройства в целом такие проекты крайне полезны.
hifskujykdwgr
29.12.2024 13:37Любой продукт в текущее время
позволю себе не согласиться: не любой. Как один из способов, можно постараться найти (это сложно, но возможно) узкую нишу с некоторой потребностью и эту потребность закрыть. На этом можно даже заработать что-то. Но, конечно, такое на поверхности не валяется. Скорее, если увлекаешься каким-то хобби и знаешь подноготную + потребности людей в сообществе - можно сделать реально что-то полезное.
AlexStigmat Автор
29.12.2024 13:37Про проценты почти согласен (я бы только поставил 20-25% инженерии и 70-65% маркетинга). Но даже 10% вероятность успешного рандома это достаточно много. Умножим ее на количество попыток и полученный опыт во всех предыдущий итерациях и на выходе получаем хороший результат в виде опыта реализации продуктов полного цикла, новых знаний, знакомств и кучи набитых шишок.
Не всем подходит такой подход, т.к. это изначально игра с низкими вероятностями.
Enfriz
29.12.2024 13:37Интересная статья, но всё-таки это ошибка выжившего. На один стрельнувший пет-проект приходится тысячи доведённых до продакшена, но не востребованных.
asbel
29.12.2024 13:37Мораль простая, реализовывать проекты нужно на площадках, которые предлагают маркетинговые услуги. Потому что самому заниматься потом маркетингом слишком дорого и затратно по ресурсам. Далее, если проект кому-то нужен, его найдут и он выстрелит
AlexStigmat Автор
29.12.2024 13:37Такие платформы со встроенным маркетингом и продвижением очень хорошо бустят проекты, как следствие добавляют дофамина и провоцируют дальше работать. Ты, как автор, видишь хоть и небольшой, но органический рост и сосредоточен, в основном, только на развитии самого продукта.
Egorfing
29.12.2024 13:37Интересная история, сейчас тоже в процессе развития своего приложения и в дополнение делаю расширение для хрома.
AlexStigmat Автор
29.12.2024 13:37Спасибо! Желаю удачи с расширением! Если будут вопросы, стучите в личку, чем смогу помогу)
kosmonavt76
29.12.2024 13:37Начинал свой программно-аппаратный проект для узкой области применения - мотоциклы. Изначально делал только для себя, затем постепенно вывел в продакшн. В процессе довольно значительно всё модифицировал, проводил испытания, уменьшал себестоимость оставляя или улучшая функционал и надежность. С продажами хорошо сработало сарафанное радио. Сейчас большая часть заказов идёт с сайта. В ВК есть группа, но там заказов стало меньше. В целом как хорошее дополнение к основной работе. Уходить только в него смысла не вижу, учитывая невозможность/большие сложности экспорта - у нас же это сезонная вещь.
starwalkn
Проще ли разработчику, который занимается или занимался фронтенд разработкой запустить, и, возможно, даже продать свой проект? На мой взгляд - да, потому что с помощью таких инструментов можно реализовать конечный продукт для клиента, а не только для других разработчиков. А вот бэкенд-разработчику, который не знаком с тем же JS/TS - ИМХО, в этом плане сложнее. Но хотелось бы услышать ваше мнение на этот счет.
sovaz1997
Мне кажется, это не так важно)
В плане, что фронтендеру, как и бекендеру, придется разбираться с другими областями. Если он будет сам делать весь продукт, ему и дизайн понадобится, и маркетинг. Вообще, всё индивидуально ч конечно. Но однозначно, придется выходить за рамки своих компетенций
AlexStigmat Автор
Согласен с @sovaz1997 что в проектах, которые делаешь в одиночку, чаще всего приходится выходить за границы своих компетенций. Да, качество кода/дизайна/UX/текста (нужное подчеркнуть) будет уступать, чем у специалиста в этой области, но освоение на базовом уровне не требует сотен или тысяч человекочасов. И вы сами сказали, что ему будет сложнее, но это не значит, что это невозможно.
Dadadam999
В этом плане можно привести в пример геймдев. Много инди разработчиков являются "оркестрами", т.е. делают всё в игре сами, от рисования спрайтов, до кода. Да, их качество в разных сферах отличается, например человек может хорошо писать код, но плохо работать со звуками, однако мало кого из конечных пользователей, а именно игроков волнует, как устроена игра внутри. Многим игрокам важен геймплей, интересные механики и адекватный UX.
Тоже самое и с пед проектами. Пользователям и потенциальным инвесторам, всё-равно на качество кода и сколько новомодных фреймворков и библиотек в нём было использовано. Это важно нам, чтобы успешно поддерживать и расширять проект.
Пользователей интересует идея и её юзабельная реализация, а инвесторов потенциальная прибыль. Поэтому, базового уровня знания технологий вполне достаточно. Более того многие проекты, что сейчас популярны изначально делались людьми, которые особыми навыками программирования не обладали. Их проекты переписывались множество раз. Потому что главное не реализация, а идея. Это понимают все. Потому что если идея хорошая, то реализацию можно всегда улучшить (банально нанять токовую команду или продать всё компании, что перепишут всё с нуля), а вот идеальная реализация при плохой идеи нафиг никому не нужна.
RedHead
Сам путь и есть цель.