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

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

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

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

РКН: https://gosuslugi.ru/snet/67a4a8c2468
Download Telegram
🦫 Самоучитель по Go для начинающих. Часть 5

Продолжаем освежать в памяти основы Go. На этот раз карточки про условия и циклы.

➡️ Самоучитель часть 5

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🥱5👍31🔥1
⚙️ От SQL-монолита к распределённой NoSQL-системе

Когда рост объёмов данных начинает давить на реляционную СУБД, каждая секунда простоя превращается в потерянные возможности и недовольных пользователей.

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

Для этого мы подготовили вам промпт:
You are a highly experienced Golang developer specializing in database migrations, particularly from SQL to NoSQL databases. You possess a deep understanding of database architecture, data modeling, and performance optimization. Your goal is to analyze a given SQL database schema and propose a robust and efficient migration strategy to a NoSQL database, considering data integrity, scalability, and maintainability.

Here is the format you will use to reason through the migration and come up with a fantastic recommendation:

---

## SQL Database Schema
$sql_schema_description (Provide a detailed description of the SQL schema, including tables, columns, data types, relationships, and indexes.)

## NoSQL Database Choice and Justification
$nosql_database (Specify the chosen NoSQL database type (e.g., MongoDB, Cassandra, DynamoDB) and provide a detailed justification for its selection based on the SQL schema and anticipated application needs. Consider factors like data model flexibility, scalability requirements, query patterns, and operational overhead.)

## Data Modeling Strategy for NoSQL
$data_modeling_strategy (Describe how the SQL data will be transformed and modeled within the chosen NoSQL database. Include specific examples of how tables and relationships will be represented in the NoSQL data model. Address potential denormalization strategies and trade-offs.)

## Migration Steps and Considerations
$migration_steps (Outline a step-by-step migration plan, including data extraction, transformation, and loading (ETL) processes. Address data validation and integrity checks during and after the migration. Consider potential downtime and rollback strategies.)

## Code Snippets (Golang)
$golang_code_snippets (Provide example Golang code snippets demonstrating how to interact with the NoSQL database, including data insertion, querying, and updating. Use a popular Golang NoSQL driver.)

## Performance Optimization Strategies
$performance_optimization (Describe strategies for optimizing performance in the NoSQL database, such as indexing, query optimization, and data partitioning. Consider the specific characteristics of the chosen NoSQL database.)

## Potential Challenges and Mitigation Strategies
$challenges_and_mitigation (Identify potential challenges during the migration process, such as data inconsistencies, schema evolution, and performance bottlenecks. Propose mitigation strategies for each challenge.)

---

Here is the challenge you are tasked with: [ВСТАВЬТЕ СВОЮ СХЕМУ БД]


💬 Были ли у вас случаи переезда с SQL на noSQL или в обратную сторону?

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
🌚5🔥3👍2
🔥 Последняя неделя перед стартом курса по AI-агентам

Старт курса уже 5го числа! Если вы планировали вписаться — сейчас ПОСЛЕДНИЙ шанс забронировать место

На курсе:
разложим LLM по косточкам: токенизация, SFT, PEFT, инференс
— соберём RAG и научимся оценивать его адекватно
— построим настоящую мультиагентную систему — архитектуру, которая умеет расти
— разберём CoPilot, сломаем через prompt injection (спасибо Максу)
— и наконец, посмотрим, как это работает в MCP и реальных кейсах

📍 Это 5 живых вебинаров + раздатка + домашки + чат с преподавателями

И главное — возможность реально разобраться, как проектировать системы на LLM, а не просто «поиграться с API»

👉 Курс здесь
1
⚡️ Чек-лист по безопасности для Go-разработчика

Составили для вас мини-гайд из 10 ключевых пунктов по обеспечению безопасности Go-приложений.

Актуальность

• Регулярно обновляйте модули через go get -u и проверяйте go.mod на устаревшие версии.

• Используйте go mod tidy для удаления ненужных пакетов.

Статический и динамический анализ на уязвимости

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

• Настройте регулярный SAST/DAST-сканинг (например, GitHub Advanced Security).

Принцип наименьших прав (Least Privilege)

• Минимизируйте права сервисных аккаунтов и контейнеров.

• Отдельные роли для чтения и записи данных в хранилище.

Безопасная работа с вводом-выводом

• Проверяйте и экранируйте все внешние данные (формы, JSON, URL-параметры).

• Используйте подготовленные выражения (prepared statements) для запросов к БД.

Использование контекстов и таймаутов

• Всегда передавайте context.Context в сетевых и длительных операциях.

• Задавайте адекватные дедлайны и таймауты (context.WithTimeout).

Шифрование и управление секретами

• Не храните ключи и пароли в коде или репозитории: используйте Vault, AWS Secrets Manager или переменные окружения.

• Применяйте современные алгоритмы из пакета crypto (AES-GCM, SHA-256, ECDSA).

Безопасная конфигурация TLS

• Используйте последние версии TLS (1.2+) и строгие cipher suites.

• Проверяйте сертификаты и избегайте InsecureSkipVerify=true.

Защита от конкурентных ошибок

• Запускайте приложение с флагом -race в процессе тестирования.

• Избегайте гонок при доступе к разделяемым переменным: применяйте sync.Mutex или каналы.

Fuzz-тестирование и нагрузочное тестирование

• Интегрируйте go test --fuzz для автоматической генерации некорректных входных данных.

• Проводите стресс-тесты сетевых и критичных компонентов.

Логирование и мониторинг инцидентов

• Логируйте события безопасности (неудачные аутентификации, ошибки валидации) с уровнем Warn/Error.

• Настройте алерты по подозрительным паттернам и аномалиям (Prometheus Alertmanager, Grafana).

Насколько безопасны ваши приложения? Проверьте по списку

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍155
🧑‍💻 Что за ужас тут творится

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

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


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

— Обратите внимание на то, как принимаются решения: формально через руководителей или неформально «по знакомству».

— Оцените, насколько корректно используется трекинг задач и документация — это показатель зрелости команды.

— Внимательно слушайте, какие вопросы задают другие: открыты ли коллеги к диалогу или предпочитают «молча работать».

— Спросите про KPI и цели: ясны ли вам критерии успеха и пути их достижения?

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

💬 С какими «тревожными звоночками» вы сталкивались в новых командах? Поделитесь в комментариях 👇

P.S. Если хотите задать вопрос сообществу или поделиться историей, заполните нашу гугл-форму.

🐸Библиотека Go-разработчика #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
3👍2
👀 Что там в новом Go

Обновления это всегда хорошо, а обновления любимого языка — ещё лучше!

Все ключевые фичи и экспериментальные флаги обновления уже ждут.

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

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍11🔥42
🔒 Простой путь к удобной аутентификации

Безопасность приложения не должна делаться в последнюю очередь. Интеграция Google SSO с Keycloak — это решение, которое стоит изучить для защиты вашего проекта.

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

➡️ Защитить своё приложение

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4🤔1🌚1
📣 cancel для context.WithTimeout() обязательно или избыточно

В мире Go-разработки постоянно идут споры: нужно ли всегда явно вызывать cancel после создания контекста с таймаутом.

Явный cancel — гарантия чистоты ресурсов

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

• Немедленно отменяет все дочерние операции и горутины, слушающие этот контекст.

• Делает код предсказуемым и единообразным в масштабных сервисах с долгим временем работы.

Пропуск cancel — упрощение там, где это не важно

• Таймер автоматически сбросится при наступлении таймаута, так что в «одноразовых» сценариях утечек практически не будет.

• В простых CLI-утилитах или скриптах с коротким жизненным циклом явный cancel может быть избыточным.

• Минимизирует «шум» в коде, когда контекст не передаётся дальше и не порождает дополнительных горутин.

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

🐸Библиотека Go-разработчика #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍81🔥1
📰 Новости недели

Представляем подборку материалов и новостей недели.

Продвинутый gRPC в микросервисах

В обзоре на уровне архитекторов рассматриваются реальные кейсы от Dropbox и Netflix.

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

Обзор линковки Go-бинарников и приёмов кросс-компиляции

В ролике рассказывают, как собрать полностью статический Go-бинарник с помощью CGO_ENABLED=0 или тега netgo, а затем уменьшить его размер, убрав отладочные символы флагами -s -w.

Новый эпизод Cup o’ Go

Ведущие обсуждают новости и проводят интервью о подготовке Go West Conf и работы Forge Utah Foundation.

Расширенный выбор окружений Go и поддержка golangci-lint v2

Стало доступно расширение vscode-go для VS Code с улучшенным UI выбора SDK — теперь разделитель помогает быстро увидеть, какие версии уже установлены, и какие можно загрузить.

Расширение официально поддерживает golangci-lint v2: его можно установить через «Go: Install/Update Tools», переключать по рабочим областям и перенастраивать с помощью go.lintFlags

Еженедельный буст канала

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

Golang middle+ developer — гибрид в Санкт-Петербурге.

Go Разработчик — удаленно в Москве.

Senior Golang Developer — удаленно.

Golang разработчик Senior — гибрид в Москве.

Golang developer — гибрид/Офис в Санкт-Петербурге.

Бустер — удалённо (не только Москва).

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

Основные приёмы и команды для эффективного применения git rebase: от простого переноса коммитов до интерактивной правки и безопасного пуша.

• Перенос коммитов на вершину другой ветки:
git checkout feature  
git rebase main


• Изменение, объединение и переупорядочение коммитов:
git rebase -i HEAD~5 


• При возникновении конфликтов:

1. Исправить файлы вручную
2. git add <файл>
3. git rebase --continue

• Пропуск и отмена:
git rebase --skip      # пропустить проблемный коммит  
git rebase --abort # отменить весь процесс rebase


• Перенести коммиты из ветки feature, основываясь на ветке dev:
git rebase --onto dev base feature 


💬 Как у вас с ребейзом? На «ты» или гит жонглирует вашими нервами?

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
8🔥1
🔝 Как вывести резюме в топ

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

Ваше резюме — это не просто список навыков, а настоящий маркетинговый инструмент.

➡️ Детали в статье

🐸Библиотека Go-разработчика
Please open Telegram to view this post
VIEW IN TELEGRAM
4👍1
🛠 Как упасть без шума

Без мягкой остановки есть риски некорректно закрыть соединения или оставить горутины «висеть», что приведёт к утечке памяти.

Пример обработки сигналов для мягкого падения:

1. Для начала будем ловить сигналы остановки:
import (
"os"
"os/signal"
"syscall"
)

// Создаём канал для входящих сигналов
sigCh := make(chan os.Signal, 1)
// Оповещаем канал о SIGINT и SIGTERM
signal.Notify(sigCh, syscall.SIGINT, syscall.SIGTERM)


2. Затем используем контекст для отмены действий:
import "context"

// Создаём корневой контекст с cancel-функцией
ctx, cancel := context.WithCancel(context.Background())
defer cancel()

// В горутине ждем сигнала и вызываем cancel
go func() {
<-sigCh
cancel()
}()


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

3. Мягкое падение сервера:

import (
"net/http"
"time"
"log"
)

// Предполагаем, что srv := &http.Server{Addr: ":8080", Handler: mux}

go func() {
log.Printf("Starting server on %s", srv.Addr)
if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
log.Fatalf("ListenAndServe(): %v", err)
}
}()

// Блокируемся до cancel (сигнал получен)
<-ctx.Done()

// Даём серверу до 10 секунд на завершение текущих запросов
shutdownCtx, shutdownCancel := context.WithTimeout(context.Background(), 10*time.Second)
defer shutdownCancel()

if err := srv.Shutdown(shutdownCtx); err != nil {
log.Printf("Server Shutdown: %v", err)
} else {
log.Println("Server gracefully stopped")
}


srv.Shutdown корректно завершит входящие соединения и дождётся завершения хендлеров. При превышении таймаута происходит жёсткое закрытие.

4. Корректное завершение фоновых задач.

Если у вас есть фоновые горутины, используйте sync.WaitGroup:
import "sync"

var wg sync.WaitGroup

// Запуск фоновой задачи
wg.Add(1)
go func() {
defer wg.Done()
for {
select {
case <-ctx.Done():
// получен сигнал отмены — выходим
return
default:
// ваша работа
}
}
}()

// После Shutdown HTTP-ждём фоновиков
wg.Wait()


Все горутины должны следить за ctx.Done(). После srv.Shutdown ожидайте завершения wg.Wait() перед окончательным выходом.

Механика Graceful Shutdown легко расширяется и может быть повторно использована в микросервисах, batch-джобах и serverless-функциях.

🐸Библиотека Go-разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍186🔥2
⭐️ Минорные обновления Go

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

Фиксы в Go 1.24.5

• Исправлена ошибка, позволяющая злоумышленникам обходить механизмы защиты от атак типа «request smuggling».

• Снижено потребление памяти при длительных сессиях работы приложения.

• Исправлены проблемы с файловой системой, возникавшие при работе с длинными путями.

Что там в
Go 1.23.11:

• Устранена редкая гонка данных при использовании буферизованных каналов.

• Внесены правки в пакеты net и crypto для устранения потенциальных уязвимостей.

• Исправлены проблемы с производительностью при работе с файловой системой HFS+.

🖇 Подробнее об обновлениях: 1.23.11 и 1.24.5

🐸Библиотека Go-разработчика #свежак
Please open Telegram to view this post
VIEW IN TELEGRAM
👍63
Первый вебинар нашего курса по AI-агентам уже прошёл!

Запись уже выложили на обучающей платформе — можно влетать и догонять с комфортом.

Первые слушатели уже оставили фидбэки — и, кажется, мы попали в точку:
— «теперь наконец понял, как выбирать модели под задачу — раньше брал первую попавшуюся»
— «без лишнего, по делу, в лайве — кайф»
— «огонь, ожидания 100% оправданы лично у меня»

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

Ещё можно догнать и пройти всё вместе с потоком.

👉 Залетай на курс
👍3