Самый простой способ добавить валидацию в Options Pattern
Можно использовать data annotations, например атрибут
Также нужно обновить настройку DI и вызвать метод
Это включит валидацию при разрешении options из DI-контейнера.
👉 @KodBlog
Можно использовать data annotations, например атрибут
Required.Также нужно обновить настройку DI и вызвать метод
ValidateDataAnnotations.Это включит валидацию при разрешении options из DI-контейнера.
public class GitHubSettings
{
[Required]
public string AccessToken { get; init; }
[Required]
public string RepositoryName { get; init; }
}
builder.Services
.AddOptions<GitHubSettings>()
.BindConfiguration("GitHubSettings")
.ValidateDataAnnotations();
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2🤔2
Самое мощное правило для написания читаемого C# кода:
(Я вынес его из одного ТВ-шоу 90-х про бои на мечах)
Никогда не делайте цепочку больше чем из одного тернарного оператора.
Сейчас объясню.
В детстве я смотрел сериал Highlander.
Если не знакомы с этим шоу:
Там куча людей дерется на мечах.
Главное правило? Должен остаться только один.
То есть в конце выживает только один.
Золотое правило при работе с тернарным оператором в C#:
Должен быть только один.
То есть избегайте цепочек из более чем одного тернарного оператора.
Решение:
1. Перепишите в
2. Посмотрите, можно ли еще сильнее отрефакторить и упростить код.
Запомните:
Если видите цепочку тернарных операторов, доставайте меч, ну то есть рефакторьте, и рубите эту цепочку.
👉 @KodBlog
(Я вынес его из одного ТВ-шоу 90-х про бои на мечах)
Никогда не делайте цепочку больше чем из одного тернарного оператора.
Сейчас объясню.
В детстве я смотрел сериал Highlander.
Если не знакомы с этим шоу:
Там куча людей дерется на мечах.
Главное правило? Должен остаться только один.
То есть в конце выживает только один.
Золотое правило при работе с тернарным оператором в C#:
Должен быть только один.
То есть избегайте цепочек из более чем одного тернарного оператора.
Решение:
1. Перепишите в
if-else.2. Посмотрите, можно ли еще сильнее отрефакторить и упростить код.
Запомните:
Если видите цепочку тернарных операторов, доставайте меч, ну то есть рефакторьте, и рубите эту цепочку.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤13🥴10💯2🤔1
В EF Core есть способ получше для массовых обновлений.
Можно использовать метод
При выполнении в базе данных он преобразуется в один SQL-запрос.
Но тут нужно заранее знать, какое именно свойство ты обновляешь и в какое значение.
👉 @KodBlog
Можно использовать метод
ExecuteUpdate. Его добавили в EF 7.При выполнении в базе данных он преобразуется в один SQL-запрос.
Но тут нужно заранее знать, какое именно свойство ты обновляешь и в какое значение.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥7❤3🤔1🥴1
В .NET 11 Preview 3 добавили раннюю preview-фичу из C# 15: unions.
Она добавляет объявления union (
Их можно обрабатывать через pattern matching / switch expressions как замкнутый набор вариантов, с проверкой exhaustiveness.
https://github.com/dotnet/csharplang/blob/main/proposals/unions.md
👉 @KodBlog
Она добавляет объявления union (
union Pet(Cat, Dog, Bird) { ... }) и union-типы, помечаемые атрибутом [Union].Их можно обрабатывать через pattern matching / switch expressions как замкнутый набор вариантов, с проверкой exhaustiveness.
https://github.com/dotnet/csharplang/blob/main/proposals/unions.md
Please open Telegram to view this post
VIEW IN TELEGRAM
GitHub
csharplang/proposals/unions.md at main · dotnet/csharplang
The official repo for the design of the C# programming language - dotnet/csharplang
🔥9🤔4
Правильно ли вы внедряете зависимости в Controllers?
Многие разработчики этого не знают
Внедрять зависимости в Controller можно двумя способами:
↳ через конструктор
↳ через внедрение в метод
Сталкивались с раздутыми контроллерами, у которых в конструкторе слишком много зависимостей?
При этом конкретный endpoint использует только часть из них.
❌ Вы зря расходуете память, потому что все зависимости из конструктора аллоцируются в куче при вызове Controller, независимо от того, будут они использоваться или нет.
✅ Так почему бы не внедрять нужные объекты прямо в метод endpoint-а?
Их можно внедрять без атрибута
Когда вы внедряете зависимости только там, где они реально нужны, это улучшает читаемость, упрощает поддержку и повышает производительность контроллеров.
👉 @KodBlog
Многие разработчики этого не знают
Внедрять зависимости в Controller можно двумя способами:
↳ через конструктор
↳ через внедрение в метод
Сталкивались с раздутыми контроллерами, у которых в конструкторе слишком много зависимостей?
При этом конкретный endpoint использует только часть из них.
Их можно внедрять без атрибута
[FromServices], он больше не нужен. Почти так же, как и в Minimal APIs.Когда вы внедряете зависимости только там, где они реально нужны, это улучшает читаемость, упрощает поддержку и повышает производительность контроллеров.
Please open Telegram to view this post
VIEW IN TELEGRAM
👎6❤5👍2🤔2
Хватит инжектить IConfiguration. Вот правильный подход в .NET 10
Однажды я выкатил систему feature-флагов, которая читала настройки из
Исправление? Заменить
Изменение в одну строку, которое стоило мне трёх часов дебага и инцидент-репорта. Этот случай показал мне: понимать Options Pattern — не опционально. Это базовая вещь. Разберёмся.
Завариваем кофею и читаем статью
👉 @KodBlog
Однажды я выкатил систему feature-флагов, которая читала настройки из
appsettings.json через IOptions<FeatureFlagOptions>. В деве всё работало нормально. Но в проде, когда команда DevOps переключала флаг, обновляя appsettings.json, ничего не происходило. API продолжал возвращать старые значения. Пользователи застряли. Чтобы подхватить изменения, мне пришлось перезапустить приложение.Исправление? Заменить
IOptions<T> на IOptionsMonitor<T>.Изменение в одну строку, которое стоило мне трёх часов дебага и инцидент-репорта. Этот случай показал мне: понимать Options Pattern — не опционально. Это базовая вещь. Разберёмся.
Завариваем кофею и читаем статью
Please open Telegram to view this post
VIEW IN TELEGRAM
❤8🔥6🥴2🤨2🤔1
MapReduce — это популярный фреймворк, изначально разработанный в Google, для эффективной и отказоустойчивой обработки больших распределённых наборов данных. Он был создан, чтобы запускать масштабные вычисления на терабайтах данных, собранных из веба, предоставляя удобный слой абстракции поверх тысяч машин.
Фреймворк основан на двух функциях из функциональных языков: Map и Reduce.
- Map принимает на вход список элементов и функцию. Она применяет эту функцию к каждому элементу списка и возвращает результат. Например, если список
- Reduce принимает список, функцию и начальное значение. Она последовательно комбинирует элементы списка с начальным значением через заданную функцию. Например, если функция суммирует два числа, начальное значение 0, а список
Внутреннее функционирование MapReduce можно описать следующими шагами:
1. Разделение данных: входные файлы делятся на несколько частей.
2. Запуск кластерной обработки: запускаются копии программы MapReduce на кластере. Одна копия — мастер, остальные — воркеры. Мастер распределяет Map и Reduce задачи между воркерами. Пользователь может задать количество задач Map и Reduce.
3. Map задачи: воркер читает свою часть входных данных, разбивает её на пары ключ/значение и передаёт в пользовательскую функцию Map.
4. Промежуточные данные: Map функция возвращает набор промежуточных пар ключ/значение. Эти пары разбиваются на партиции, а информация о расположении каждой партиции отправляется мастеру. Эти партиции становятся входом для Reduce воркеров.
5. Reduce задачи: воркер считывает пары, группирует все элементы с одинаковым ключом и передаёт ключ с соответствующим набором значений в пользовательскую функцию Reduce. Результат Reduce добавляется в выходной файл.
6. Завершение работы: когда все Map и Reduce задачи выполнены, мастер возвращает контроль пользователю. Выходные данные доступны через файлы, один файл на каждого Reduce воркера.
Таким образом, MapReduce превращает огромные распределённые вычисления в управляемый процесс с понятной логикой распределения и агрегации данных.
👉 @KodBlog
Фреймворк основан на двух функциях из функциональных языков: Map и Reduce.
- Map принимает на вход список элементов и функцию. Она применяет эту функцию к каждому элементу списка и возвращает результат. Например, если список
[1,2,3,4], а функция возводит число в квадрат, Map преобразует его в [1,4,9,16].- Reduce принимает список, функцию и начальное значение. Она последовательно комбинирует элементы списка с начальным значением через заданную функцию. Например, если функция суммирует два числа, начальное значение 0, а список
[1,2,3,4], Reduce вернёт 10.Внутреннее функционирование MapReduce можно описать следующими шагами:
1. Разделение данных: входные файлы делятся на несколько частей.
2. Запуск кластерной обработки: запускаются копии программы MapReduce на кластере. Одна копия — мастер, остальные — воркеры. Мастер распределяет Map и Reduce задачи между воркерами. Пользователь может задать количество задач Map и Reduce.
3. Map задачи: воркер читает свою часть входных данных, разбивает её на пары ключ/значение и передаёт в пользовательскую функцию Map.
4. Промежуточные данные: Map функция возвращает набор промежуточных пар ключ/значение. Эти пары разбиваются на партиции, а информация о расположении каждой партиции отправляется мастеру. Эти партиции становятся входом для Reduce воркеров.
5. Reduce задачи: воркер считывает пары, группирует все элементы с одинаковым ключом и передаёт ключ с соответствующим набором значений в пользовательскую функцию Reduce. Результат Reduce добавляется в выходной файл.
6. Завершение работы: когда все Map и Reduce задачи выполнены, мастер возвращает контроль пользователю. Выходные данные доступны через файлы, один файл на каждого Reduce воркера.
Таким образом, MapReduce превращает огромные распределённые вычисления в управляемый процесс с понятной логикой распределения и агрегации данных.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤6👏3
This media is not supported in your browser
VIEW IN TELEGRAM
Чувак сделал Ctrl+F для всего экрана.
Нажимаешь хоткей → экран «замораживается» → вводишь текст для поиска → совпадения подсвечиваются в реальном времени. Работает с любым видимым контентом — невыделяемые PDF, диалоги ошибок, текст на изображениях и т.д.
Также можно выделить мышью любую область (drag-select), и приложение автоматически копирует весь текст из этой области — как Snipping Tool, только для текста, с автокопированием.
Один
Вот приложение — github.com/sid1552/ScreenFind
TL;DR: Ctrl+F, но для всего экрана.
👉 @KodBlog
Нажимаешь хоткей → экран «замораживается» → вводишь текст для поиска → совпадения подсвечиваются в реальном времени. Работает с любым видимым контентом — невыделяемые PDF, диалоги ошибок, текст на изображениях и т.д.
Также можно выделить мышью любую область (drag-select), и приложение автоматически копирует весь текст из этой области — как Snipping Tool, только для текста, с автокопированием.
Один
.exe, работает локально, используя встроенный в Windows OCR.Вот приложение — github.com/sid1552/ScreenFind
TL;DR: Ctrl+F, но для всего экрана.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤🔥12❤3🤔3🔥2👏1
SignalR позволяет добавлять real-time функциональность в .NET-приложения.
И всё начинается с Hub.
Hub — это центральный компонент приложения, который управляет клиентами и отправляет сообщения.
Чтобы получать и отправлять сообщения, клиенты должны подключиться к Hub.
👉 @KodBlog
И всё начинается с Hub.
Hub — это центральный компонент приложения, который управляет клиентами и отправляет сообщения.
Чтобы получать и отправлять сообщения, клиенты должны подключиться к Hub.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10❤1🤩1
Когда кажется, что в Postgres уже не осталось того, чего он не умеет… 🐘
Да, даже полнотекстовый поиск.
И его можно подключить через EF Core.
С этим вы можете:
Настроить индексы для полнотекстового поиска
Писать эффективные поисковые запросы
Ранжировать и сортировать результаты по релевантности
Плавно интегрировать это в ваши .NET-приложения
https://www.milanjovanovic.tech/blog/how-i-implemented-full-text-search-on-my-website
👉 @KodBlog
Да, даже полнотекстовый поиск.
И его можно подключить через EF Core.
С этим вы можете:
Настроить индексы для полнотекстового поиска
Писать эффективные поисковые запросы
Ранжировать и сортировать результаты по релевантности
Плавно интегрировать это в ваши .NET-приложения
https://www.milanjovanovic.tech/blog/how-i-implemented-full-text-search-on-my-website
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8🤩1
Большинство разработчиков могут назвать 10 типов тестирования.
Но лишь немногие могут объяснить, когда использовать каждый из них.
Вот краткий разбор:
1. Smoke Testing (смоук-тестирование)
Приложение вообще запускается?
2. Functional Testing (функциональное тестирование)
Каждая функция возвращает корректный результат?
3. Integration Testing (интеграционное тестирование)
Модули продолжают работать корректно, когда они соединены между собой?
4. Regression Testing (регрессионное тестирование)
Последний коммит не сломал то, что ещё вчера работало?
5. Load Testing (нагрузочное тестирование)
Система справляется с реальным трафиком без «захлёбывания»?
6. Stress Testing (стресс-тестирование)
Что произойдёт, если нагрузку довести до предела?
7. Security Testing (тестирование безопасности)
Может ли кто-то воспользоваться уязвимостью, о которой вы не знали?
8. UI Testing (тестирование пользовательского интерфейса)
Интерфейс ведёт себя так, как ожидает пользователь?
9. Fuzz Testing (фазз-тестирование)
Что сломается, если отправлять приложению случайные или некорректные данные?
10. Reliability Testing (тестирование надёжности)
Система остаётся стабильной после работы в течение дней, а не минут?
👉 @KodBlog
Но лишь немногие могут объяснить, когда использовать каждый из них.
Вот краткий разбор:
1. Smoke Testing (смоук-тестирование)
Приложение вообще запускается?
2. Functional Testing (функциональное тестирование)
Каждая функция возвращает корректный результат?
3. Integration Testing (интеграционное тестирование)
Модули продолжают работать корректно, когда они соединены между собой?
4. Regression Testing (регрессионное тестирование)
Последний коммит не сломал то, что ещё вчера работало?
5. Load Testing (нагрузочное тестирование)
Система справляется с реальным трафиком без «захлёбывания»?
6. Stress Testing (стресс-тестирование)
Что произойдёт, если нагрузку довести до предела?
7. Security Testing (тестирование безопасности)
Может ли кто-то воспользоваться уязвимостью, о которой вы не знали?
8. UI Testing (тестирование пользовательского интерфейса)
Интерфейс ведёт себя так, как ожидает пользователь?
9. Fuzz Testing (фазз-тестирование)
Что сломается, если отправлять приложению случайные или некорректные данные?
10. Reliability Testing (тестирование надёжности)
Система остаётся стабильной после работы в течение дней, а не минут?
Please open Telegram to view this post
VIEW IN TELEGRAM
👍9🤔3❤1🤩1
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4👏4👨💻3
Вот как можно реализовать фильтр запросов на основе тенанта с использованием EF Core.
Вам понадобится сервис, который будет предоставлять TenantId для текущего тенанта. Это значение можно получить из заголовка запроса или клейма
Побочный эффект: вы сможете использовать DbContext только в рамках HTTP-запроса.
👉 @KodBlog
Вам понадобится сервис, который будет предоставлять TenantId для текущего тенанта. Это значение можно получить из заголовка запроса или клейма
Побочный эффект: вы сможете использовать DbContext только в рамках HTTP-запроса.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤3👍2👀2
Как создавать фоновые задачи в .NET?
С Quartz это так же просто, как реализовать интерфейс.
Вы можете внедрять любые необходимые зависимости через DI. Фоновые задачи также имеют scoped-область, поэтому можно даже внедрять DbContext.
👉 @KodBlog
С Quartz это так же просто, как реализовать интерфейс.
Вы можете внедрять любые необходимые зависимости через DI. Фоновые задачи также имеют scoped-область, поэтому можно даже внедрять DbContext.
[DisallowConcurrentExecution]
public class MyBackgroundJob : IJob
{
public MyBackgroundJob(...)
{
}
public async Task Execute(IJobExecutionContext context)
{
// Implement your logic here.
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8❤2😁2👨💻1
Сделать столбец Sparse в Entity Framework 💡
В SQL Server sparse-столбцы — это обычные столбцы, оптимизированные для хранения значений
Хорошими кандидатами для sparse-столбцов являются любые столбцы, у которых в большинстве строк вероятно будет значение
и т. д.
Sparse-столбцы легко настраиваются в EF
👉 @KodBlog
В SQL Server sparse-столбцы — это обычные столбцы, оптимизированные для хранения значений
NULL. Их использование может значительно экономить место.Хорошими кандидатами для sparse-столбцов являются любые столбцы, у которых в большинстве строк вероятно будет значение
NULL, например:dateAccountClosed
discountAmount
Suffix
Address4
DeliveryInstructions
OrderReturnDate
и т. д.
Sparse-столбцы легко настраиваются в EF
Please open Telegram to view this post
VIEW IN TELEGRAM
❤1👏1
This media is not supported in your browser
VIEW IN TELEGRAM
REST API vs WebSocket
REST API:
- Модель запрос–ответ
- Клиент отправляет запрос → сервер возвращает ответ
- Stateless (каждый запрос независим)
- Лучше всего подходит для CRUD-операций
- Использует HTTP/HTTPS
• Пример: получение данных пользователя, отправка форм
WebSocket:
- Двусторонняя связь в реальном времени
- Постоянное full-duplex соединение
- Stateful-соединение
- Лучше всего подходит для live-обновлений
- Использует протокол ws/wss
• Пример: чат-приложения, лайв-трейдинг, онлайн-игры
🟢 REST = запросил → получил
🔵 WebSocket = постоянное соединение и обмен данными в любой момент
👉 @KodBlog
REST API:
- Модель запрос–ответ
- Клиент отправляет запрос → сервер возвращает ответ
- Stateless (каждый запрос независим)
- Лучше всего подходит для CRUD-операций
- Использует HTTP/HTTPS
• Пример: получение данных пользователя, отправка форм
WebSocket:
- Двусторонняя связь в реальном времени
- Постоянное full-duplex соединение
- Stateful-соединение
- Лучше всего подходит для live-обновлений
- Использует протокол ws/wss
• Пример: чат-приложения, лайв-трейдинг, онлайн-игры
Please open Telegram to view this post
VIEW IN TELEGRAM
👏7❤2
FluentValidation делает валидацию входных данных очень простой.
Знали ли вы, что валидаторы поддерживают DI (Dependency Injection)?
Вы можете внедрять объекты настроек, сконфигурированные через DI, и использовать их внутри валидаторов.
Посмотрите пример в сниппете кода ниже.👇
Знали ли вы, что валидаторы поддерживают DI (Dependency Injection)?
Вы можете внедрять объекты настроек, сконфигурированные через DI, и использовать их внутри валидаторов.
Посмотрите пример в сниппете кода ниже.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍9🥴1
Непопулярное мнение:
Большинство разработчиков на самом деле не понимают Git.
Они знают только три команды:
1.
2.
3.
Но Git может гораздо больше:
- ветвление (branching)
- rebase
- stash
- cherry-pick
- разрешение конфликтов (conflict resolution)
Правильное понимание Git может сэкономить часы отладки и исправления сломанных веток.
👉 @KodBlog
Большинство разработчиков на самом деле не понимают Git.
Они знают только три команды:
1.
git add2.
git commit3.
git pushНо Git может гораздо больше:
- ветвление (branching)
- rebase
- stash
- cherry-pick
- разрешение конфликтов (conflict resolution)
Правильное понимание Git может сэкономить часы отладки и исправления сломанных веток.
Please open Telegram to view this post
VIEW IN TELEGRAM
😐21🥴5❤1👎1
Используешь ли ты trunk-based development?
Это стратегия ветвления, при которой все разработчики работают напрямую в «trunk» (основной ветке).
Feature flags — обязательная часть такого подхода.
Незавершённые фичи прячутся за feature flag и выкатываются только тогда, когда они готовы.
👉 @KodBlog
Это стратегия ветвления, при которой все разработчики работают напрямую в «trunk» (основной ветке).
Feature flags — обязательная часть такого подхода.
Незавершённые фичи прячутся за feature flag и выкатываются только тогда, когда они готовы.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🤔3❤1