Golang Portal
7.9K subscribers
404 photos
26 videos
7 files
438 links
Присоединяйтесь к нашему каналу и погрузитесь в мир для Golang-разработчика

Связь: @devmangx
Download Telegram
Модульный бэкенд для e-commerce с GraphQL-шлюзом и gRPC-микросервисами для управления аккаунтами, товарами, заказами и рекомендациями.

https://github.com/rasadov/EcommerceAPI

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
7👍5
Используйте пустой цикл for, чтобы создать бесконечный цикл в Go. Это может быть полезно в ряде случаев, например, для продолжения выполнения работы до завершения приложения или получения сигнала на остановку

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
🤯18👍71
How to manage configuration settings in Go web applications

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

В этой статье представлены полезные рекомендации по эффективным методам управления конфигурацией

🔹Читать

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍71👎1
WaitGroup.Go в Go 1.25 — это действительно изменение, упрощающее жизнь. Я видел (и сам допускал) ошибку, когда wg.Add(1) вызывался внутри горутины, и вот теперь эта проблема наконец ушла

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
31👍16🤔2
Пакет chans предоставляет универсальные операции с каналами, которые помогают строить конкурентные пайплайны в Go. Его цель — быть гибким, ненавязчивым и легко комбинируемым, без лишней абстракции и без отъёма контроля у разработчика

Вот упрощённый пример:
// Given a channel of documents.
docs := make(chan []string, 10)
docs <- []string{"go", "is", "awesome"}
docs <- []string{"cats", "are", "cute"}
close(docs)

// Extract all words from the documents.
words := make(chan string, 10)
chans.Flatten(ctx, words, docs)
close(words)

// Calculate the total byte count of all words.
step := func(acc int, word string) int { return acc + len(word) }
count := chans.Reduce(ctx, words, 0, step)

fmt.Println("byte count =", count)
// byte count = 22


👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍114
Если вы использовали slog, Uber Zap, Logrus, Zerolog и другие библиотеки для структурированного логирования, прочитайте эту статью: https://victoriametrics.com/blog/victorialogs-concepts-message-time-stream/

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

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
5👍4
Вышел Go 1.25.0!

🔹 Release notes: https://go.dev/doc/go1.25
🔹 Скачать: https://go.dev/dl/#go1.25.0

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥22👍31🤯1
Быстрый, современный генератор документации для Go. Использует идиоматичную работу с конкурентностью, минимальное количество зависимостей и чистые HTML-шаблоны для создания полноценно просматриваемых и фильтруемых страниц документации для Go-кодовых баз

https://github.com/navid-m/arrow

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍102
От TCP до HTTP. Свежий полный курс: почти 5 часов, бесплатно на YouTube

Весь веб построен на HTTP, и нет лучшего способа понять, как что-то работает, чем реализовать это самостоятельно. В этом курсе мы разберём все тонкости протокола HTTP/1.1 и параллельно с этим напишем свой собственный HTTP-сервер с нуля на Go

https://www.youtube.com/watch?v=FknTw9bJsXM

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
11🔥5👍4
google/wire теперь в архиве, потому что считается завершённым, а не устаревшим

Тем не менее, лучше избегать DI-фреймворков и собирать зависимости вручную.

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

Если проект уже построен вокруг DI-фреймворка или бизнес-требования слишком сложны для ручной сборки, использовать его нормально. Предпочтительный выбор — google/wire, а не uber/dig или fx, так как динамическая сборка зависимостей нежелательна; явная сборка на этапе компиляции всегда лучше.

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍113
Создание игр на Go для абсолютных новичков

Статья призывает разработчиков вернуть интерес к кодингу, создавая простые игры на Go с библиотекой Ebitengine, и объясняет базовые принципы геймдева на практике 😏

https://threedots.tech/post/making-games-in-go/

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥15👍2🤔1
Лучший совет, который я когда-либо использовал, чтобы разобраться в кодовой базе, — это попросить Mermaid-диаграмму в Cursor

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
12👍7🤯1
Два новых расширения для SQLite от Walter Wanderley

- HTTP-запросы
- MQTT publish/subscribe

https://sqlpkg.org/?q=litesql

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍94🌚2
Это должно быть обязательным к прочтению гайдом по проектированию RESTful API:
https://opensource.zalando.com/restful-api-guidelines/

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍63🤔1🌚1
Generics in Go — From Basics to Advanced for Senior Developers

Гид для опытных разработчиков по освоению дженериков в Go, от базовых концепций до практического применения

https://medium.com/@sogol.hedayatmanesh/generics-in-go-from-basics-to-advanced-for-senior-developers-887790b018d0

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍82🔥2
В Go 1.25 на Linux по умолчанию включён Container-aware GOMAXPROCS

Если вы не в курсе, в чём именно проблема с GOMAXPROCS, почитайте вот это: https://victoriametrics.com/blog/kubernetes-cpu-go-gomaxprocs/

Что важно знать:

1. Фича активируется только тогда, когда Go-программа запущена внутри cgroup с выставленными CPU-лимитами.

Если вы запускаете Go напрямую на Linux-машине (не в контейнере) или если у контейнера не заданы CPU-лимиты, рантайм не увидит никаких ограничений от cgroup и будет вести себя по-старому — использовать все доступные CPU-ядра.

2. Рантайм Go не выставляет GOMAXPROCS только на старте

В Go есть специальная горутина — system monitor (sysmon), которая работает в фоне и выполняет разные служебные задачи. Этот system monitor периодически вызывает логику container-aware GOMAXPROCS, чтобы проверить, не изменились ли CPU-лимиты.

Если вы явно задали GOMAXPROCS, такие обновления полностью прекращаются.

3. Формула: GOMAXPROCS = min(affinity_count, max(2, ceil(quota/period)))

Минимальное значение GOMAXPROCS всегда равно 2, независимо от того, насколько низко выставлен CPU-лимит контейнера (за исключением случая, когда affinity_count < 2). Любой дробный CPU-лимит округляется вверх до ближайшего целого числа

Например: если задать лимит контейнера 0.5 ядра, то всё равно получится GOMAXPROCS=2; если задать 2.3 ядра — получится GOMAXPROCS=3; если задать 8 ядер на машине с 4 ядрами — получится GOMAXPROCS=4.

Обратите внимание, что CPU affinity отличается от CPU limits:

- CPU affinity говорит: «ты можешь выполняться только на этих конкретных ядрах» (например, ядра 2, 4, 6, 8).

- CPU limits говорят: «ты можешь использовать вот столько процессорного времени» (например, эквивалент 2.5 ядер по времени выполнения).

В большинстве обычных случаев affinity_count равен общему числу CPU-ядер на ноде.

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
8👍7
Нашел годный ресурс, где автор пишет статьи по System Design. Внутри очень много схем и все они похоже отрисованы автором вручную для каждой статьи. Контент качественный, излагается почти в том порядке как на реальном интервью.

https://systemdesign.one/real-time-presence-platform-system-design/

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
12👍5👀1
Механика работы sync.Pool отлично описана здесь: https://victoriametrics.com/blog/go-sync-pool/index.html

- Почему в New() у sync.Pool следует возвращать указатель?
- Как sync.Pool связан с планировщиком или GMP-моделью?
- Что такое проблема false sharing?
- Как устроен sync.Pool внутри?
- Как работает механизм stealing в sync.Pool?
- Почему в Go прямо указано: «Любой объект, положенный в Pool, может быть удалён автоматически в любой момент без уведомления»?

Кто ещё не читал, рекомендую ✌️

👉 @GolangPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥63👍3