Библиотека Go-разработчика | Golang
23.3K subscribers
2.07K photos
42 videos
87 files
4.44K links
Все самое полезное для Go-разработчика в одном канале.

По рекламе: @proglib_adv

Учиться у нас: https://proglib.io/w/32d20779

Для обратной связи: @proglibrary_feeedback_bot

РКН: https://gosuslugi.ru/snet/67a4a8c2468
Download Telegram
🚨 Что на самом деле происходит с увольнениями в ИТ

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

🎯 Что мы выясним:
→ Реальные причины увольнений
→ Сколько времени нужно на поиск работы
→ Самые безумные истории смены работы

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

👉 Пройдите опрос за 3 минуты и помогите всему сообществу: https://clc.to/yJ5krg
📰 Дайджест недели

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

Монолит: хороший, плохой и уродливый

Анализ трёх типов монолитов: модульного (готового к масштабированию), распределённого (маскирующегося под микросервисы) и традиционного (трудного в сопровождении).

Рассматриваются их особенности, преимущества и недостатки, а также влияние на поддержку и развитие систем.

Нативная поддержка FIPS 140-3 без сторонних библиотек

Go 1.24 представил встроенную поддержку FIPS 140-3, устраняя необходимость в сторонних криптобиблиотеках. Это упрощает соответствие требованиям безопасности для государственных и регулируемых отраслей.

Как защитить API: 6 ключевых аспектов безопасности

Revive v1.10.0

Cup O’ Go эпизод №112

🐸Библиотека Go-разработчика #свежак
Please open Telegram to view this post
VIEW IN TELEGRAM
🍴 Топ-вакансий для Go-разработчиков за неделю

Senior Developer BE Golang — от 300 000 ₽, Гибрид (Москва)

GoLang-программист — Гибрид/Офис (Волгоград)

Разработчик в S3 — от 300 000, Удаленно (Москва/Санкт-Петербург/Новосибирск)

Software Engineer (Golang) — от 3 650 €, Удаленно (Испания, Сербия, Кипр — помощь с переездом)

Senior Go developer — Удаленно (Москва).

Бустер — Удалёнка по всей планете Земля.

➡️ Еще больше топовых вакансий — в нашем канале Go jobs
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2🔥1
🧑‍💻 Ускоряем разработку на Go

В Go есть встроенный инструмент go generate, который генерирует код по директивам в коде.

Генерация кода помогает избегать рутинного написания однотипного кода, поддерживать DRY и улучшать структуру проектов. Разберёмся как это применить.

1. Добавляем директиву //go:generate

В нужном файле добавьте комментарий с инструкцией генерации. Пример для генерации моков с помощью mockgen:
//go:generate mockgen -source=service.go -destination=mock_service.go -package=yourpackage
package yourpackage

type Service interface {
DoSomething(input string) error
}


2. Запускаем генерацию

В терминале в каталоге с исходным файлом выполните:
go generate


3. Использование с другими инструментами

go generate запускает любую shell-команду, поэтому можно использовать stringer для генерации методов String() по константам: //go:generate stringer -type=MyEnum.

Также можно использовать собственные скрипты на Go или Bash для генерации конфигураций или шаблонов.

Пример:
package colors

//go:generate stringer -type=Color
type Color int

const (
Red Color = iota
Green
Blue
)


Запустив go generate, будет создан файл color_string.go с реализацией метода String() для перечисления Color.

💡 Советы по использованию go generate

• Помещайте директивы //go:generate непосредственно перед декларацией, к которой они относятся.

• Сохраняйте сгенерированные файлы рядом с исходниками и не редактируйте их вручную.

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

• Используйте go generate ./... для запуска генерации рекурсивно во всех поддиректориях.

💬 Используете генерацию кода или предпочитаете ручной контроль всех строчек кода? Делитесь мыслями в комментариях 👇

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2182🔥2
⚡️ Ошибки, которые ставят под угрозу безопасность вашего API

Зачем ждать взлома, если можно предотвратить атаки заранее? В карточках — основные аспекты, которые помогут надёжно защитить ваш API и избежать распространённых ошибок.

➡️ Прочитайте статью и внедрите лучшие практики в свой проект

🐸Библиотека Go-разработчика
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍12🥱43🔥2
💻 Как измерить масштаб изменений между коммитами

Часто при работе с большими репозиториями нужно увидеть количество изменений, а не построчную разницу. Для этого есть команда:
git diff --stat <commit1> <commit2>


Это покажет статистику изменений между двумя коммитами, в каком файле сколько строк изменено, создано или удалено.

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍184🔥3
⚡️ Обработку ошибок в Go не будут менять

Команда разработки Go столкнулась с трудностями при попытке упростить этот процесс через синтаксические изменения языка.

За последние несколько лет разработчики пытались улучшить обработку ошибок через:

• Механизм check/handle в 2018.
• Функцию try в 2019.
• Предложение с оператором «?» в 2024.

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

➡️ Читать размышления разработчиков

🐸Библиотека Go-разработчика #свежак
Please open Telegram to view this post
VIEW IN TELEGRAM
👍64😢126😁3👾2
Чек-лист для создания и запуска пет-проекта

Составили для вас чек-лист, который поможет вам структурировать процесс создания вашего пет-проекта. Описали всё от 0 до 1.

1. Определите цель проекта

• Сформулируйте, зачем вы хотите создать этот проект (например, улучшить навыки, создать портфолио, решить реальную задачу).

• Разбейте цель на более мелкие, измеримые задачи.

2. Выберите интересную и полезную тему


• Выберите тему, которая вам интересна, чтобы поддерживать мотивацию.

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

3. Составьте план разработки


• Определите основные этапы и сроки выполнения.

• Разбейте проект на небольшие задачи и milestones.

• Оцените, сколько времени вы готовы уделять проекту.

4. Выберите стек технологий

• Подумайте, какие технологии вам хочется освоить или использовать в проекте.

• Выберите инструменты и библиотеки, которые соответствуют вашим целям.

5. Настройте репозиторий и версионный контроль

• Создайте репозиторий на GitHub, GitLab или другом сервисе для хранения кода.

• Настройте .gitignore и добавьте базовые файлы конфигурации.

6. Подготовьте рабочее окружение

• Настройте IDE, редактор кода и необходимые инструменты (например, Docker, виртуальные окружения, базу данных).

• Если проект требует внешних сервисов, настройте их.

7. Начните с прототипа


• Разработайте прототип или MVP (минимально жизнеспособный продукт).

• Сосредоточьтесь на реализации ключевой функциональности без излишних деталей.

8. Пишите тесты с самого начала

• Начинайте писать юнит-тесты для важных функций

• Убедитесь, что ваш код легко тестировать и поддерживать.

9. Документируйте


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

• Объясняйте, как запустить проект, какие зависимости использовались и как использовать функциональность.

10. Отслеживайте прогресс

• Регулярно проверяйте выполнение задач по плану.

• Спрашивайте сами у себя статус по задаче.

• Используйте инструменты для управления задачами и следите за сроками.

11. Развивайте проект

• Начните с основной функциональности и постепенно добавляйте новые возможности.

• Не пытайтесь сразу сделать всё идеально, любой проект начинается из .. и палок

12. Публикуйте проект

• Если это веб-приложение, разместите его на хостинге.

• Если это библиотека или инструмент, опубликуйте его на платформах с библиотеками, поделитесь с коллегами.

13. Продемонстрируйте результат

• Напишите блог-пост или сделайте видеопрезентацию проекта

• Поделитесь ссылкой на проект в социальных сетях, форумах или с коллегами.

14. Получайте обратную связь

• Попросите других людей проверить ваш проект и дать отзыв.

• Используйте полученные комментарии для улучшений.

15. Планируйте дальнейшее развитие

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

• Сделайте план для будущих улучшений и новых функций.

Следуйте пошагово по составленному чек-листу и тогда у вашего приложения будет шанс показать себя, а не лежать в стадии «почти MVP» несколько лет.

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍125🔥3
🫣 Устали от HR-сказок про «дружный коллектив» и «печеньки в офисе»?

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

🧐 Мы проводим исследование, чтобы выяснить:

— Как часто мы прыгаем между компаниями (и почему)
— Какие красные флаги заставляют бежать без оглядки
— Где реально находят работу
— Что бесит в HR больше всего
— Сколько кругов собеседований — это уже перебор

Результаты покажут реальную картину рынка. Без приукрашиваний. Может, компании поймут, что нужно менять, а специалисты — куда двигаться дальше.

😈 Опрос займет 5 минут, но результаты будут работать на всех нас → https://clc.to/9aaXVg
💯2👍1
🧑‍💻 Паттерны и собеседования

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

Наш подписчик спрашивает:
Какие паттерны реально используются? Пока что встречались только на собесах, ну, не считая синглтон или прототип


Нашему админу повезло в этом плане — на собеседованиях спрашивали только базу: синглтон, билдер, фабрика. На практике сталкивался с CQRS.

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

💬 Какие паттерны проектирования реально работают? Делитесь своими примерами в комментариях 👇

🐸Библиотека Go-разработчика #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍52🔥1
📹 Когда хочется просто сделать игру

Go всё больше привлекает начинающих инди-разработчиков. С библиотекой Ebiten простая аркада с графикой, звуком и физикой делается за пару дней.

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

➡️ Смотреть видео

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
9👍5🔥1
This media is not supported in your browser
VIEW IN TELEGRAM
👨‍💻 Жизненный цикл компонентов в Go по-взрослому

Когда в приложении три сервиса — можно вручную стартовать их в main(), закрыть через defer, и всё будет «работать».

А потом начинается боль: кто должен стартовать первым? Как убедиться, что компонент реально готов? Как корректно всё гасить при падении?

Знакомьтесь — GOscade, библиотека для автоматического старта, остановки и координации зависимостей в Go.

🧩 Что делает GOscade:

• Компоненты запускаются по цепочке: сначала зависимости, потом — всё остальное

• Готовность проверяется через readinessProbe(nil) — если не готов, зависящие компоненты не стартуют.

• Остановка — тоже по графу: если кто-то падает, все связанные корректно завершаются

• Всё управляется через контектс — понятно, прозрачно, канонично по-Go-шному.

Как это выглядит в коде:
func (s *Server) Run(ctx context.Context, ready func(error)) error {
go func() {
err := checkPort(s.Addr)
ready(err)
}()

if err := s.ListenAndServe(); err != nil {
return err
}

<-ctx.Done()
return s.Shutdown(context.Background())
}


Всё просто. Главное — сигнализировать о готовности и уметь завершаться по ctx.

📎 Репозиторий проекта
📎 Подробнее про проект

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍85🥱5🔥2
🥴 Средний разработчик меняет работу каждые 1,5 года

И это не потому, что мы такие непостоянные. Просто рынок показывает свое истинное лицо быстрее, чем успевают напечатать визитки.

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

😳 О чем говорим откровенно:
— Job-hopping и что за этим стоит
— Red flags, которые мгновенно убивают мотивацию
— Реальные источники вакансий (не те, что рекламируют)
— Боль от общения с рекрутерами
— Сколько этапов отбора — норма, а сколько — издевательство

Когда мы объединим опыт сотен IT-специалистов, получится настоящая карта того, как устроена индустрия. Не по версии HR-отделов, а по версии тех, кто пишет код, тестирует продукты и двигает технологии вперед.

🚀 Участвовать в исследовании → https://clc.to/9aaXVg
😁52