[{"data":1,"prerenderedAt":9146},["ShallowReactive",2],{"navigation_docs":3,"-csharp-aspnet-monitoring-health-checks":3302,"-csharp-aspnet-monitoring-health-checks-surround":9141},[4,1707,1896,2350,2531,2572,2779,2901,2951,3008,3042,3168,3245,3298],{"title":5,"icon":6,"path":7,"stem":8,"children":9},"C#","i-devicon-csharp","\u002Fcsharp","01.csharp",[10,13,60,90,120,202,219,253,379,404,457,650,1364,1654,1703],{"title":11,"path":7,"stem":12},"C# та .NET","01.csharp\u002Findex",{"title":14,"icon":15,"path":16,"stem":17,"children":18,"page":59},"Fundamentals","i-lucide-book-open","\u002Fcsharp\u002Ffundamentals","01.csharp\u002F01.fundamentals",[19,23,27,31,35,39,43,47,51,55],{"title":20,"path":21,"stem":22},"Вступ до екосистеми .NET","\u002Fcsharp\u002Ffundamentals\u002Fintroduction-to-ecosystem","01.csharp\u002F01.fundamentals\u002F01.introduction-to-ecosystem",{"title":24,"path":25,"stem":26},"Структура програми на C#","\u002Fcsharp\u002Ffundamentals\u002Fprogram-structure","01.csharp\u002F01.fundamentals\u002F02.program-structure",{"title":28,"path":29,"stem":30},"Змінні та Типи Даних","\u002Fcsharp\u002Ffundamentals\u002Fvariables-data-types","01.csharp\u002F01.fundamentals\u002F03.variables-data-types",{"title":32,"path":33,"stem":34},"Масиви","\u002Fcsharp\u002Ffundamentals\u002Farrays","01.csharp\u002F01.fundamentals\u002F04.arrays",{"title":36,"path":37,"stem":38},"Strings & Text Handling","\u002Fcsharp\u002Ffundamentals\u002Fstrings-text-handling","01.csharp\u002F01.fundamentals\u002F05.strings-text-handling",{"title":40,"path":41,"stem":42},"Дати і Час","\u002Fcsharp\u002Ffundamentals\u002Fdates-time-handling","01.csharp\u002F01.fundamentals\u002F06.dates-time-handling",{"title":44,"path":45,"stem":46},"Потік Керування","\u002Fcsharp\u002Ffundamentals\u002Fcontrol-flow","01.csharp\u002F01.fundamentals\u002F07.control-flow",{"title":48,"path":49,"stem":50},"Методи","\u002Fcsharp\u002Ffundamentals\u002Fmethods","01.csharp\u002F01.fundamentals\u002F08.methods",{"title":52,"path":53,"stem":54},"Основи Відлагодження","\u002Fcsharp\u002Ffundamentals\u002Fdebugging-basics","01.csharp\u002F01.fundamentals\u002F09.debugging-basics",{"title":56,"path":57,"stem":58},"Інтерактивна Консоль (Classic)","\u002Fcsharp\u002Ffundamentals\u002Finteractive-console","01.csharp\u002F01.fundamentals\u002F10.interactive-console",false,{"title":61,"icon":62,"path":63,"stem":64,"children":65,"page":59},"OOP","i-lucide-box","\u002Fcsharp\u002Foop","01.csharp\u002F02.oop",[66,70,74,78,82,86],{"title":67,"path":68,"stem":69},"Package Management (Управління Пакетами)","\u002Fcsharp\u002Foop\u002Fpackage-management","01.csharp\u002F02.oop\u002F01.package-management",{"title":71,"path":72,"stem":73},"Класи та Об'єкти","\u002Fcsharp\u002Foop\u002Fclasses-objects","01.csharp\u002F02.oop\u002F02.classes-objects",{"title":75,"path":76,"stem":77},"Властивості та Поля","\u002Fcsharp\u002Foop\u002Fproperties-fields","01.csharp\u002F02.oop\u002F03.properties-fields",{"title":79,"path":80,"stem":81},"Стовпи ООП","\u002Fcsharp\u002Foop\u002Foop-pillars","01.csharp\u002F02.oop\u002F04.oop-pillars",{"title":83,"path":84,"stem":85},"Advanced Types","\u002Fcsharp\u002Foop\u002Fadvanced-types","01.csharp\u002F02.oop\u002F05.advanced-types",{"title":87,"path":88,"stem":89},"Namespaces (Простори Імен)","\u002Fcsharp\u002Foop\u002Fnamespaces","01.csharp\u002F02.oop\u002F06.namespaces",{"title":91,"icon":92,"path":93,"stem":94,"children":95,"page":59},"Advanced Core","i-lucide-zap","\u002Fcsharp\u002Fadvanced-core","01.csharp\u002F03.advanced-core",[96,100,104,108,112,116],{"title":97,"path":98,"stem":99},"Generics (Узагальнення)","\u002Fcsharp\u002Fadvanced-core\u002Fgenerics","01.csharp\u002F03.advanced-core\u002F01.generics",{"title":101,"path":102,"stem":103},"Делегати, Події та Лямбда-вирази","\u002Fcsharp\u002Fadvanced-core\u002Fdelegates-events-lambdas","01.csharp\u002F03.advanced-core\u002F02.delegates-events-lambdas",{"title":105,"path":106,"stem":107},"Interfaces Deep Dive (Інтерфейси: Поглиблений Розгляд)","\u002Fcsharp\u002Fadvanced-core\u002Finterfaces-deep-dive","01.csharp\u002F03.advanced-core\u002F03.interfaces-deep-dive",{"title":109,"path":110,"stem":111},"Обробка Винятків","\u002Fcsharp\u002Fadvanced-core\u002Fexception-handling","01.csharp\u002F03.advanced-core\u002F04.exception-handling",{"title":113,"path":114,"stem":115},"Pattern Matching","\u002Fcsharp\u002Fadvanced-core\u002Fpattern-matching","01.csharp\u002F03.advanced-core\u002F05.pattern-matching",{"title":117,"path":118,"stem":119},"Додаткові Можливості C#","\u002Fcsharp\u002Fadvanced-core\u002Fadditional-features","01.csharp\u002F03.advanced-core\u002F06.additional-features",{"title":121,"icon":122,"path":123,"stem":124,"children":125,"page":59},"Architecture Best Practices","i-lucide-building-2","\u002Fcsharp\u002Farchitecture-best-practices","01.csharp\u002F04.architecture-best-practices",[126,130,149,153,157,161,165,169],{"title":127,"path":128,"stem":129},"Software Design Principles (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fsoftware-design-principles","01.csharp\u002F04.architecture-best-practices\u002F01.software-design-principles",{"title":131,"icon":132,"path":133,"stem":134,"children":135,"page":59},"Design Patterns","i-lucide-folder","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns",[136],{"title":137,"icon":132,"path":138,"stem":139,"children":140,"page":59},"Creational","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational",[141,145],{"title":142,"path":143,"stem":144},"Singleton (Одинак)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fsingleton","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F01.singleton",{"title":146,"path":147,"stem":148},"Builder (Будівельник)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fbuilder","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F02.builder",{"title":150,"path":151,"stem":152},"Building Professional CLIs","\u002Fcsharp\u002Farchitecture-best-practices\u002Fbuilding-professional-clis","01.csharp\u002F04.architecture-best-practices\u002F03.building-professional-clis",{"title":154,"path":155,"stem":156},"Validation & Flow Control","\u002Fcsharp\u002Farchitecture-best-practices\u002Fvalidation-flow-control","01.csharp\u002F04.architecture-best-practices\u002F04.validation-flow-control",{"title":158,"path":159,"stem":160},"The Modern .NET Host (Microsoft.Extensions)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fmodern-dotnet-host","01.csharp\u002F04.architecture-best-practices\u002F05.modern-dotnet-host",{"title":162,"path":163,"stem":164},"Data Mapper: Repository та DAO патерни (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part1","01.csharp\u002F04.architecture-best-practices\u002F06.data-mapper-part1",{"title":166,"path":167,"stem":168},"Data Mapper: Repository та DAO патерни (Частина 2)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part2","01.csharp\u002F04.architecture-best-practices\u002F07.data-mapper-part2",{"title":170,"icon":132,"path":171,"stem":172,"children":173,"page":59},"Di Ioc","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc",[174,178,182,186,190,194,198],{"title":175,"path":176,"stem":177},"Проблема залежностей та Інверсія Контролю","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fthe-dependency-problem","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F01.the-dependency-problem",{"title":179,"path":180,"stem":181},"Будуємо власний Service Container","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fbuild-your-own-container","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F02.build-your-own-container",{"title":183,"path":184,"stem":185},"Service Locator: Паттерн та Анти-паттерн","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-locator-pattern","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F03.service-locator-pattern",{"title":187,"path":188,"stem":189},"Паттерни Dependency Injection","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdependency-injection-patterns","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F04.dependency-injection-patterns",{"title":191,"path":192,"stem":193},"Microsoft DI: IServiceCollection та IServiceProvider","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fmicrosoft-di-deep-dive","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F05.microsoft-di-deep-dive",{"title":195,"path":196,"stem":197},"Service Lifetimes та Scopes","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-lifetimes-and-scopes","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F06.service-lifetimes-and-scopes",{"title":199,"path":200,"stem":201},"DI Анти-паттерни та Найкращі Практики","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdi-anti-patterns-and-best-practices","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F07.di-anti-patterns-and-best-practices",{"title":203,"icon":132,"path":204,"stem":205,"children":206,"page":59},"Standard Library","\u002Fcsharp\u002Fstandard-library","01.csharp\u002F05.standard-library",[207,211,215],{"title":208,"path":209,"stem":210},"Collections (Колекції)","\u002Fcsharp\u002Fstandard-library\u002Fcollections","01.csharp\u002F05.standard-library\u002F01.collections",{"title":212,"path":213,"stem":214},"High Performance Types (Високопродуктивні Типи)","\u002Fcsharp\u002Fstandard-library\u002Fhigh-performance-types","01.csharp\u002F05.standard-library\u002F02.high-performance-types",{"title":216,"path":217,"stem":218},"LINQ (Language Integrated Query)","\u002Fcsharp\u002Fstandard-library\u002Flinq","01.csharp\u002F05.standard-library\u002F03.linq",{"title":220,"icon":221,"path":222,"stem":223,"children":224,"page":59},"System Internals Concurrency","i-lucide-server","\u002Fcsharp\u002Fsystem-internals-concurrency","01.csharp\u002F06.system-internals-concurrency",[225,229,233,237,241,245,249],{"title":226,"path":227,"stem":228},"Memory Management","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmemory-management","01.csharp\u002F06.system-internals-concurrency\u002F01.memory-management",{"title":230,"path":231,"stem":232},"Reflection API: System.Type та Метадані","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Freflection-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F02.reflection-fundamentals",{"title":234,"path":235,"stem":236},"Attributes та Dynamic Language Runtime","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fattributes-dynamic","01.csharp\u002F06.system-internals-concurrency\u002F03.attributes-dynamic",{"title":238,"path":239,"stem":240},"Expression Trees: Швидка Альтернатива Рефлексії","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fexpression-trees-compiled","01.csharp\u002F06.system-internals-concurrency\u002F04.expression-trees-compiled",{"title":242,"path":243,"stem":244},"Source Generators: Compile-Time Code Generation","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsource-generators","01.csharp\u002F06.system-internals-concurrency\u002F05.source-generators",{"title":246,"path":247,"stem":248},"Multithreading Fundamentals","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmultithreading-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F06.multithreading-fundamentals",{"title":250,"path":251,"stem":252},"Synchronization Primitives","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsynchronization-primitives","01.csharp\u002F06.system-internals-concurrency\u002F07.synchronization-primitives",{"title":254,"icon":255,"path":256,"stem":257,"children":258,"page":59},"System Programming Windows","i-lucide-cpu","\u002Fcsharp\u002Fsystem-programming-windows","01.csharp\u002F07.system-programming-windows",[259,263,267,271,275,279,283,287,291,295,299,303,307,311,315,319,323,327,331,335,339,343,347,351,355,359,363,367,371,375],{"title":260,"path":261,"stem":262},"Як Працює Операційна Система","\u002Fcsharp\u002Fsystem-programming-windows\u002Fhow-os-works","01.csharp\u002F07.system-programming-windows\u002F01.how-os-works",{"title":264,"path":265,"stem":266},"Процеси в .NET — API та Запуск","\u002Fcsharp\u002Fsystem-programming-windows\u002Fprocesses-in-dotnet","01.csharp\u002F07.system-programming-windows\u002F02.processes-in-dotnet",{"title":268,"path":269,"stem":270},"Процеси в .NET — IPC та Міжпроцесна Комунікація","\u002Fcsharp\u002Fsystem-programming-windows\u002F02a.processes-ipc","01.csharp\u002F07.system-programming-windows\u002F02a.processes-ipc",{"title":272,"path":273,"stem":274},"Application Domains та Збірки — AppDomain і AssemblyLoadContext","\u002Fcsharp\u002Fsystem-programming-windows\u002Fappdomains-assemblies","01.csharp\u002F07.system-programming-windows\u002F03.appdomains-assemblies",{"title":276,"path":277,"stem":278},"Application Domains та Збірки — Plug-in Система з Hot-Reload","\u002Fcsharp\u002Fsystem-programming-windows\u002F03a.appdomains-plugin-system","01.csharp\u002F07.system-programming-windows\u002F03a.appdomains-plugin-system",{"title":280,"path":281,"stem":282},"Потоки — Основи та API Thread","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-fundamentals","01.csharp\u002F07.system-programming-windows\u002F04.thread-fundamentals",{"title":284,"path":285,"stem":286},"Потоки — Lifecycle, Пріоритети та Безпечне Завершення","\u002Fcsharp\u002Fsystem-programming-windows\u002F04a.thread-lifecycle-priorities","01.csharp\u002F07.system-programming-windows\u002F04a.thread-lifecycle-priorities",{"title":288,"path":289,"stem":290},"Проблеми Спільного Стану — Race Condition та Data Race","\u002Fcsharp\u002Fsystem-programming-windows\u002Fshared-state-problems","01.csharp\u002F07.system-programming-windows\u002F05.shared-state-problems",{"title":292,"path":293,"stem":294},"Проблеми Спільного Стану — Memory Model та volatile","\u002Fcsharp\u002Fsystem-programming-windows\u002F05a.shared-state-memory-model","01.csharp\u002F07.system-programming-windows\u002F05a.shared-state-memory-model",{"title":296,"path":297,"stem":298},"Синхронізація — Monitor, lock та еволюція примітивів","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-fundamentals","01.csharp\u002F07.system-programming-windows\u002F06.synchronization-fundamentals",{"title":300,"path":301,"stem":302},"Синхронізація — Наскрізний Приклад та Deadlock Detection","\u002Fcsharp\u002Fsystem-programming-windows\u002F06a.synchronization-walkthrough","01.csharp\u002F07.system-programming-windows\u002F06a.synchronization-walkthrough",{"title":304,"path":305,"stem":306},"Синхронізація — Mutex, Semaphore та Event-Based Primitives","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-advanced","01.csharp\u002F07.system-programming-windows\u002F07.synchronization-advanced",{"title":308,"path":309,"stem":310},"Синхронізація — Interlocked, Volatile та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002F07a.synchronization-advanced-walkthrough","01.csharp\u002F07.system-programming-windows\u002F07a.synchronization-advanced-walkthrough",{"title":312,"path":313,"stem":314},"Interlocked, CAS та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002Finterlocked-cas-lockfree","01.csharp\u002F07.system-programming-windows\u002F08.interlocked-cas-lockfree",{"title":316,"path":317,"stem":318},"Volatile, Memory Model та Spinning","\u002Fcsharp\u002Fsystem-programming-windows\u002F08a.volatile-memory-model","01.csharp\u002F07.system-programming-windows\u002F08a.volatile-memory-model",{"title":320,"path":321,"stem":322},"ThreadPool — Пул Потоків для Ефективного Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-pool","01.csharp\u002F07.system-programming-windows\u002F09.thread-pool",{"title":324,"path":325,"stem":326},"ThreadPool — Просунуті Сценарії та Внутрішня Будова","\u002Fcsharp\u002Fsystem-programming-windows\u002F09a.thread-pool-advanced","01.csharp\u002F07.system-programming-windows\u002F09a.thread-pool-advanced",{"title":328,"path":329,"stem":330},"Concurrent та Immutable Collections","\u002Fcsharp\u002Fsystem-programming-windows\u002Fconcurrent-collections","01.csharp\u002F07.system-programming-windows\u002F10.concurrent-collections",{"title":332,"path":333,"stem":334},"TPL, Task та Композиція — Від Thread до Task","\u002Fcsharp\u002Fsystem-programming-windows\u002Ftpl-parallel-plinq","01.csharp\u002F07.system-programming-windows\u002F11.tpl-parallel-plinq",{"title":336,"path":337,"stem":338},"Parallel Class та PLINQ — Data Parallelism","\u002Fcsharp\u002Fsystem-programming-windows\u002F11a.tpl-parallel-plinq-advanced","01.csharp\u002F07.system-programming-windows\u002F11a.tpl-parallel-plinq-advanced",{"title":340,"path":341,"stem":342},"Async\u002FAwait — Фундамент Асинхронного Програмування","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-fundamentals","01.csharp\u002F07.system-programming-windows\u002F12.async-fundamentals",{"title":344,"path":345,"stem":346},"SynchronizationContext та ConfigureAwait — Контекст Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-context-configureawait","01.csharp\u002F07.system-programming-windows\u002F13.async-context-configureawait",{"title":348,"path":349,"stem":350},"Async — Просунуті Паттерни","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-advanced","01.csharp\u002F07.system-programming-windows\u002F14.async-advanced",{"title":352,"path":353,"stem":354},"System.Threading.Channels — Async Producer-Consumer","\u002Fcsharp\u002Fsystem-programming-windows\u002Fchannels","01.csharp\u002F07.system-programming-windows\u002F15.channels",{"title":356,"path":357,"stem":358},"Асинхронна Синхронізація","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-synchronization","01.csharp\u002F07.system-programming-windows\u002F16.async-synchronization",{"title":360,"path":361,"stem":362},"Unsafe Code та Вказівники","\u002Fcsharp\u002Fsystem-programming-windows\u002Funsafe-code","01.csharp\u002F07.system-programming-windows\u002F17.unsafe-code",{"title":364,"path":365,"stem":366},"P\u002FInvoke та Windows API — Міст між .NET та Native Code","\u002Fcsharp\u002Fsystem-programming-windows\u002Fpinvoke-winapi","01.csharp\u002F07.system-programming-windows\u002F18.pinvoke-winapi",{"title":368,"path":369,"stem":370},"Реєстр Windows — Центральна База Конфігурації Системи","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-registry","01.csharp\u002F07.system-programming-windows\u002F19.windows-registry",{"title":372,"path":373,"stem":374},"Windows Hooks, Hotkeys та Services — Глибока Інтеграція з ОС","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-hooks-services","01.csharp\u002F07.system-programming-windows\u002F20.windows-hooks-services",{"title":376,"path":377,"stem":378},"Системне Програмування C# (Windows) — 07.system-programming-windows","\u002Fcsharp\u002Fsystem-programming-windows\u002Fimplementation_plan","01.csharp\u002F07.system-programming-windows\u002Fimplementation_plan",{"title":380,"icon":132,"path":381,"stem":382,"children":383,"page":59},"Io","\u002Fcsharp\u002Fio","01.csharp\u002F08.io",[384,388,392,396,400],{"title":385,"path":386,"stem":387},"8.1.1. Основи роботи з файловою системою","\u002Fcsharp\u002Fio\u002Ffile-system-basics","01.csharp\u002F08.io\u002F01.file-system-basics",{"title":389,"path":390,"stem":391},"8.1.2. Потоки (Streams) та Серіалізація Даних","\u002Fcsharp\u002Fio\u002Fstreams-serialization","01.csharp\u002F08.io\u002F02.streams-serialization",{"title":393,"path":394,"stem":395},"8.2.1. JSON Serialization з System.Text.Json","\u002Fcsharp\u002Fio\u002Fjson-serialization","01.csharp\u002F08.io\u002F03.json-serialization",{"title":397,"path":398,"stem":399},"8.2.2. XML Serialization та LINQ to XML","\u002Fcsharp\u002Fio\u002Fxml-serialization","01.csharp\u002F08.io\u002F04.xml-serialization",{"title":401,"path":402,"stem":403},"8.2.3. Binary Serialization: MessagePack та Protocol Buffers","\u002Fcsharp\u002Fio\u002Fbinary-serialization","01.csharp\u002F08.io\u002F05.binary-serialization",{"title":405,"icon":132,"path":406,"stem":407,"children":408,"page":59},"Ado Net","\u002Fcsharp\u002Fado-net","01.csharp\u002F09.ado-net",[409,413,417,421,425,429,433,437,441,445,449,453],{"title":410,"path":411,"stem":412},"9.1. Введення в ADO.NET","\u002Fcsharp\u002Fado-net\u002Fintroduction-to-adonet","01.csharp\u002F09.ado-net\u002F01.introduction-to-adonet",{"title":414,"path":415,"stem":416},"9.2. Клас DbConnection — з'єднання з базою даних","\u002Fcsharp\u002Fado-net\u002Fconnection","01.csharp\u002F09.ado-net\u002F02.connection",{"title":418,"path":419,"stem":420},"9.3. Клас DbCommand — виконання SQL-запитів","\u002Fcsharp\u002Fado-net\u002Fcommand-and-queries","01.csharp\u002F09.ado-net\u002F03.command-and-queries",{"title":422,"path":423,"stem":424},"9.4. Клас DbDataReader — ефективне читання даних","\u002Fcsharp\u002Fado-net\u002Fdatareader","01.csharp\u002F09.ado-net\u002F04.datareader",{"title":426,"path":427,"stem":428},"9.5. Параметризовані запити та захист від SQL Injection","\u002Fcsharp\u002Fado-net\u002Fparameters-and-sql-injection","01.csharp\u002F09.ado-net\u002F05.parameters-and-sql-injection",{"title":430,"path":431,"stem":432},"9.6. Транзакції в ADO.NET","\u002Fcsharp\u002Fado-net\u002Ftransactions","01.csharp\u002F09.ado-net\u002F06.transactions",{"title":434,"path":435,"stem":436},"9.7. DbProviderFactory — провайдер-незалежний код","\u002Fcsharp\u002Fado-net\u002Fprovider-factory","01.csharp\u002F09.ado-net\u002F07.provider-factory",{"title":438,"path":439,"stem":440},"9.8. Асинхронний доступ до даних","\u002Fcsharp\u002Fado-net\u002Fasync-data-access","01.csharp\u002F09.ado-net\u002F08.async-data-access",{"title":442,"path":443,"stem":444},"9.9. Від'єднаний режим: DataSet, DataTable, DataRow","\u002Fcsharp\u002Fado-net\u002Fdisconnected-mode-dataset","01.csharp\u002F09.ado-net\u002F09.disconnected-mode-dataset",{"title":446,"path":447,"stem":448},"9.10. DataAdapter — міст між DataSet та базою даних","\u002Fcsharp\u002Fado-net\u002Fdata-adapter","01.csharp\u002F09.ado-net\u002F10.data-adapter",{"title":450,"path":451,"stem":452},"9.11. Data Mapper та Repository: Архітектура доступу до даних","\u002Fcsharp\u002Fado-net\u002Fdata-mapper-repository","01.csharp\u002F09.ado-net\u002F11.data-mapper-repository",{"title":454,"path":455,"stem":456},"9.12. Identity Map, Unit of Work та Specification Pattern","\u002Fcsharp\u002Fado-net\u002Fadvanced-patterns","01.csharp\u002F09.ado-net\u002F12.advanced-patterns",{"title":458,"icon":255,"path":459,"stem":460,"children":461,"page":59},"Ef Core","\u002Fcsharp\u002Fef-core","01.csharp\u002F10.ef-core",[462,466,470,474,478,482,486,490,494,498,502,506,510,514,518,522,526,532,538,542,546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618,622,626,630,634,638,642,646],{"title":463,"path":464,"stem":465},"Що таке ORM? Від SQL до об'єктів","\u002Fcsharp\u002Fef-core\u002Fwhat-is-orm","01.csharp\u002F10.ef-core\u002F01.what-is-orm",{"title":467,"path":468,"stem":469},"Перший проєкт — від нуля до CRUD","\u002Fcsharp\u002Fef-core\u002Ffirst-project","01.csharp\u002F10.ef-core\u002F02.first-project",{"title":471,"path":472,"stem":473},"DbContext — Серце EF Core","\u002Fcsharp\u002Fef-core\u002Fdbcontext-deep-dive","01.csharp\u002F10.ef-core\u002F03.dbcontext-deep-dive",{"title":475,"path":476,"stem":477},"Провайдери баз даних — Архітектура та Вибір СУБД","\u002Fcsharp\u002Fef-core\u002Fdatabase-providers","01.csharp\u002F10.ef-core\u002F04.database-providers",{"title":479,"path":480,"stem":481},"Конвенції EF Core — Магія без конфігурації","\u002Fcsharp\u002Fef-core\u002Fconventions","01.csharp\u002F10.ef-core\u002F05.conventions",{"title":483,"path":484,"stem":485},"Fluent API та Data Annotations — Явна конфігурація моделі","\u002Fcsharp\u002Fef-core\u002Ffluent-api-vs-annotations","01.csharp\u002F10.ef-core\u002F06.fluent-api-vs-annotations",{"title":487,"path":488,"stem":489},"Зв'язки — One-to-One та One-to-Many","\u002Fcsharp\u002Fef-core\u002Frelationships-basics","01.csharp\u002F10.ef-core\u002F07.relationships-basics",{"title":491,"path":492,"stem":493},"Зв'язки Advanced — Many-to-Many та Складні Сценарії","\u002Fcsharp\u002Fef-core\u002Frelationships-advanced","01.csharp\u002F10.ef-core\u002F08.relationships-advanced",{"title":495,"path":496,"stem":497},"Властивості — Типи, Конвертери, Компаратори (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part1","01.csharp\u002F10.ef-core\u002F09.property-configuration-part1",{"title":499,"path":500,"stem":501},"Властивості — Value Comparers, Generators, Shadow Properties (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part2","01.csharp\u002F10.ef-core\u002F09.property-configuration-part2",{"title":503,"path":504,"stem":505},"Складні типи — Owned Types та Complex Types (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part1","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part1",{"title":507,"path":508,"stem":509},"Складні типи — Complex Types, Keyless Entities, Порівняння (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part2","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part2",{"title":511,"path":512,"stem":513},"JSON Columns — Складні дані у JSON (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part1","01.csharp\u002F10.ef-core\u002F11.json-columns-part1",{"title":515,"path":516,"stem":517},"JSON Columns — Value Comparers, Індекси, Провайдери (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part2","01.csharp\u002F10.ef-core\u002F11.json-columns-part2",{"title":519,"path":520,"stem":521},"Успадкування — Абстрактні класи та TPH (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finheritance-part1","01.csharp\u002F10.ef-core\u002F12.inheritance-part1",{"title":523,"path":524,"stem":525},"Успадкування — TPT, TPC та Порівняння Стратегій (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finheritance-part2","01.csharp\u002F10.ef-core\u002F12.inheritance-part2",{"title":527,"path":528,"stem":529,"children":530},"Індекси, Обмеження та Схема (Частина 1)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part1","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part1",[531],{"title":527,"path":528,"stem":529},{"title":533,"path":534,"stem":535,"children":536},"Індекси, Обмеження та Схема (Частина 2)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part2","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part2",[537],{"title":533,"path":534,"stem":535},{"title":539,"path":540,"stem":541},"Seed Data — Початкові Дані (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fseeding-part1","01.csharp\u002F10.ef-core\u002F14.seeding-part1",{"title":543,"path":544,"stem":545},"Seed Data — SQL-скрипти, Bogus та Стратегії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fseeding-part2","01.csharp\u002F10.ef-core\u002F14.seeding-part2",{"title":547,"path":548,"stem":549},"Global Query Filters — Глобальні Фільтри (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part1","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part1",{"title":551,"path":552,"stem":553},"Global Query Filters — Підводні камені та Інтеграція (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part2","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part2",{"title":555,"path":556,"stem":557},"LINQ-запити в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part1","01.csharp\u002F10.ef-core\u002F16.linq-queries-part1",{"title":559,"path":560,"stem":561},"LINQ-запити в EF Core (Частина 2)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part2","01.csharp\u002F10.ef-core\u002F16.linq-queries-part2",{"title":563,"path":564,"stem":565},"Завантаження Пов'язаних Даних (Частина 1)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part1","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part1",{"title":567,"path":568,"stem":569},"Завантаження Пов'язаних Даних (Частина 2)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part2","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part2",{"title":571,"path":572,"stem":573},"Raw SQL, Views та Stored Procedures (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part1","01.csharp\u002F10.ef-core\u002F18.raw-sql-part1",{"title":575,"path":576,"stem":577},"Raw SQL — Stored Procedures, DbFunction та Bulk Operations (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part2","01.csharp\u002F10.ef-core\u002F18.raw-sql-part2",{"title":579,"path":580,"stem":581},"Продвинуті Запити — Compiled Queries, Bulk та Оптимізація (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part1","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part1",{"title":583,"path":584,"stem":585},"Продвинуті Запити — Query Tags, Bulk та Interceptors (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part2","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part2",{"title":587,"path":588,"stem":589},"Change Tracker — Відстеження Змін (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part1","01.csharp\u002F10.ef-core\u002F20.change-tracking-part1",{"title":591,"path":592,"stem":593},"Change Tracker — Графи Об'єктів та Disconnected (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part2","01.csharp\u002F10.ef-core\u002F20.change-tracking-part2",{"title":595,"path":596,"stem":597},"Збереження Даних та Транзакції (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part1","01.csharp\u002F10.ef-core\u002F21.saving-data-part1",{"title":599,"path":600,"stem":601},"Збереження Даних — Concurrency та Outbox (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part2","01.csharp\u002F10.ef-core\u002F21.saving-data-part2",{"title":603,"path":604,"stem":605},"Конкурентність та Блокування (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part1","01.csharp\u002F10.ef-core\u002F22.concurrency-part1",{"title":607,"path":608,"stem":609},"Конкурентність — Дедлоки та Queue Processing (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part2","01.csharp\u002F10.ef-core\u002F22.concurrency-part2",{"title":611,"path":612,"stem":613},"Міграції в EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part1","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part1",{"title":615,"path":616,"stem":617},"Міграції в EF Core — Основи (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part2","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part2",{"title":619,"path":620,"stem":621},"Міграції — Просунуті Сценарії (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part1","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part1",{"title":623,"path":624,"stem":625},"Міграції — Просунуті Сценарії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part2","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part2",{"title":627,"path":628,"stem":629},"Управління Схемою та Database-First (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part1","01.csharp\u002F10.ef-core\u002F25.schema-management-part1",{"title":631,"path":632,"stem":633},"Управління Схемою та Database-First (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part2","01.csharp\u002F10.ef-core\u002F25.schema-management-part2",{"title":635,"path":636,"stem":637},"Продуктивність EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fperformance-fundamentals-part1","01.csharp\u002F10.ef-core\u002F26.performance-fundamentals-part1",{"title":639,"path":640,"stem":641},"Interceptors в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part1","01.csharp\u002F10.ef-core\u002F29.interceptors-part1",{"title":643,"path":644,"stem":645},"Interceptors в EF Core — Connection, Transaction та Materialization (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part2","01.csharp\u002F10.ef-core\u002F29.interceptors-part2",{"title":647,"path":648,"stem":649},"План вивчення Entity Framework Core — Повний курс","\u002Fcsharp\u002Fef-core\u002Fimplementation_plan","01.csharp\u002F10.ef-core\u002Fimplementation_plan",{"title":651,"icon":652,"path":653,"stem":654,"children":655,"page":59},"ASP.NET","i-devicon-dotnetcore","\u002Fcsharp\u002Faspnet","01.csharp\u002F11.aspnet",[656,730,791,869,927,941,967,1057,1111,1182,1212,1289,1346],{"title":657,"icon":658,"path":659,"stem":660,"children":661,"page":59},"Minimal API","i-lucide-network","\u002Fcsharp\u002Faspnet\u002Fminimal-api","01.csharp\u002F11.aspnet\u002F01.minimal-api",[662,666,670,674,678,682,686,690,694,698,702,706,710,714,718,722,726],{"title":663,"path":664,"stem":665},"Вступ до ASP.NET та еволюція фреймворку","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fintroduction","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F01.introduction",{"title":667,"path":668,"stem":669},"Перший додаток на ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Ffirst-application","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F02.first-application",{"title":671,"path":672,"stem":673},"WebApplication, Builder та Dependency Injection","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fwebapplication-builder","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F03.webapplication-builder",{"title":675,"path":676,"stem":677},"Конвеєр запитів та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frequest-pipeline-middleware","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F04.request-pipeline-middleware",{"title":679,"path":680,"stem":681},"Маршрутизація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F05.routing-basics",{"title":683,"path":684,"stem":685},"Маршрутизація в ASP.NET Core: Розширені можливості","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F06.routing-advanced",{"title":687,"path":688,"stem":689},"Статичні файли в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-files","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F07.static-files",{"title":691,"path":692,"stem":693},"Статичні Активи: MapStaticAssets (ASP.NET Core 9.0)","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-assets","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F08.static-assets",{"title":695,"path":696,"stem":697},"Конфігурація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-fundamentals","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F09.configuration-fundamentals",{"title":699,"path":700,"stem":701},"Конфігурація: Паттерн Options","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-options","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F10.configuration-options",{"title":703,"path":704,"stem":705},"Логування в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F11.logging-basics",{"title":707,"path":708,"stem":709},"Логування: Serilog та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F12.logging-advanced",{"title":711,"path":712,"stem":713},"Управління станом: HttpContext.Items та Cookies","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstate-management","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F13.state-management",{"title":715,"path":716,"stem":717},"Стан сесії: Sessions","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fsession-state","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F14.session-state",{"title":719,"path":720,"stem":721},"Структура проєкту: від хаосу до архітектури","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fproject-structure","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F15.project-structure",{"title":723,"path":724,"stem":725},"Scalar у Minimal API: повний проєкт і Fluent OpenAPI","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fscalar-openapi-fluent","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F16.scalar-openapi-fluent",{"title":727,"path":728,"stem":729},"Swagger \u002F Swashbuckle у Minimal API: окремий класичний шлях","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fswagger-swashbuckle","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F17.swagger-swashbuckle",{"title":731,"icon":658,"path":732,"stem":733,"children":734,"page":59},"API","\u002Fcsharp\u002Faspnet\u002Fapi","01.csharp\u002F11.aspnet\u002F02.api",[735,739,743,747,751,755,759,763,767,771,775,779,783,787],{"title":736,"path":737,"stem":738},"Що таке API. Клієнт-серверна архітектура","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fwhat-is-api","01.csharp\u002F11.aspnet\u002F02.api\u002F01.what-is-api",{"title":740,"path":741,"stem":742},"Формати даних: JSON, XML, TOML та бінарні формати","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fdata-formats","01.csharp\u002F11.aspnet\u002F02.api\u002F02.data-formats",{"title":744,"path":745,"stem":746},"Парадигми API та концепція REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-paradigms-rest","01.csharp\u002F11.aspnet\u002F02.api\u002F03.api-paradigms-rest",{"title":748,"path":749,"stem":750},"HTTP-методи, статус-коди та заголовки","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fhttp-methods-status-codes","01.csharp\u002F11.aspnet\u002F02.api\u002F04.http-methods-status-codes",{"title":752,"path":753,"stem":754},"Організація HTTP API за принципами REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Frest-organizing","01.csharp\u002F11.aspnet\u002F02.api\u002F05.rest-organizing",{"title":756,"path":757,"stem":758},"Номенклатура URL та CRUD-операції","\u002Fcsharp\u002Faspnet\u002Fapi\u002Furl-nomenclature-crud","01.csharp\u002F11.aspnet\u002F02.api\u002F06.url-nomenclature-crud",{"title":760,"path":761,"stem":762},"Правила дизайну: іменування та стандарти","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-naming","01.csharp\u002F11.aspnet\u002F02.api\u002F07.api-design-naming",{"title":764,"path":765,"stem":766},"Валідація, ліміти та обробка помилок","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-validation","01.csharp\u002F11.aspnet\u002F02.api\u002F08.api-design-validation",{"title":768,"path":769,"stem":770},"Обробка помилок у Minimal API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Ferror-handling-http","01.csharp\u002F11.aspnet\u002F02.api\u002F09.error-handling-http",{"title":772,"path":773,"stem":774},"Ідемпотентність та синхронізація стану","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fidempotency-sync","01.csharp\u002F11.aspnet\u002F02.api\u002F10.idempotency-sync",{"title":776,"path":777,"stem":778},"Пагінація та організація списків","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fpagination-lists","01.csharp\u002F11.aspnet\u002F02.api\u002F11.pagination-lists",{"title":780,"path":781,"stem":782},"Безпека API, кешування та інтернаціоналізація","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fsecurity-auth","01.csharp\u002F11.aspnet\u002F02.api\u002F12.security-auth",{"title":784,"path":785,"stem":786},"Процес проєктування API та документування","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-process","01.csharp\u002F11.aspnet\u002F02.api\u002F13.api-design-process",{"title":788,"path":789,"stem":790},"OpenAPI: контракт, специфікація та документація API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fopenapi","01.csharp\u002F11.aspnet\u002F02.api\u002F14.openapi",{"title":792,"icon":793,"path":794,"stem":795,"children":796,"page":59},"Auth","i-lucide-shield-check","\u002Fcsharp\u002Faspnet\u002Fauth","01.csharp\u002F11.aspnet\u002F03.auth",[797,801,805,809,813,817,821,825,829,833,837,841,845,849,853,857,861,865],{"title":798,"path":799,"stem":800},"Основи аутентифікації та авторизації","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauth-fundamentals","01.csharp\u002F11.aspnet\u002F03.auth\u002F01.auth-fundamentals",{"title":802,"path":803,"stem":804},"JWT-аутентифікація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fjwt-authentication","01.csharp\u002F11.aspnet\u002F03.auth\u002F02.jwt-authentication",{"title":806,"path":807,"stem":808},"Авторизація: ролі, політики та resource-based доступ","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauthorization-policies","01.csharp\u002F11.aspnet\u002F03.auth\u002F03.authorization-policies",{"title":810,"path":811,"stem":812},"Cookie-аутентифікація та ASP.NET Core Identity","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcookie-auth-identity","01.csharp\u002F11.aspnet\u002F03.auth\u002F04.cookie-auth-identity",{"title":814,"path":815,"stem":816},"JWT + Refresh Tokens (HttpOnly Cookie)","\u002Fcsharp\u002Faspnet\u002Fauth\u002F04b.identity-auth-jwt","01.csharp\u002F11.aspnet\u002F03.auth\u002F04b.identity-auth-jwt",{"title":818,"path":819,"stem":820},"Identity: Підтвердження Email та Скидання Пароля","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-email-confirmation","01.csharp\u002F11.aspnet\u002F03.auth\u002F05.identity-email-confirmation",{"title":822,"path":823,"stem":824},"Identity: Двофакторна Аутентифікація (2FA)","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-two-factor","01.csharp\u002F11.aspnet\u002F03.auth\u002F06.identity-two-factor",{"title":826,"path":827,"stem":828},"Identity: Внутрішня Архітектура та Кастомізація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-internals","01.csharp\u002F11.aspnet\u002F03.auth\u002F07.identity-internals",{"title":830,"path":831,"stem":832},"OAuth 2.0 та зовнішні провайдери","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-external-providers","01.csharp\u002F11.aspnet\u002F03.auth\u002F08.oauth-external-providers",{"title":834,"path":835,"stem":836},"Безпека на практиці: CORS, HTTPS та захист від атак","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fsecurity-hardening","01.csharp\u002F11.aspnet\u002F03.auth\u002F09.security-hardening",{"title":838,"path":839,"stem":840},"Теорія OAuth 2.0: Поняття, Аналогії та Флоу","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-theory","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oauth-theory",{"title":842,"path":843,"stem":844},"OIDC, OAuth 2.0 та Keycloak в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foidc-keycloak","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oidc-keycloak",{"title":846,"path":847,"stem":848},"API Keys аутентифікація в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fapi-keys","01.csharp\u002F11.aspnet\u002F03.auth\u002F11.api-keys",{"title":850,"path":851,"stem":852},"Rate Limiting та Throttling в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frate-limiting","01.csharp\u002F11.aspnet\u002F03.auth\u002F12.rate-limiting",{"title":854,"path":855,"stem":856},"Refresh Token Rotation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frefresh-token-rotation","01.csharp\u002F11.aspnet\u002F03.auth\u002F13.refresh-token-rotation",{"title":858,"path":859,"stem":860},"Certificate Authentication та mTLS в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcertificate-auth","01.csharp\u002F11.aspnet\u002F03.auth\u002F14.certificate-auth",{"title":862,"path":863,"stem":864},"RBAC, ABAC та ReBAC в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frbac-abac-rebac","01.csharp\u002F11.aspnet\u002F03.auth\u002F15.rbac-abac-rebac",{"title":866,"path":867,"stem":868},"Multi-tenancy та ізоляція даних в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fmulti-tenancy","01.csharp\u002F11.aspnet\u002F03.auth\u002F16.multi-tenancy",{"title":870,"icon":871,"path":872,"stem":873,"children":874,"page":59},"Нотифікації","i-lucide-bell","\u002Fcsharp\u002Faspnet\u002Fnotifications","01.csharp\u002F11.aspnet\u002F04.notifications",[875,879,883,887,891,895,899,903,907,911,915,919,923],{"title":876,"path":877,"stem":878},"In-App нотифікації через базу даних","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fin-app-database-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F01.in-app-database-notifications",{"title":880,"path":881,"stem":882},"Polling: Регулярний запит оновлень","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fpolling","01.csharp\u002F11.aspnet\u002F04.notifications\u002F02.polling",{"title":884,"path":885,"stem":886},"Server-Sent Events: Однострімовий push від сервера","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fserver-sent-events","01.csharp\u002F11.aspnet\u002F04.notifications\u002F03.server-sent-events",{"title":888,"path":889,"stem":890},"WebSockets: Двостороннє з'єднання в реальному часі","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fwebsockets","01.csharp\u002F11.aspnet\u002F04.notifications\u002F04.websockets",{"title":892,"path":893,"stem":894},"SignalR: Абстракція над транспортами реального часу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fsignalr","01.csharp\u002F11.aspnet\u002F04.notifications\u002F05.signalr",{"title":896,"path":897,"stem":898},"Background Services: Фонові задачі в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fbackground-services","01.csharp\u002F11.aspnet\u002F04.notifications\u002F06.background-services",{"title":900,"path":901,"stem":902},"Web Push нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fweb-push","01.csharp\u002F11.aspnet\u002F04.notifications\u002F07.web-push",{"title":904,"path":905,"stem":906},"Email нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Femail-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F08.email-notifications",{"title":908,"path":909,"stem":910},"Порівняння підходів: Як вибрати правильну технологію нотифікацій","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fchoosing-the-right-approach","01.csharp\u002F11.aspnet\u002F04.notifications\u002F09.choosing-the-right-approach",{"title":912,"path":913,"stem":914},"Hangfire: Надійне планування фонових задач","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire","01.csharp\u002F11.aspnet\u002F04.notifications\u002F10.hangfire",{"title":916,"path":917,"stem":918},"Практика: Конвертація зображень у WebP через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-image-webp","01.csharp\u002F11.aspnet\u002F04.notifications\u002F11.hangfire-image-webp",{"title":920,"path":921,"stem":922},"Практика: Підготовка відео до HLS-стрімінгу через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-video-hls","01.csharp\u002F11.aspnet\u002F04.notifications\u002F12.hangfire-video-hls",{"title":924,"path":925,"stem":926},"Telegram-нотифікації: від одного повідомлення до масових розсилок і мульти-канального підходу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Ftelegram-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F13.telegram-notifications",{"title":928,"icon":929,"path":930,"stem":931,"children":932,"page":59},"Інтернаціоналізація","i-lucide-languages","\u002Fcsharp\u002Faspnet\u002Fi18n","01.csharp\u002F11.aspnet\u002F05.i18n",[933,937],{"title":934,"path":935,"stem":936},"Інтернаціоналізація (i18n) у Minimal API: від A до Я","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Finternationalization","01.csharp\u002F11.aspnet\u002F05.i18n\u002F01.internationalization",{"title":938,"path":939,"stem":940},"Humanizer: людиномовні рядки у .NET","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Fhumanizer","01.csharp\u002F11.aspnet\u002F05.i18n\u002F02.humanizer",{"title":942,"icon":943,"path":944,"stem":945,"children":946,"page":59},"Кешування","i-lucide-layers","\u002Fcsharp\u002Faspnet\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching",[947,951,955,959,963],{"title":948,"path":949,"stem":950},"Огляд кешування: чотири рівні і коли що обирати","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching\u002F01.caching",{"title":952,"path":953,"stem":954},"IMemoryCache: кеш в оперативній пам'яті","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fmemory-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F02.memory-cache",{"title":956,"path":957,"stem":958},"IDistributedCache і Redis: розподілений кеш","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fdistributed-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F03.distributed-cache",{"title":960,"path":961,"stem":962},"Response Cache: HTTP-кешування через Cache-Control","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fresponse-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F04.response-cache",{"title":964,"path":965,"stem":966},"Output Cache: серверний кеш HTTP-відповідей (.NET 7+)","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Foutput-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F05.output-cache",{"title":968,"icon":969,"path":970,"stem":971,"children":972,"page":59},"Тестування","i-lucide-test-tube","\u002Fcsharp\u002Faspnet\u002Ftesting","01.csharp\u002F11.aspnet\u002F07.testing",[973,977,981,985,989,993,997,1001,1005,1009,1013,1017,1021,1025,1029,1033,1037,1041,1045,1049,1053],{"title":974,"path":975,"stem":976},"Що таке тестування? Від інтуїції до науки","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-is-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F01.what-is-testing",{"title":978,"path":979,"stem":980},"Піраміда тестування — Стратегія, а не Догма","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-pyramid","01.csharp\u002F11.aspnet\u002F07.testing\u002F02.testing-pyramid",{"title":982,"path":983,"stem":984},"Дві Школи Тестування — Лондон проти Детройту","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-schools","01.csharp\u002F11.aspnet\u002F07.testing\u002F03.testing-schools",{"title":986,"path":987,"stem":988},"TDD та BDD — Тести як Дизайн-інструмент","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftdd-and-bdd","01.csharp\u002F11.aspnet\u002F07.testing\u002F04.tdd-and-bdd",{"title":990,"path":991,"stem":992},"Що саме тестувати — Техніки аналізу та Циклomatична складність","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-to-test","01.csharp\u002F11.aspnet\u002F07.testing\u002F05.what-to-test",{"title":994,"path":995,"stem":996},"Тестові Фреймворки — Навіщо вони і що всередині","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftest-frameworks","01.csharp\u002F11.aspnet\u002F07.testing\u002F06.test-frameworks",{"title":998,"path":999,"stem":1000},"xUnit — Факти, Теорії та Lifecycle тестів","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-basics","01.csharp\u002F11.aspnet\u002F07.testing\u002F07.xunit-basics",{"title":1002,"path":1003,"stem":1004},"xUnit Advanced — Fixtures, Кастомізація та Розширення","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F08.xunit-advanced",{"title":1006,"path":1007,"stem":1008},"Moq — Глибоке занурення в мокування","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fmocking-with-moq","01.csharp\u002F11.aspnet\u002F07.testing\u002F09.mocking-with-moq",{"title":1010,"path":1011,"stem":1012},"Тестування Баз Даних — EF Core, SQLite та Testcontainers","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fdatabase-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F10.database-testing",{"title":1014,"path":1015,"stem":1016},"Integration Testing — Частина 1 [Теорія та WebApplicationFactory]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F11.integration-testing",{"title":1018,"path":1019,"stem":1020},"Інтеграційне тестування — Практика","\u002Fcsharp\u002Faspnet\u002Ftesting\u002F11a.integration-testing-practice","01.csharp\u002F11.aspnet\u002F07.testing\u002F11a.integration-testing-practice",{"title":1022,"path":1023,"stem":1024},"Integration Testing — Частина 2 [Просунуті Сценарії та Testcontainers]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F12.integration-testing-advanced",{"title":1026,"path":1027,"stem":1028},"Професійний Postman: Колекції, Змінні та GitHub Інтеграція","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fpostman-professional","01.csharp\u002F11.aspnet\u002F07.testing\u002F13.postman-professional",{"title":1030,"path":1031,"stem":1032},"HttpClient у Тестах Частина 1: Архітектура та MockHttpMessageHandler","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fhttpclient-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F14.httpclient-testing",{"title":1034,"path":1035,"stem":1036},"HttpClient у Тестах Частина 2: WireMock.Net та Resilience","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwiremock-net","01.csharp\u002F11.aspnet\u002F07.testing\u002F15.wiremock-net",{"title":1038,"path":1039,"stem":1040},"Патерни та Анти-патерни Тестування: Test Smells","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-patterns","01.csharp\u002F11.aspnet\u002F07.testing\u002F16.testing-patterns",{"title":1042,"path":1043,"stem":1044},"Просунуті інструменти: Time, Snapshots та Властивості","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fadvanced-testing-tools","01.csharp\u002F11.aspnet\u002F07.testing\u002F17.advanced-testing-tools",{"title":1046,"path":1047,"stem":1048},"Тестування Архітектури з NetArchTest","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Farchitecture-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F18.architecture-testing",{"title":1050,"path":1051,"stem":1052},"Тестування Продуктивності: BenchmarkDotNet, NBomber та k6","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fperformance-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F19.performance-testing",{"title":1054,"path":1055,"stem":1056},"Залишок плану для курсу \"Тестування ASP.NET Minimal API\"","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fremaining_plan","01.csharp\u002F11.aspnet\u002F07.testing\u002Fremaining_plan",{"title":1058,"icon":1059,"path":1060,"stem":1061,"children":1062,"page":59},"Платежі","i-lucide-credit-card","\u002Fcsharp\u002Faspnet\u002Fpayments","01.csharp\u002F11.aspnet\u002F08.payments",[1063,1067,1071,1075,1079,1083,1087,1091,1095,1099,1103,1107],{"title":1064,"path":1065,"stem":1066},"Основи платіжної інфраструктури","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-fundamentals","01.csharp\u002F11.aspnet\u002F08.payments\u002F01.payment-fundamentals",{"title":1068,"path":1069,"stem":1070},"Методи оплати в Україні","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-methods-ukraine","01.csharp\u002F11.aspnet\u002F08.payments\u002F02.payment-methods-ukraine",{"title":1072,"path":1073,"stem":1074},"PCI DSS та безпека платежів","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpci-dss-security","01.csharp\u002F11.aspnet\u002F08.payments\u002F03.pci-dss-security",{"title":1076,"path":1077,"stem":1078},"Архітектура платіжної підсистеми","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-architecture","01.csharp\u002F11.aspnet\u002F08.payments\u002F04.payment-architecture",{"title":1080,"path":1081,"stem":1082},"Інтеграція LiqPay (ПриватБанк)","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fliqpay-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F05.liqpay-integration",{"title":1084,"path":1085,"stem":1086},"Інтеграція Monobank Acquiring API","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fmonobank-acquiring","01.csharp\u002F11.aspnet\u002F08.payments\u002F06.monobank-acquiring",{"title":1088,"path":1089,"stem":1090},"Інтеграція Stripe","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fstripe-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F07.stripe-integration",{"title":1092,"path":1093,"stem":1094},"Webhooks — глибоке занурення","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fwebhooks-deep-dive","01.csharp\u002F11.aspnet\u002F08.payments\u002F08.webhooks-deep-dive",{"title":1096,"path":1097,"stem":1098},"Підписки та рекурентні платежі","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fsubscriptions-recurring","01.csharp\u002F11.aspnet\u002F08.payments\u002F09.subscriptions-recurring",{"title":1100,"path":1101,"stem":1102},"Повернення коштів та диспути","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Frefunds-disputes","01.csharp\u002F11.aspnet\u002F08.payments\u002F10.refunds-disputes",{"title":1104,"path":1105,"stem":1106},"Тестування платіжних інтеграцій","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Ftesting-payments","01.csharp\u002F11.aspnet\u002F08.payments\u002F11.testing-payments",{"title":1108,"path":1109,"stem":1110},"Чекліст виходу в Production","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fproduction-checklist","01.csharp\u002F11.aspnet\u002F08.payments\u002F12.production-checklist",{"title":1112,"icon":1113,"items":1114,"path":1127,"stem":1128,"children":1129,"page":59},"Популярні бібліотеки","lucide:box",[1115,1116,1117,1118,1119,1120,1121,1122,1123,1124,1125,1126],"01.fluent-validation","02.mapster","03.erroror-result-pattern","04.serilog","05.mediatr","06.polly","07.health-checks","08.feature-management","09.fluent-email","10.quest-pdf","11.bogus","12.humanizer-guard","\u002Fcsharp\u002Faspnet\u002Flibraries","01.csharp\u002F11.aspnet\u002F09.libraries",[1130,1134,1138,1142,1146,1150,1154,1158,1162,1166,1170,1174,1178],{"title":1131,"path":1132,"stem":1133},"Валідація з FluentValidation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-validation","01.csharp\u002F11.aspnet\u002F09.libraries\u002F01.fluent-validation",{"title":1135,"path":1136,"stem":1137},"Маппінг об","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmapster","01.csharp\u002F11.aspnet\u002F09.libraries\u002F02.mapster",{"title":1139,"path":1140,"stem":1141},"Обробка помилок з ErrorOr та Result Pattern в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ferroror-result-pattern","01.csharp\u002F11.aspnet\u002F09.libraries\u002F03.erroror-result-pattern",{"title":1143,"path":1144,"stem":1145},"Структуроване логування з Serilog в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fserilog","01.csharp\u002F11.aspnet\u002F09.libraries\u002F04.serilog",{"title":1147,"path":1148,"stem":1149},"CQRS та Mediator з MediatR в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmediatr","01.csharp\u002F11.aspnet\u002F09.libraries\u002F05.mediatr",{"title":1151,"path":1152,"stem":1153},"Відмовостійкість з Polly в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fpolly","01.csharp\u002F11.aspnet\u002F09.libraries\u002F06.polly",{"title":1155,"path":1156,"stem":1157},"Health Checks в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F09.libraries\u002F07.health-checks",{"title":1159,"path":1160,"stem":1161},"Feature Management та Feature Flags в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffeature-management","01.csharp\u002F11.aspnet\u002F09.libraries\u002F08.feature-management",{"title":1163,"path":1164,"stem":1165},"Відправка Email з FluentEmail в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-email","01.csharp\u002F11.aspnet\u002F09.libraries\u002F09.fluent-email",{"title":1167,"path":1168,"stem":1169},"Генерація PDF з QuestPDF в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fquest-pdf","01.csharp\u002F11.aspnet\u002F09.libraries\u002F10.quest-pdf",{"title":1171,"path":1172,"stem":1173},"Генерація тестових даних з Bogus в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fbogus","01.csharp\u002F11.aspnet\u002F09.libraries\u002F11.bogus",{"title":1175,"path":1176,"stem":1177},"Humanizer та Guard Clauses в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhumanizer-guard","01.csharp\u002F11.aspnet\u002F09.libraries\u002F12.humanizer-guard",{"title":1179,"path":1180,"stem":1181},"План модуля 10.libraries — Популярні бібліотеки ASP.NET","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fplan","01.csharp\u002F11.aspnet\u002F09.libraries\u002Fplan",{"title":1183,"icon":1184,"path":1185,"stem":1186,"children":1187,"page":59},"Razor Pages","i-lucide-layout-template","\u002Fcsharp\u002Faspnet\u002Frazor-pages","01.csharp\u002F11.aspnet\u002F10.razor-pages",[1188,1192,1196,1200,1204,1208],{"title":1189,"path":1190,"stem":1191},"Від Minimal API до Razor Pages: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ffrom-minimal-api","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F01.from-minimal-api",{"title":1193,"path":1194,"stem":1195},"PageModel: логіка сторінки Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fpage-model","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F02.page-model",{"title":1197,"path":1198,"stem":1199},"Razor синтаксис: шаблонізатор у .cshtml","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Frazor-syntax","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F03.razor-syntax",{"title":1201,"path":1202,"stem":1203},"Tag Helpers: типізований HTML","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ftag-helpers","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F04.tag-helpers",{"title":1205,"path":1206,"stem":1207},"Форми і валідація: повний цикл обробки даних","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fforms-validation","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F05.forms-validation",{"title":1209,"path":1210,"stem":1211},"Практичний проєкт: TaskManager на Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fproject-task-manager","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F06.project-task-manager",{"title":1213,"path":1214,"stem":1215,"children":1216,"page":59},"ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc","01.csharp\u002F11.aspnet\u002F11.mvc",[1217,1221,1225,1229,1233,1237,1241,1245,1249,1253,1257,1261,1265,1269,1273,1277,1281,1285],{"title":1218,"path":1219,"stem":1220},"Патерн MVC: архітектура, що змінила веб","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-pattern","01.csharp\u002F11.aspnet\u002F11.mvc\u002F01.mvc-pattern",{"title":1222,"path":1223,"stem":1224},"Від Razor Pages до MVC: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffrom-razor-pages","01.csharp\u002F11.aspnet\u002F11.mvc\u002F02.from-razor-pages",{"title":1226,"path":1227,"stem":1228},"Controllers та Actions: серце MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fcontrollers-actions","01.csharp\u002F11.aspnet\u002F11.mvc\u002F03.controllers-actions",{"title":1230,"path":1231,"stem":1232},"Маршрутизація в MVC: Convention vs Attribute Routing","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Frouting-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F04.routing-mvc",{"title":1234,"path":1235,"stem":1236},"Model Binding: від HTTP до C#","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmodel-binding","01.csharp\u002F11.aspnet\u002F11.mvc\u002F05.model-binding",{"title":1238,"path":1239,"stem":1240},"Views, ViewData, ViewBag, TempData і ViewModel","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fviews-viewdata-tempdata","01.csharp\u002F11.aspnet\u002F11.mvc\u002F06.views-viewdata-tempdata",{"title":1242,"path":1243,"stem":1244},"Filters: аспектно-орієнтоване програмування в MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffilters","01.csharp\u002F11.aspnet\u002F11.mvc\u002F07.filters",{"title":1246,"path":1247,"stem":1248},"Areas: структурування великих застосунків","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fareas","01.csharp\u002F11.aspnet\u002F11.mvc\u002F08.areas",{"title":1250,"path":1251,"stem":1252},"View Components: повторювані незалежні блоки UI","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fview-components","01.csharp\u002F11.aspnet\u002F11.mvc\u002F09.view-components",{"title":1254,"path":1255,"stem":1256},"Display та Editor Templates","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fdisplay-editor-templates","01.csharp\u002F11.aspnet\u002F11.mvc\u002F10.display-editor-templates",{"title":1258,"path":1259,"stem":1260},"Валідація: IValidatableObject та FluentValidation","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fvalidation-advanced","01.csharp\u002F11.aspnet\u002F11.mvc\u002F11.validation-advanced",{"title":1262,"path":1263,"stem":1264},"HTMX: інтерактивність через HTML-атрибути","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx","01.csharp\u002F11.aspnet\u002F11.mvc\u002F12.htmx",{"title":1266,"path":1267,"stem":1268},"HTMX у ASP.NET Core MVC: серверна інтеграція","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fajax-htmx-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F13.ajax-htmx-mvc",{"title":1270,"path":1271,"stem":1272},"Практичний проєкт: Каталог товарів з HTMX","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F14.htmx-project",{"title":1274,"path":1275,"stem":1276},"Завантаження та обробка файлів","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffile-upload","01.csharp\u002F11.aspnet\u002F11.mvc\u002F15.file-upload",{"title":1278,"path":1279,"stem":1280},"Глобалізація та Локалізація MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fglobalization-localization","01.csharp\u002F11.aspnet\u002F11.mvc\u002F16.globalization-localization",{"title":1282,"path":1283,"stem":1284},"Підсумковий проєкт: Блог-платформа","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F17.mvc-project",{"title":1286,"path":1287,"stem":1288},"План курсу: ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fplan","01.csharp\u002F11.aspnet\u002F11.mvc\u002Fplan",{"title":1290,"path":1291,"stem":1292,"children":1293,"page":59},"Web Api","\u002Fcsharp\u002Faspnet\u002Fweb-api","01.csharp\u002F11.aspnet\u002F12.web-api",[1294,1298,1302,1306,1310,1314,1318,1322,1326,1330,1334,1338,1342],{"title":1295,"path":1296,"stem":1297},"Від Minimal API до Controller-based API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffrom-minimal-api-to-controllers","01.csharp\u002F11.aspnet\u002F12.web-api\u002F01.from-minimal-api-to-controllers",{"title":1299,"path":1300,"stem":1301},"ControllerBase, ActionResult\u003CT> та Response Types","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontroller-base-actionresult","01.csharp\u002F11.aspnet\u002F12.web-api\u002F02.controller-base-actionresult",{"title":1303,"path":1304,"stem":1305},"Content Negotiation - JSON, XML та власні форматери","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontent-negotiation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F03.content-negotiation",{"title":1307,"path":1308,"stem":1309},"Версіонування API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-versioning","01.csharp\u002F11.aspnet\u002F12.web-api\u002F04.api-versioning",{"title":1311,"path":1312,"stem":1313},"ProblemDetails та структурована обробка помилок","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fproblemdetails-error-handling","01.csharp\u002F11.aspnet\u002F12.web-api\u002F05.problemdetails-error-handling",{"title":1315,"path":1316,"stem":1317},"Фільтри у Web API контексті","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffilters-for-api","01.csharp\u002F11.aspnet\u002F12.web-api\u002F06.filters-for-api",{"title":1319,"path":1320,"stem":1321},"Пагінація, фільтрація та сортування","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fpagination-filtering-sorting","01.csharp\u002F11.aspnet\u002F12.web-api\u002F07.pagination-filtering-sorting",{"title":1323,"path":1324,"stem":1325},"HATEOAS та Resource Expansion","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhateoas-resource-expansion","01.csharp\u002F11.aspnet\u002F12.web-api\u002F08.hateoas-resource-expansion",{"title":1327,"path":1328,"stem":1329},"Гібридна архітектура - Minimal API + Controllers","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fminimal-api-vs-controllers-hybrid","01.csharp\u002F11.aspnet\u002F12.web-api\u002F09.minimal-api-vs-controllers-hybrid",{"title":1331,"path":1332,"stem":1333},"Документація API - Swashbuckle, NSwag та генерація клієнтів","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-documentation-generation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F10.api-documentation-generation",{"title":1335,"path":1336,"stem":1337},"Health Checks та моніторинг API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhealth-checks-monitoring","01.csharp\u002F11.aspnet\u002F12.web-api\u002F11.health-checks-monitoring",{"title":1339,"path":1340,"stem":1341},"Підсумковий проєкт - Production-Ready REST API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fweb-api-project","01.csharp\u002F11.aspnet\u002F12.web-api\u002F12.web-api-project",{"title":1343,"path":1344,"stem":1345},"План курсу: ASP.NET Core Web API (Controllers)","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fplan","01.csharp\u002F11.aspnet\u002F12.web-api\u002Fplan",{"title":1347,"icon":1348,"path":1349,"stem":1350,"children":1351,"page":59},"Моніторинг","i-lucide-activity","\u002Fcsharp\u002Faspnet\u002Fmonitoring","01.csharp\u002F11.aspnet\u002F13.monitoring",[1352,1356,1360],{"title":1353,"path":1354,"stem":1355},"Спостережуваність: від console.log до production-систем","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fobservability-intro","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F01.observability-intro",{"title":1357,"path":1358,"stem":1359},"Health Checks: перший рівень observability","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F02.health-checks",{"title":1361,"path":1362,"stem":1363},"Вбудовані метрики .NET 10 та System.Diagnostics.Metrics","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fdotnet-metrics","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F03.dotnet-metrics",{"title":1365,"icon":1366,"path":1367,"stem":1368,"children":1369,"page":59},"Desktop UI","i-lucide-app-window","\u002Fcsharp\u002Fdesktop-ui","01.csharp\u002F12.desktop-ui",[1370,1374,1378,1382,1386,1390,1394,1398,1402,1406,1410,1414,1418,1422,1426,1430,1434,1438,1442,1446,1450,1454,1458,1462,1466,1470,1474,1478,1482,1486,1490,1494,1498,1502,1506,1510,1514,1518,1522,1526,1530,1534,1538,1542,1546,1550,1554,1558,1562,1566,1570,1574,1578,1582,1586,1590,1594,1598,1602,1606,1610,1614,1618,1622,1626,1630,1634,1638,1642,1646,1650],{"title":1371,"path":1372,"stem":1373},"Що таке десктопна розробка?","\u002Fcsharp\u002Fdesktop-ui\u002Fwhat-is-desktop-dev","01.csharp\u002F12.desktop-ui\u002F01.what-is-desktop-dev",{"title":1375,"path":1376,"stem":1377},"Архітектура WPF — як влаштований графічний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-architecture","01.csharp\u002F12.desktop-ui\u002F02.wpf-architecture",{"title":1379,"path":1380,"stem":1381},"Перший WPF-проєкт — від нуля до вікна","\u002Fcsharp\u002Fdesktop-ui\u002Ffirst-wpf-app","01.csharp\u002F12.desktop-ui\u002F03.first-wpf-app",{"title":1383,"path":1384,"stem":1385},"Перший Avalonia-проєкт: WPF для всіх платформ","\u002Fcsharp\u002Fdesktop-ui\u002F03a.first-avalonia-app","01.csharp\u002F12.desktop-ui\u002F03a.first-avalonia-app",{"title":1387,"path":1388,"stem":1389},"XAML: декларативний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-basics","01.csharp\u002F12.desktop-ui\u002F04.xaml-basics",{"title":1391,"path":1392,"stem":1393},"Fluent UI у WPF — сучасний дизайн Windows 11","\u002Fcsharp\u002Fdesktop-ui\u002F04a.wpf-fluent-ui","01.csharp\u002F12.desktop-ui\u002F04a.wpf-fluent-ui",{"title":1395,"path":1396,"stem":1397},"WPF UI — сучасна бібліотека Fluent контролів","\u002Fcsharp\u002Fdesktop-ui\u002F04b.wpf-ui-library","01.csharp\u002F12.desktop-ui\u002F04b.wpf-ui-library",{"title":1399,"path":1400,"stem":1401},"HandyControl — велика бібліотека UI контролів для WPF","\u002Fcsharp\u002Fdesktop-ui\u002F04c.handycontrol-library","01.csharp\u002F12.desktop-ui\u002F04c.handycontrol-library",{"title":1403,"path":1404,"stem":1405},"Простори імен та ресурси XAML","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-namespaces-resources","01.csharp\u002F12.desktop-ui\u002F05.xaml-namespaces-resources",{"title":1407,"path":1408,"stem":1409},"XAML в Avalonia: ключові відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F05a.avalonia-xaml-differences","01.csharp\u002F12.desktop-ui\u002F05a.avalonia-xaml-differences",{"title":1411,"path":1412,"stem":1413},"Розширення розмітки XAML (Markup Extensions)","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-markup-extensions","01.csharp\u002F12.desktop-ui\u002F06.xaml-markup-extensions",{"title":1415,"path":1416,"stem":1417},"Панелі Layout: StackPanel, WrapPanel, DockPanel","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part1","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part1",{"title":1419,"path":1420,"stem":1421},"Grid, Canvas, UniformGrid","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part2","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part2",{"title":1423,"path":1424,"stem":1425},"Просунуті техніки Layout","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-advanced","01.csharp\u002F12.desktop-ui\u002F08.layout-advanced",{"title":1427,"path":1428,"stem":1429},"Адаптивний Layout та найкращі практики","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-responsive","01.csharp\u002F12.desktop-ui\u002F09.layout-responsive",{"title":1431,"path":1432,"stem":1433},"Layout в Avalonia: відмінності та нові можливості","\u002Fcsharp\u002Fdesktop-ui\u002F09a.layout-avalonia","01.csharp\u002F12.desktop-ui\u002F09a.layout-avalonia",{"title":1435,"path":1436,"stem":1437},"Button, Image, ProgressBar та інші базові контроли","\u002Fcsharp\u002Fdesktop-ui\u002Fbasic-controls","01.csharp\u002F12.desktop-ui\u002F10.basic-controls",{"title":1439,"path":1440,"stem":1441},"Контроли в Avalonia: відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F10a.controls-avalonia","01.csharp\u002F12.desktop-ui\u002F10a.controls-avalonia",{"title":1443,"path":1444,"stem":1445},"Текстові контроли — TextBlock, TextBox, RichTextBox","\u002Fcsharp\u002Fdesktop-ui\u002Ftext-controls","01.csharp\u002F12.desktop-ui\u002F11.text-controls",{"title":1447,"path":1448,"stem":1449},"Контроли вибору — CheckBox, RadioButton, ComboBox, ListBox, DatePicker","\u002Fcsharp\u002Fdesktop-ui\u002Fselection-controls","01.csharp\u002F12.desktop-ui\u002F12.selection-controls",{"title":1451,"path":1452,"stem":1453},"Content Model — GroupBox, Expander, TabControl, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fcontent-controls","01.csharp\u002F12.desktop-ui\u002F13.content-controls",{"title":1455,"path":1456,"stem":1457},"UI\u002FUX принципи десктопних застосунків","\u002Fcsharp\u002Fdesktop-ui\u002F13a.ui-ux-principles","01.csharp\u002F12.desktop-ui\u002F13a.ui-ux-principles",{"title":1459,"path":1460,"stem":1461},"Dependency Properties — Концепція та Value Resolution","\u002Fcsharp\u002Fdesktop-ui\u002Fdependency-properties-part1","01.csharp\u002F12.desktop-ui\u002F14.dependency-properties-part1",{"title":1463,"path":1464,"stem":1465},"Avalonia Property System — StyledProperty та DirectProperty","\u002Fcsharp\u002Fdesktop-ui\u002F14a.avalonia-property-system","01.csharp\u002F12.desktop-ui\u002F14a.avalonia-property-system",{"title":1467,"path":1468,"stem":1469},"Attached Properties — Властивості без меж","\u002Fcsharp\u002Fdesktop-ui\u002Fattached-properties","01.csharp\u002F12.desktop-ui\u002F15.attached-properties",{"title":1471,"path":1472,"stem":1473},"Routed Events — Маршрутизація подій у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Frouted-events","01.csharp\u002F12.desktop-ui\u002F16.routed-events",{"title":1475,"path":1476,"stem":1477},"Data Binding — Від Code-Behind до Декларативності","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part1","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part1",{"title":1479,"path":1480,"stem":1481},"INotifyPropertyChanged — Живе оновлення UI","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part2","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part2",{"title":1483,"path":1484,"stem":1485},"Compiled Bindings в Avalonia — Безпека на етапі компіляції","\u002Fcsharp\u002Fdesktop-ui\u002F17a.avalonia-compiled-bindings","01.csharp\u002F12.desktop-ui\u002F17a.avalonia-compiled-bindings",{"title":1487,"path":1488,"stem":1489},"Просунутий Data Binding — ElementName, RelativeSource, MultiBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-advanced","01.csharp\u002F12.desktop-ui\u002F18.data-binding-advanced",{"title":1491,"path":1492,"stem":1493},"Value Converters — Перетворення типів даних у Data Binding","\u002Fcsharp\u002Fdesktop-ui\u002Fvalue-converters","01.csharp\u002F12.desktop-ui\u002F19.value-converters",{"title":1495,"path":1496,"stem":1497},"Data Templates — Візуалізація об'єктів у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-templates","01.csharp\u002F12.desktop-ui\u002F20.data-templates",{"title":1499,"path":1500,"stem":1501},"Collections Binding Part 1 — ObservableCollection та ItemsControl","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part1","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part1",{"title":1503,"path":1504,"stem":1505},"Collections Binding Part 2 — ICollectionView, Filtering, Sorting та Virtualization","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part2","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part2",{"title":1507,"path":1508,"stem":1509},"MVVM Pattern — Від Spaghetti Code до архітектури","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-pattern","01.csharp\u002F12.desktop-ui\u002F22.mvvm-pattern",{"title":1511,"path":1512,"stem":1513},"ViewModel Implementation — Від BaseViewModel до валідації","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-implementation","01.csharp\u002F12.desktop-ui\u002F23.viewmodel-implementation",{"title":1515,"path":1516,"stem":1517},"Commands — Від event handlers до декларативних команд","\u002Fcsharp\u002Fdesktop-ui\u002Fcommands","01.csharp\u002F12.desktop-ui\u002F24.commands",{"title":1519,"path":1520,"stem":1521},"MVVM Toolkit — MVVM без boilerplate через Source Generators","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-toolkit","01.csharp\u002F12.desktop-ui\u002F25.mvvm-toolkit",{"title":1523,"path":1524,"stem":1525},"Messenger Pattern — Комунікація між ViewModel без прямих посилань","\u002Fcsharp\u002Fdesktop-ui\u002Fmessenger-pattern","01.csharp\u002F12.desktop-ui\u002F26.messenger-pattern",{"title":1527,"path":1528,"stem":1529},"Стилі WPF — CSS для десктопу","\u002Fcsharp\u002Fdesktop-ui\u002Fstyles-basics","01.csharp\u002F12.desktop-ui\u002F27.styles-basics",{"title":1531,"path":1532,"stem":1533},"CSS-like стилі Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F27a.avalonia-css-styling","01.csharp\u002F12.desktop-ui\u002F27a.avalonia-css-styling",{"title":1535,"path":1536,"stem":1537},"Control Templates — Частина 1. Концепція та TemplateBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part1","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part1",{"title":1539,"path":1540,"stem":1541},"Control Templates — Частина 2. Named Parts та ContentPresenter","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part2","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part2",{"title":1543,"path":1544,"stem":1545},"Control Themes в Avalonia — нова ера стилізації","\u002Fcsharp\u002Fdesktop-ui\u002F28a.avalonia-control-themes","01.csharp\u002F12.desktop-ui\u002F28a.avalonia-control-themes",{"title":1547,"path":1548,"stem":1549},"Triggers та Visual State Manager у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Ftriggers-visual-states","01.csharp\u002F12.desktop-ui\u002F29.triggers-visual-states",{"title":1551,"path":1552,"stem":1553},"Pseudo-classes в Avalonia — замість WPF Triggers","\u002Fcsharp\u002Fdesktop-ui\u002F29a.avalonia-pseudo-classes","01.csharp\u002F12.desktop-ui\u002F29a.avalonia-pseudo-classes",{"title":1555,"path":1556,"stem":1557},"Теми та ресурсні словники у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fresources-themes","01.csharp\u002F12.desktop-ui\u002F30.resources-themes",{"title":1559,"path":1560,"stem":1561},"Avalonia Themes — Fluent Design та система тематизації","\u002Fcsharp\u002Fdesktop-ui\u002F30a.avalonia-themes-fluent","01.csharp\u002F12.desktop-ui\u002F30a.avalonia-themes-fluent",{"title":1563,"path":1564,"stem":1565},"Контроли колекцій — глибоке занурення","\u002Fcsharp\u002Fdesktop-ui\u002Fcollection-controls","01.csharp\u002F12.desktop-ui\u002F31.collection-controls",{"title":1567,"path":1568,"stem":1569},"DataGrid — колонки та базове відображення","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part1","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part1",{"title":1571,"path":1572,"stem":1573},"DataGrid — сортування, фільтрація, редагування","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part2","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part2",{"title":1575,"path":1576,"stem":1577},"TreeView та GridView","\u002Fcsharp\u002Fdesktop-ui\u002Ftreeview-listview","01.csharp\u002F12.desktop-ui\u002F33.treeview-listview",{"title":1579,"path":1580,"stem":1581},"Меню, Toolbar, ContextMenu, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fmenus-toolbars","01.csharp\u002F12.desktop-ui\u002F34.menus-toolbars",{"title":1583,"path":1584,"stem":1585},"Навігація та керування вікнами. Частина 1: вікна та сторінки","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part1","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part1",{"title":1587,"path":1588,"stem":1589},"Навігація та керування вікнами. Частина 2: MVVM-навігація","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part2","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part2",{"title":1591,"path":1592,"stem":1593},"Avalonia — Навігація та діалоги","\u002Fcsharp\u002Fdesktop-ui\u002F35a.avalonia-navigation-dialogs","01.csharp\u002F12.desktop-ui\u002F35a.avalonia-navigation-dialogs",{"title":1595,"path":1596,"stem":1597},"Діалоги та File Pickers у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdialogs-file-pickers","01.csharp\u002F12.desktop-ui\u002F36.dialogs-file-pickers",{"title":1599,"path":1600,"stem":1601},"UserControl: компонентний підхід у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fuser-controls","01.csharp\u002F12.desktop-ui\u002F37.user-controls",{"title":1603,"path":1604,"stem":1605},"Custom Controls: Lookless Controls у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fcustom-controls","01.csharp\u002F12.desktop-ui\u002F38.custom-controls",{"title":1607,"path":1608,"stem":1609},"Avalonia TemplatedControl — Lookless Controls","\u002Fcsharp\u002Fdesktop-ui\u002F38a.avalonia-templated-controls","01.csharp\u002F12.desktop-ui\u002F38a.avalonia-templated-controls",{"title":1611,"path":1612,"stem":1613},"Анімації у WPF: Storyboard та Easing Functions","\u002Fcsharp\u002Fdesktop-ui\u002Fanimations-transitions","01.csharp\u002F12.desktop-ui\u002F39.animations-transitions",{"title":1615,"path":1616,"stem":1617},"Анімації в Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F39a.avalonia-animations","01.csharp\u002F12.desktop-ui\u002F39a.avalonia-animations",{"title":1619,"path":1620,"stem":1621},"2D Графіка та Мультимедіа у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fmedia-graphics","01.csharp\u002F12.desktop-ui\u002F40.media-graphics",{"title":1623,"path":1624,"stem":1625},"Dependency Injection у WPF та Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Fdi-integration","01.csharp\u002F12.desktop-ui\u002F41.di-integration",{"title":1627,"path":1628,"stem":1629},"SQLite та EF Core у десктопних додатках","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part1","01.csharp\u002F12.desktop-ui\u002F42.data-persistence-part1",{"title":1631,"path":1632,"stem":1633},"Repository Pattern та Unit of Work","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part2","01.csharp\u002F12.desktop-ui\u002F43.data-persistence-part2",{"title":1635,"path":1636,"stem":1637},"Тестування ViewModels","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-testing","01.csharp\u002F12.desktop-ui\u002F44.viewmodel-testing",{"title":1639,"path":1640,"stem":1641},"Avalonia Headless Testing — тестування UI без вікон","\u002Fcsharp\u002Fdesktop-ui\u002F44a.avalonia-headless-testing","01.csharp\u002F12.desktop-ui\u002F44a.avalonia-headless-testing",{"title":1643,"path":1644,"stem":1645},"Кросплатформна розробка з Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-cross-platform","01.csharp\u002F12.desktop-ui\u002F45.avalonia-cross-platform",{"title":1647,"path":1648,"stem":1649},"Пакування та розгортання Avalonia додатків","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F46.avalonia-packaging-deployment",{"title":1651,"path":1652,"stem":1653},"Розгортання WPF застосунків","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F47.wpf-packaging-deployment",{"title":1655,"icon":658,"path":1656,"stem":1657,"children":1658,"page":59},"Network Programming","\u002Fcsharp\u002Fnetwork-programming","01.csharp\u002F13.network-programming",[1659,1663,1667,1671,1675,1679,1683,1687,1691,1695,1699],{"title":1660,"path":1661,"stem":1662},"Основи комп'ютерних мереж","\u002Fcsharp\u002Fnetwork-programming\u002Ffoundations","01.csharp\u002F13.network-programming\u002F01.foundations",{"title":1664,"path":1665,"stem":1666},"Модель OSI та стек TCP\u002FIP","\u002Fcsharp\u002Fnetwork-programming\u002Fosi-model","01.csharp\u002F13.network-programming\u002F02.osi-model",{"title":1668,"path":1669,"stem":1670},"IP-протокол та адресація","\u002Fcsharp\u002Fnetwork-programming\u002Fip-addressing","01.csharp\u002F13.network-programming\u002F03.ip-addressing",{"title":1672,"path":1673,"stem":1674},"UDP — протокол без з'єднання","\u002Fcsharp\u002Fnetwork-programming\u002Fudp","01.csharp\u002F13.network-programming\u002F05.udp",{"title":1676,"path":1677,"stem":1678},"UDP Broadcast та Multicast","\u002Fcsharp\u002Fnetwork-programming\u002Fudp-broadcast-multicast","01.csharp\u002F13.network-programming\u002F06.udp-broadcast-multicast",{"title":1680,"path":1681,"stem":1682},"HTTP — протокол вебу","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-fundamentals","01.csharp\u002F13.network-programming\u002F07.http-fundamentals",{"title":1684,"path":1685,"stem":1686},"HttpListener — вбудований HTTP-сервер .NET","\u002Fcsharp\u002Fnetwork-programming\u002F07a.http-listener","01.csharp\u002F13.network-programming\u002F07a.http-listener",{"title":1688,"path":1689,"stem":1690},"HTTP Advanced — cookies, аутентифікація та HTTPS","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-advanced","01.csharp\u002F13.network-programming\u002F08.http-advanced",{"title":1692,"path":1693,"stem":1694},"SMTP та протоколи електронної пошти","\u002Fcsharp\u002Fnetwork-programming\u002Fsmtp","01.csharp\u002F13.network-programming\u002F09.smtp",{"title":1696,"path":1697,"stem":1698},"WebSocket — повнодуплексний протокол реального часу","\u002Fcsharp\u002Fnetwork-programming\u002Fwebsockets","01.csharp\u002F13.network-programming\u002F10.websockets",{"title":1700,"path":1701,"stem":1702},"TLS\u002FSSL — криптографічний захист мережевих з'єднань","\u002Fcsharp\u002Fnetwork-programming\u002Ftls-ssl","01.csharp\u002F13.network-programming\u002F11.tls-ssl",{"title":1704,"path":1705,"stem":1706},"C# & .NET: The Ultimate Roadmap","\u002Fcsharp\u002Froadmap","01.csharp\u002Froadmap",{"title":1708,"icon":1709,"path":1710,"stem":1711,"children":1712,"page":59},"C++","i-devicon-cplusplus","\u002Fcpp","02.cpp",[1713,1717,1721,1725,1729,1733,1737,1741,1745,1748,1752,1756,1760,1764,1768,1772,1776,1780,1784,1788,1792,1796,1800,1804,1808,1812,1816,1820,1824,1828,1832,1836,1840,1844,1848,1852,1856,1860,1864,1868,1872,1876,1880,1884,1888,1892],{"title":1714,"path":1715,"stem":1716},"Вступ у програмування та алгоритми","\u002Fcpp\u002Fintro-algorithms","02.cpp\u002F01.intro-algorithms",{"title":1718,"path":1719,"stem":1720},"Code Style: угоди про оформлення коду","\u002Fcpp\u002Fcode-style","02.cpp\u002F02.code-style",{"title":1722,"path":1723,"stem":1724},"Середовище розробки та перший проєкт","\u002Fcpp\u002Fide-setup","02.cpp\u002F03.ide-setup",{"title":1726,"path":1727,"stem":1728},"Вивід даних на екран","\u002Fcpp\u002Fdata-output","02.cpp\u002F04.data-output",{"title":1730,"path":1731,"stem":1732},"Типи даних, змінні та константи","\u002Fcpp\u002Fdata-types-variables","02.cpp\u002F05.data-types-variables",{"title":1734,"path":1735,"stem":1736},"Ввід даних з клавіатури","\u002Fcpp\u002Fdata-input","02.cpp\u002F06.data-input",{"title":1738,"path":1739,"stem":1740},"Оператори, перетворення типів та логічні операції","\u002Fcpp\u002Foperators-type-conversion","02.cpp\u002F07.operators-type-conversion",{"title":1742,"path":1743,"stem":1744},"Цикли","\u002Fcpp\u002Floops","02.cpp\u002F08.loops",{"title":32,"path":1746,"stem":1747},"\u002Fcpp\u002Farrays","02.cpp\u002F09.arrays",{"title":1749,"path":1750,"stem":1751},"Алгоритми сортування та аналіз складності","\u002Fcpp\u002Fsorting","02.cpp\u002F10.sorting",{"title":1753,"path":1754,"stem":1755},"Алгоритми пошуку","\u002Fcpp\u002Fsearching","02.cpp\u002F11.searching",{"title":1757,"path":1758,"stem":1759},"Функції: основи","\u002Fcpp\u002Ffunctions-basics","02.cpp\u002F12.functions-basics",{"title":1761,"path":1762,"stem":1763},"Функції: прототипи, область видимості та додаткові можливості","\u002Fcpp\u002Ffunctions-scope","02.cpp\u002F13.functions-scope",{"title":1765,"path":1766,"stem":1767},"Функції: перевантаження та шаблони","\u002Fcpp\u002Ffunctions-overloading-templates","02.cpp\u002F14.functions-overloading-templates",{"title":1769,"path":1770,"stem":1771},"Вказівники: основи","\u002Fcpp\u002Fpointers-basics","02.cpp\u002F15.pointers-basics",{"title":1773,"path":1774,"stem":1775},"Посилання (References)","\u002Fcpp\u002Freferences","02.cpp\u002F16.references",{"title":1777,"path":1778,"stem":1779},"Вказівники, const і масиви","\u002Fcpp\u002Fpointers-const-arrays","02.cpp\u002F17.pointers-const-arrays",{"title":1781,"path":1782,"stem":1783},"Адресна арифметика","\u002Fcpp\u002Fpointer-arithmetic","02.cpp\u002F18.pointer-arithmetic",{"title":1785,"path":1786,"stem":1787},"Динамічна пам'ять","\u002Fcpp\u002Fdynamic-memory","02.cpp\u002F19.dynamic-memory",{"title":1789,"path":1790,"stem":1791},"Вказівники типу void","\u002Fcpp\u002Fvoid-pointers","02.cpp\u002F20.void-pointers",{"title":1793,"path":1794,"stem":1795},"Вказівники на вказівники","\u002Fcpp\u002Fpointers-to-pointers","02.cpp\u002F21.pointers-to-pointers",{"title":1797,"path":1798,"stem":1799},"Оператор доступу до членів через вказівник (->)","\u002Fcpp\u002Fmember-access-operator","02.cpp\u002F22.member-access-operator",{"title":1801,"path":1802,"stem":1803},"Цикл for-each (Range-based for)","\u002Fcpp\u002Fforeach-loop","02.cpp\u002F23.foreach-loop",{"title":1805,"path":1806,"stem":1807},"Вказівники на функції","\u002Fcpp\u002Ffunction-pointers","02.cpp\u002F24.function-pointers",{"title":1809,"path":1810,"stem":1811},"Лямбда-вирази","\u002Fcpp\u002Flambdas","02.cpp\u002F25.lambdas",{"title":1813,"path":1814,"stem":1815},"Лямбда-захоплення","\u002Fcpp\u002Flambda-captures","02.cpp\u002F26.lambda-captures",{"title":1817,"path":1818,"stem":1819},"Еліпсис","\u002Fcpp\u002Fellipsis","02.cpp\u002F27.ellipsis",{"title":1821,"path":1822,"stem":1823},"Безпечні альтернативи еліпсису","\u002Fcpp\u002F27a.ellipsis","02.cpp\u002F27a.ellipsis",{"title":1825,"path":1826,"stem":1827},"Аргументи командного рядка","\u002Fcpp\u002Fcommand-line-arguments","02.cpp\u002F28.command-line-arguments",{"title":1829,"path":1830,"stem":1831},"Перерахування (enum)","\u002Fcpp\u002Fenum","02.cpp\u002F29.enum",{"title":1833,"path":1834,"stem":1835},"Класи-перерахування (enum class)","\u002Fcpp\u002Fenum-class","02.cpp\u002F30.enum-class",{"title":1837,"path":1838,"stem":1839},"Псевдоніми типів (typedef і using)","\u002Fcpp\u002Ftype-aliases","02.cpp\u002F31.type-aliases",{"title":1841,"path":1842,"stem":1843},"Системи числення та двійкова арифметика","\u002Fcpp\u002Fnumber-systems","02.cpp\u002F32.number-systems",{"title":1845,"path":1846,"stem":1847},"Структури (struct): агрегування даних","\u002Fcpp\u002Fstruct","02.cpp\u002F33.struct",{"title":1849,"path":1850,"stem":1851},"Структури у функціях","\u002Fcpp\u002Fstruct-functions","02.cpp\u002F34.struct-functions",{"title":1853,"path":1854,"stem":1855},"Масиви структур і вкладені структури","\u002Fcpp\u002Fstruct-arrays","02.cpp\u002F35.struct-arrays",{"title":1857,"path":1858,"stem":1859},"Патерни struct та межі застосування","\u002Fcpp\u002Fstruct-patterns","02.cpp\u002F36.struct-patterns",{"title":1861,"path":1862,"stem":1863},"Символи та таблиця ASCII","\u002Fcpp\u002Fascii-characters","02.cpp\u002F37.ascii-characters",{"title":1865,"path":1866,"stem":1867},"Unicode та кодування UTF","\u002Fcpp\u002Funicode-utf","02.cpp\u002F38.unicode-utf",{"title":1869,"path":1870,"stem":1871},"C-style рядки","\u002Fcpp\u002Fc-strings","02.cpp\u002F39.c-strings",{"title":1873,"path":1874,"stem":1875},"Вступ до std::string","\u002Fcpp\u002Fstd-string-intro","02.cpp\u002F40.std-string-intro",{"title":1877,"path":1878,"stem":1879},"Довжина, ємність та доступ до символів std::string","\u002Fcpp\u002Fstd-string-capacity-access","02.cpp\u002F41.std-string-capacity-access",{"title":1881,"path":1882,"stem":1883},"Модифікація std::string: присвоювання, додавання, вставка, видалення та заміна","\u002Fcpp\u002Fstd-string-modification","02.cpp\u002F42.std-string-modification",{"title":1885,"path":1886,"stem":1887},"Пошук у std::string: find, npos та практичні патерни","\u002Fcpp\u002Fstd-string-search","02.cpp\u002F43.std-string-search",{"title":1889,"path":1890,"stem":1891},"std::string_view: невласницький погляд на рядок без копіювання","\u002Fcpp\u002Fstd-string-view","02.cpp\u002F44.std-string-view",{"title":1893,"path":1894,"stem":1895},"План навчання: Курс C++ — Продовження (Статті 29–60+)","\u002Fcpp\u002Fcurriculum-plan","02.cpp\u002Fcurriculum-plan",{"title":1897,"icon":1898,"path":1899,"stem":1900,"children":1901,"page":59},"JavaScript","i-devicon-javascript","\u002Fjavascript","03.javascript",[1902,1928,1982,2004,2308,2346],{"title":1903,"icon":1904,"path":1905,"stem":1906,"children":1907,"page":59},"Events","i-lucide-mouse-pointer-click","\u002Fjavascript\u002Fevents","03.javascript\u002F01.events",[1908,1912,1916,1920,1924],{"title":1909,"path":1910,"stem":1911},"Вступ до подій браузера","\u002Fjavascript\u002Fevents\u002Fintro","03.javascript\u002F01.events\u002F01.intro",{"title":1913,"path":1914,"stem":1915},"Бульбашковий механізм (Bubbling) та занурення (Capturing)","\u002Fjavascript\u002Fevents\u002Fbubbling-capturing","03.javascript\u002F01.events\u002F02.bubbling-capturing",{"title":1917,"path":1918,"stem":1919},"Делегування подій (Event Delegation)","\u002Fjavascript\u002Fevents\u002Fdelegate-events","03.javascript\u002F01.events\u002F03.delegate-events",{"title":1921,"path":1922,"stem":1923},"Типові дії браузера та preventDefault()","\u002Fjavascript\u002Fevents\u002Fprevent-default","03.javascript\u002F01.events\u002F04.prevent-default",{"title":1925,"path":1926,"stem":1927},"Запуск користувацьких подій (Custom Events)","\u002Fjavascript\u002Fevents\u002Fcustom-events","03.javascript\u002F01.events\u002F05.custom-events",{"title":1929,"icon":1930,"path":1931,"stem":1932,"children":1933,"page":59},"Network","i-lucide-globe","\u002Fjavascript\u002Fnetwork","03.javascript\u002F02.network",[1934,1938,1942,1946,1950,1954,1958,1962,1966,1970,1974,1978],{"title":1935,"path":1936,"stem":1937},"Fetch API - Сучасний підхід до HTTP-запитів","\u002Fjavascript\u002Fnetwork\u002F01-fetch-api","03.javascript\u002F02.network\u002F01-fetch-api",{"title":1939,"path":1940,"stem":1941},"FormData - Робота з формами та файлами","\u002Fjavascript\u002Fnetwork\u002F02-formdata","03.javascript\u002F02.network\u002F02-formdata",{"title":1943,"path":1944,"stem":1945},"Відстеження прогресу завантаження","\u002Fjavascript\u002Fnetwork\u002F03-download-progress","03.javascript\u002F02.network\u002F03-download-progress",{"title":1947,"path":1948,"stem":1949},"Переривання fetch-запитів","\u002Fjavascript\u002Fnetwork\u002F04-abort-requests","03.javascript\u002F02.network\u002F04-abort-requests",{"title":1951,"path":1952,"stem":1953},"CORS - Запити між різними джерелами","\u002Fjavascript\u002Fnetwork\u002F05-cors","03.javascript\u002F02.network\u002F05-cors",{"title":1955,"path":1956,"stem":1957},"Fetch API - Повний довідник опцій","\u002Fjavascript\u002Fnetwork\u002F06-fetch-options","03.javascript\u002F02.network\u002F06-fetch-options",{"title":1959,"path":1960,"stem":1961},"URL Objects - Робота з посиланнями","\u002Fjavascript\u002Fnetwork\u002F07-url-objects","03.javascript\u002F02.network\u002F07-url-objects",{"title":1963,"path":1964,"stem":1965},"XMLHttpRequest - AJAX та низькорівневі запити","\u002Fjavascript\u002Fnetwork\u002F08-xmlhttprequest","03.javascript\u002F02.network\u002F08-xmlhttprequest",{"title":1967,"path":1968,"stem":1969},"Відновлюване завантаження файлів","\u002Fjavascript\u002Fnetwork\u002F09-resumable-upload","03.javascript\u002F02.network\u002F09-resumable-upload",{"title":1971,"path":1972,"stem":1973},"Cookies, document.cookie та світ після \"Cookiepocalypse\"","\u002Fjavascript\u002Fnetwork\u002F10-cookies","03.javascript\u002F02.network\u002F10-cookies",{"title":1975,"path":1976,"stem":1977},"js-cookie: Керування Cookies без Болю","\u002Fjavascript\u002Fnetwork\u002F11-js-cookie","03.javascript\u002F02.network\u002F11-js-cookie",{"title":1979,"path":1980,"stem":1981},"Axios: Потужний HTTP-клієнт для JavaScript","\u002Fjavascript\u002Fnetwork\u002F12-axios","03.javascript\u002F02.network\u002F12-axios",{"title":1983,"icon":1984,"path":1985,"stem":1986,"children":1987,"page":59},"Bom","i-lucide-monitor","\u002Fjavascript\u002Fbom","03.javascript\u002F03.bom",[1988,1992,1996,2000],{"title":1989,"path":1990,"stem":1991},"LocalStorage, SessionStorage та patterns збереження даних","\u002Fjavascript\u002Fbom\u002F01-localstorage","03.javascript\u002F03.bom\u002F01-localstorage",{"title":1993,"path":1994,"stem":1995},"Location Object - Керування адресою сторінки","\u002Fjavascript\u002Fbom\u002F02-location-object","03.javascript\u002F03.bom\u002F02-location-object",{"title":1997,"path":1998,"stem":1999},"History API - Керування історією браузера","\u002Fjavascript\u002Fbom\u002F03-history-api","03.javascript\u002F03.bom\u002F03-history-api",{"title":2001,"path":2002,"stem":2003},"Navigator Object - Ідентифікація та Можливості Пристрою","\u002Fjavascript\u002Fbom\u002F04-navigator-object","03.javascript\u002F03.bom\u002F04-navigator-object",{"title":2005,"icon":2006,"path":2007,"stem":2008,"children":2009},"React","i-devicon-react","\u002Fjavascript\u002Freact","03.javascript\u002F04.react\u002Findex",[2010,2011,2015,2019,2023,2027,2090,2125,2277],{"title":2005,"path":2007,"stem":2008},{"title":2012,"path":2013,"stem":2014},"Робота з Формами в React","\u002Fjavascript\u002Freact\u002Freact-forms","03.javascript\u002F04.react\u002F01.react-forms",{"title":2016,"path":2017,"stem":2018},"React Hook Form: Професійна Робота з Формами","\u002Fjavascript\u002Freact\u002Freact-hook-form","03.javascript\u002F04.react\u002F02.react-hook-form",{"title":2020,"path":2021,"stem":2022},"React Hook Form: Глибоке Розуміння Архітектури та Оптимізації","\u002Fjavascript\u002Freact\u002Freact-hook-form-new","03.javascript\u002F04.react\u002F02.react-hook-form-new",{"title":2024,"path":2025,"stem":2026},"Axios та React: Професійна Архітектура Запитів","\u002Fjavascript\u002Freact\u002Fdata-fetching-axios","03.javascript\u002F04.react\u002F03.data-fetching-axios",{"title":2028,"icon":132,"path":2029,"stem":2030,"children":2031},"Tanstack Query","\u002Fjavascript\u002Freact\u002Ftanstack-query","03.javascript\u002F04.react\u002F04.tanstack-query\u002Findex",[2032,2034,2038,2042,2046,2050,2054,2058,2062,2066,2070,2074,2078,2082,2086],{"title":2033,"path":2029,"stem":2030},"TanStack Query: Майстерність Керування Станом Сервера",{"title":2035,"path":2036,"stem":2037},"Парадигма Server State: Чому useEffect недостатньо","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-state-paradigm","03.javascript\u002F04.react\u002F04.tanstack-query\u002F01.server-state-paradigm",{"title":2039,"path":2040,"stem":2041},"Встановлення та Налаштування: Фундамент","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Finstallation-and-devtools","03.javascript\u002F04.react\u002F04.tanstack-query\u002F02.installation-and-devtools",{"title":2043,"path":2044,"stem":2045},"Основи Запитів та Магія Ключів","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fquery-basics-and-keys","03.javascript\u002F04.react\u002F04.tanstack-query\u002F03.query-basics-and-keys",{"title":2047,"path":2048,"stem":2049},"Синхронізація Даних: Життєвий Цикл Запиту","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fdata-synchronization","03.javascript\u002F04.react\u002F04.tanstack-query\u002F04.data-synchronization",{"title":2051,"path":2052,"stem":2053},"Мутації та Інвалідація: Зміна Даних","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fmutations-and-invalidation","03.javascript\u002F04.react\u002F04.tanstack-query\u002F05.mutations-and-invalidation",{"title":2055,"path":2056,"stem":2057},"Оптимістичні Оновлення: Швидше за Світло","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Foptimistic-updates","03.javascript\u002F04.react\u002F04.tanstack-query\u002F06.optimistic-updates",{"title":2059,"path":2060,"stem":2061},"Пагінація та Infinite Scroll","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fpagination-and-load-more","03.javascript\u002F04.react\u002F04.tanstack-query\u002F07.pagination-and-load-more",{"title":2063,"path":2064,"stem":2065},"Просунуті Патерни та Оптимізація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F04.tanstack-query\u002F08.advanced-patterns",{"title":2067,"path":2068,"stem":2069},"Архітектура та Best Practices","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Farchitecture-and-best-practices","03.javascript\u002F04.react\u002F04.tanstack-query\u002F09.architecture-and-best-practices",{"title":2071,"path":2072,"stem":2073},"Server-Side Rendering (SSR) та Гідратація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-side-rendering","03.javascript\u002F04.react\u002F04.tanstack-query\u002F10.server-side-rendering",{"title":2075,"path":2076,"stem":2077},"Стратегії Тестування","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Ftesting-strategies","03.javascript\u002F04.react\u002F04.tanstack-query\u002F11.testing-strategies",{"title":2079,"path":2080,"stem":2081},"Аутентифікація та Обробка Помилок","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fauthentication-and-errors","03.javascript\u002F04.react\u002F04.tanstack-query\u002F12.authentication-and-errors",{"title":2083,"path":2084,"stem":2085},"React Suspense та Майбутнє","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Freact-suspense","03.javascript\u002F04.react\u002F04.tanstack-query\u002F13.react-suspense",{"title":2087,"path":2088,"stem":2089},"Глибоке Занурення в Продуктивність","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fperformance-deep-dive","03.javascript\u002F04.react\u002F04.tanstack-query\u002F14.performance-deep-dive",{"title":2091,"icon":2006,"path":2092,"stem":2093,"children":2094},"React Router","\u002Fjavascript\u002Freact\u002Freact-router","03.javascript\u002F04.react\u002F05.react-router\u002Findex",[2095,2097,2101,2105,2109,2113,2117,2121],{"title":2096,"path":2092,"stem":2093},"React Router: Навігаційна система сучасного вебу",{"title":2098,"path":2099,"stem":2100},"Налаштування та Базовий Роутинг","\u002Fjavascript\u002Freact\u002Freact-router\u002Fsetup-and-basic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F01.setup-and-basic-routing",{"title":2102,"path":2103,"stem":2104},"Динамічна Навігація","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnavigation-and-links","03.javascript\u002F04.react\u002F05.react-router\u002F02.navigation-and-links",{"title":2106,"path":2107,"stem":2108},"Вкладені Маршрути та Макети","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnested-routes-and-layouts","03.javascript\u002F04.react\u002F05.react-router\u002F03.nested-routes-and-layouts",{"title":2110,"path":2111,"stem":2112},"Динамічні Маршрути та Параметри","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdynamic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F04.dynamic-routing",{"title":2114,"path":2115,"stem":2116},"Data APIs: Loaders та Actions","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdata-loading","03.javascript\u002F04.react\u002F05.react-router\u002F05.data-loading",{"title":2118,"path":2119,"stem":2120},"Просунуті Патерни","\u002Fjavascript\u002Freact\u002Freact-router\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F05.react-router\u002F06.advanced-patterns",{"title":2122,"path":2123,"stem":2124},"Legacy Routing: Компонентний підхід","\u002Fjavascript\u002Freact\u002Freact-router\u002Flegacy-routing","03.javascript\u002F04.react\u002F05.react-router\u002F07.legacy-routing",{"title":2126,"icon":132,"path":2127,"stem":2128,"children":2129},"Redux","\u002Fjavascript\u002Freact\u002Fredux","03.javascript\u002F04.react\u002F06.redux\u002Findex",[2130,2132,2148,2177,2186,2207,2223,2252],{"title":2131,"path":2127,"stem":2128},"Redux: Еволюція управління станом",{"title":14,"icon":15,"path":2133,"stem":2134,"children":2135,"page":59},"\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals",[2136,2140,2144],{"title":2137,"path":2138,"stem":2139},"Вступ до State Management","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fintro-state-management","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F01.intro-state-management",{"title":2141,"path":2142,"stem":2143},"Філософія Redux та Три Принципи","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fredux-philosophy","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F02.redux-philosophy",{"title":2145,"path":2146,"stem":2147},"Чисті функції та Іммутабельність","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fpure-functions-immutability","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F03.pure-functions-immutability",{"title":2149,"icon":132,"path":2150,"stem":2151,"children":2152,"page":59},"Classic Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux",[2153,2157,2161,2165,2169,2173],{"title":2154,"path":2155,"stem":2156},"Створення Store (Classic Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fstore-setup","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F01.store-setup",{"title":2158,"path":2159,"stem":2160},"Actions, Constants та Action Creators","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Factions-constants","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F02.actions-constants",{"title":2162,"path":2163,"stem":2164},"Логіка Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freducers","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F03.reducers",{"title":2166,"path":2167,"stem":2168},"Комбінування Reducers (Root Reducer)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fdata-flow","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F04.data-flow",{"title":2170,"path":2171,"stem":2172},"Підключення до React (React-Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freact-redux-connection","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F05.react-redux-connection",{"title":2174,"path":2175,"stem":2176},"Middleware та Асинхронність (Redux Thunk)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fmiddleware-thunk","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F06.middleware-thunk",{"title":2178,"icon":132,"path":2179,"stem":2180,"children":2181,"page":59},"Transition To Rtk","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk",[2182],{"title":2183,"path":2184,"stem":2185},"Проблеми класичного Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk\u002Fproblems-with-classic","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk\u002F01.problems-with-classic",{"title":2187,"icon":132,"path":2188,"stem":2189,"children":2190,"page":59},"Redux Toolkit","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit",[2191,2195,2199,2203],{"title":2192,"path":2193,"stem":2194},"Налаштування Store з configureStore","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fconfigure-store","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F01.configure-store",{"title":2196,"path":2197,"stem":2198},"createSlice: Революція в Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fcreate-slice","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F02.create-slice",{"title":2200,"path":2201,"stem":2202},"Асинхронність з createAsyncThunk","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fasync-thunks","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F03.async-thunks",{"title":2204,"path":2205,"stem":2206},"04. Entity Adapter: Керування нормалізованим станом","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fentity-adapter","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F04.entity-adapter",{"title":2208,"icon":92,"path":2209,"stem":2210,"children":2211,"page":59},"Advanced","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced",[2212,2216,2220],{"title":2213,"path":2214,"stem":2215},"Мемоізація та Селектори: Повний Гайд по Reselect","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Fselectors-reselect","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F01.selectors-reselect",{"title":2217,"path":2218,"stem":2219},"RTK Query: Архітектура Серверного Кешу","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Frtk-query-intro","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F02.rtk-query-intro",{"title":2067,"path":2221,"stem":2222},"\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Farchitecture-best-practices","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F03.architecture-best-practices",{"title":2224,"icon":132,"path":2225,"stem":2226,"children":2227,"page":59},"Project Kanban","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban",[2228,2232,2236,2240,2244,2248],{"title":2229,"path":2230,"stem":2231},"Проєкт: Kanban Board (Trello Clone)","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fproject-overview","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F01.project-overview",{"title":2233,"path":2234,"stem":2235},"Налаштування та Типізація","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fsetup-and-types","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F02.setup-and-types",{"title":2237,"path":2238,"stem":2239},"Board Slice: Серце Дошки","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fboard-slice","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F03.board-slice",{"title":2241,"path":2242,"stem":2243},"Логіка Drag & Drop","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fdrag-and-drop-logic","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F04.drag-and-drop-logic",{"title":2245,"path":2246,"stem":2247},"Інтеграція з RTK Query","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Frtk-query-integration","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F05.rtk-query-integration",{"title":2249,"path":2250,"stem":2251},"Optimistic Updates","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Foptimistic-updates","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F06.optimistic-updates",{"title":2253,"icon":132,"path":2254,"stem":2255,"children":2256,"page":59},"Testing","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting","03.javascript\u002F04.react\u002F06.redux\u002F07.testing",[2257,2261,2265,2269,2273],{"title":2258,"path":2259,"stem":2260},"Тестування Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Fintro-testing","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F01.intro-testing",{"title":2262,"path":2263,"stem":2264},"Тестування Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-reducers","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F02.testing-reducers",{"title":2266,"path":2267,"stem":2268},"Тестування Селекторів","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-selectors","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F03.testing-selectors",{"title":2270,"path":2271,"stem":2272},"Тестування Компонентів (Integration)","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-components","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F04.testing-components",{"title":2274,"path":2275,"stem":2276},"Тестування Async Thunks","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-thunks","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F05.testing-thunks",{"title":2278,"icon":132,"path":2279,"stem":2280,"children":2281},"Ui Libraries","\u002Fjavascript\u002Freact\u002Fui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002Findex",[2282,2284,2288,2292,2296,2300,2304],{"title":2283,"path":2279,"stem":2280},"UI Бібліотеки в React",{"title":2285,"path":2286,"stem":2287},"Вступ до UI Бібліотек: Навіщо Винаходити Велосипед Двічі?","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fintroduction-to-ui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002F01.introduction-to-ui-libraries",{"title":2289,"path":2290,"stem":2291},"Філософія shadcn\u002Fui: \"Not a Component Library\"","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-philosophy","03.javascript\u002F04.react\u002F07.ui-libraries\u002F02.shadcn-philosophy",{"title":2293,"path":2294,"stem":2295},"Установка та Налаштування shadcn\u002Fui","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-installation","03.javascript\u002F04.react\u002F07.ui-libraries\u002F03.shadcn-installation",{"title":2297,"path":2298,"stem":2299},"Базові Компоненти shadcn\u002Fui: Фундамент Інтерфейсу","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-basics","03.javascript\u002F04.react\u002F07.ui-libraries\u002F04.shadcn-components-basics",{"title":2301,"path":2302,"stem":2303},"Компоненти Форм: Побудова Інтерактивних Form","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-forms","03.javascript\u002F04.react\u002F07.ui-libraries\u002F05.shadcn-components-forms",{"title":2305,"path":2306,"stem":2307},"Складні Компоненти: Dialog, Dropdown, Table та Command","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-advanced","03.javascript\u002F04.react\u002F07.ui-libraries\u002F06.shadcn-components-advanced",{"title":2309,"icon":2310,"path":2311,"stem":2312,"children":2313,"page":59},"TypeScript","i-devicon-typescript","\u002Fjavascript\u002Ftypescript","03.javascript\u002F05.typescript",[2314,2318,2322,2326,2330,2334,2338,2342],{"title":2315,"path":2316,"stem":2317},"TypeScript: Броня для вашого коду","\u002Fjavascript\u002Ftypescript\u002Fintro-and-basic-types","03.javascript\u002F05.typescript\u002F01.intro-and-basic-types",{"title":2319,"path":2320,"stem":2321},"Майстерність Моделювання Даних: Інтерфейси та Просунуті Типи","\u002Fjavascript\u002Ftypescript\u002Finterfaces-and-advanced-types","03.javascript\u002F05.typescript\u002F02.interfaces-and-advanced-types",{"title":2323,"path":2324,"stem":2325},"Алхімія Типів: Generics та Utility Types","\u002Fjavascript\u002Ftypescript\u002Fgenerics-and-utilities","03.javascript\u002F05.typescript\u002F03.generics-and-utilities",{"title":2327,"path":2328,"stem":2329},"Архітектура та Шаблони: Класи в TypeScript","\u002Fjavascript\u002Ftypescript\u002Fclasses-and-oop","03.javascript\u002F05.typescript\u002F04.classes-and-oop",{"title":2331,"path":2332,"stem":2333},"Продакшн та Екосистема: Advanced Config & Workflow","\u002Fjavascript\u002Ftypescript\u002Fadvanced-patterns-and-config","03.javascript\u002F05.typescript\u002F05.advanced-patterns-and-config",{"title":2335,"path":2336,"stem":2337},"TypeScript у світі React","\u002Fjavascript\u002Ftypescript\u002Freact-basics","03.javascript\u002F05.typescript\u002F06.react-basics",{"title":2339,"path":2340,"stem":2341},"React + TypeScript: Продвинуті патерни","\u002Fjavascript\u002Ftypescript\u002Freact-advanced","03.javascript\u002F05.typescript\u002F07.react-advanced",{"title":2343,"path":2344,"stem":2345},"React + TypeScript: Екосистема та бібліотеки","\u002Fjavascript\u002Ftypescript\u002Freact-ecosystem","03.javascript\u002F05.typescript\u002F08.react-ecosystem",{"title":2347,"path":2348,"stem":2349},"Atomic Design","\u002Fjavascript\u002Fatomic-design","03.javascript\u002F2.atomic-design",{"title":2351,"icon":2352,"path":2353,"stem":2354,"children":2355,"page":59},"Java","i-devicon-java","\u002Fjava","04.java",[2356,2359,2362,2366,2370,2374,2378],{"title":162,"path":2357,"stem":2358},"\u002Fjava\u002Fdata-mapper-part1","04.java\u002F01.data-mapper-part1",{"title":166,"path":2360,"stem":2361},"\u002Fjava\u002Fdata-mapper-part2","04.java\u002F02.data-mapper-part2",{"title":2363,"path":2364,"stem":2365},"Service Layer: Організація бізнес-логіки","\u002Fjava\u002Fservice-layer","04.java\u002F03.service-layer",{"title":2367,"path":2368,"stem":2369},"Rich Domain Model та State Pattern","\u002Fjava\u002Frich-domain-model","04.java\u002F04.rich-domain-model",{"title":2371,"path":2372,"stem":2373},"Патерни для складної бізнес-логіки","\u002Fjava\u002Fbusiness-logic-patterns","04.java\u002F05.business-logic-patterns",{"title":2375,"path":2376,"stem":2377},"Обробка помилок та валідація","\u002Fjava\u002Ferror-handling-validation","04.java\u002F06.error-handling-validation",{"title":2379,"path":2380,"stem":2381,"children":2382,"page":59},"Проектування баз даних","\u002Fjava\u002Fpr2","04.java\u002Fpr2",[2383,2387,2391,2395,2399,2403,2407,2411,2415,2419,2423,2427,2431,2435,2439,2443,2447,2451,2455,2459,2463,2467,2471,2475,2479,2483,2487,2491,2495,2499,2503,2507,2511,2515,2519,2523,2527],{"title":2384,"path":2385,"stem":2386},"Концептуальне моделювання: Мистецтво розуміння предметної області","\u002Fjava\u002Fpr2\u002Fconceptual-modeling","04.java\u002Fpr2\u002F01.conceptual-modeling",{"title":2388,"path":2389,"stem":2390},"Логічне моделювання: Від бізнес-ідей до структур даних","\u002Fjava\u002Fpr2\u002Flogical-modeling","04.java\u002Fpr2\u002F02.logical-modeling",{"title":2392,"path":2393,"stem":2394},"Нормалізація: Гігієна даних та боротьба з аномаліями","\u002Fjava\u002Fpr2\u002Fnormalization","04.java\u002Fpr2\u002F03.normalization",{"title":2396,"path":2397,"stem":2398},"Фізична схема: Від абстракції до DDL","\u002Fjava\u002Fpr2\u002Fphysical-schema","04.java\u002Fpr2\u002F04.physical-schema",{"title":2400,"path":2401,"stem":2402},"Архітектурна класифікація таблиць","\u002Fjava\u002Fpr2\u002Ftable-classification","04.java\u002Fpr2\u002F05.table-classification",{"title":2404,"path":2405,"stem":2406},"Database Migrations: Версіонування схеми з Flyway","\u002Fjava\u002Fpr2\u002Fdatabase-migrations","04.java\u002Fpr2\u002F06.database-migrations",{"title":2408,"path":2409,"stem":2410},"А що, якби це була не реляційна БД?","\u002Fjava\u002Fpr2\u002Fbeyond-relational","04.java\u002Fpr2\u002F07.beyond-relational",{"title":2412,"path":2413,"stem":2414},"Object-Relational Impedance Mismatch: Два світи, що не хочуть дружити","\u002Fjava\u002Fpr2\u002Fimpedance-mismatch","04.java\u002Fpr2\u002F09.impedance-mismatch",{"title":2416,"path":2417,"stem":2418},"JDBC: Перший контакт із базою даних","\u002Fjava\u002Fpr2\u002Fjdbc-fundamentals","04.java\u002Fpr2\u002F10.jdbc-fundamentals",{"title":2420,"path":2421,"stem":2422},"Якість коду: Spotless, SpotBugs та SonarQube","\u002Fjava\u002Fpr2\u002F10a.code-quality","04.java\u002Fpr2\u002F10a.code-quality",{"title":2424,"path":2425,"stem":2426},"Connection Pool: Патерн Object Pool для JDBC-з'єднань","\u002Fjava\u002Fpr2\u002Fconnection-pool","04.java\u002Fpr2\u002F11.connection-pool",{"title":2428,"path":2429,"stem":2430},"Row Data Gateway: Об'єкт як обгортка рядка таблиці","\u002Fjava\u002Fpr2\u002Frow-data-gateway","04.java\u002Fpr2\u002F12.row-data-gateway",{"title":2432,"path":2433,"stem":2434},"Table Data Gateway: Фасад таблиці як архітектурний відступ","\u002Fjava\u002Fpr2\u002Ftable-data-gateway","04.java\u002Fpr2\u002F13.table-data-gateway",{"title":2436,"path":2437,"stem":2438},"Repository + Data Mapper: Правильна шарова архітектура з JDBC","\u002Fjava\u002Fpr2\u002Frepository-data-mapper","04.java\u002Fpr2\u002F14.repository-data-mapper",{"title":2440,"path":2441,"stem":2442},"Identity Map: Кешування сутностей у рамках сесії","\u002Fjava\u002Fpr2\u002Fidentity-map","04.java\u002Fpr2\u002F15.identity-map",{"title":2444,"path":2445,"stem":2446},"Unit of Work: Відстеження змін і координація JDBC-транзакцій","\u002Fjava\u002Fpr2\u002Funit-of-work","04.java\u002Fpr2\u002F16.unit-of-work",{"title":2448,"path":2449,"stem":2450},"Strategy: Замінювані SQL-стратегії для підтримки різних СУБД","\u002Fjava\u002Fpr2\u002Fstrategy-sql","04.java\u002Fpr2\u002F17.strategy-sql",{"title":2452,"path":2453,"stem":2454},"Proxy: Lazy Loading для One-To-Many колекцій","\u002Fjava\u002Fpr2\u002Fproxy-lazy-loading","04.java\u002Fpr2\u002F18.proxy-lazy-loading",{"title":2456,"path":2457,"stem":2458},"Generic Repository через Java Reflection: анотації та динамічний SQL","\u002Fjava\u002Fpr2\u002Fgeneric-repository-reflection","04.java\u002Fpr2\u002F19.generic-repository-reflection",{"title":2460,"path":2461,"stem":2462},"Specification Pattern: Композиція бізнес-правил для складних запитів","\u002Fjava\u002Fpr2\u002Fspecification-pattern","04.java\u002Fpr2\u002F20.specification-pattern",{"title":2464,"path":2465,"stem":2466},"Розширені можливості Specification Pattern: підзапити, агрегації та гібридний підхід","\u002Fjava\u002Fpr2\u002F20a.advanced-specifications","04.java\u002Fpr2\u002F20a.advanced-specifications",{"title":2468,"path":2469,"stem":2470},"Асинхронність у JDBC: Від блокуючих викликів до CompletableFuture","\u002Fjava\u002Fpr2\u002Fasynchronous-jdbc","04.java\u002Fpr2\u002F21.asynchronous-jdbc",{"title":2472,"path":2473,"stem":2474},"Інтеграційне тестування JDBC-репозиторіїв: Embedded H2 та патерн AAA","\u002Fjava\u002Fpr2\u002Fintegration-testing-h2","04.java\u002Fpr2\u002F22.integration-testing-h2",{"title":2476,"path":2477,"stem":2478},"Testcontainers: Тестування з реальною PostgreSQL у Docker-контейнерах","\u002Fjava\u002Fpr2\u002Fintegration-testing-testcontainers","04.java\u002Fpr2\u002F23.integration-testing-testcontainers",{"title":2480,"path":2481,"stem":2482},"Google Guice: Впровадження залежностей у JavaFX-проєкті","\u002Fjava\u002Fpr2\u002Fdependency-injection-guice","04.java\u002Fpr2\u002F24.dependency-injection-guice",{"title":2484,"path":2485,"stem":2486},"JavaFX: Основи побудови графічних інтерфейсів","\u002Fjava\u002Fpr2\u002Fjavafx-fundamentals","04.java\u002Fpr2\u002F25.javafx-fundamentals",{"title":2488,"path":2489,"stem":2490},"Properties та Bindings: Реактивність у JavaFX","\u002Fjava\u002Fpr2\u002Fjavafx-properties-bindings","04.java\u002Fpr2\u002F26.javafx-properties-bindings",{"title":2492,"path":2493,"stem":2494},"MVC vs MVP vs MVVM: Еволюція архітектурних патернів UI","\u002Fjava\u002Fpr2\u002Fui-architecture-patterns","04.java\u002Fpr2\u002F27.ui-architecture-patterns",{"title":2496,"path":2497,"stem":2498},"MVVM на практиці: Побудова ViewModel","\u002Fjava\u002Fpr2\u002Fmvvm-viewmodel-implementation","04.java\u002Fpr2\u002F28.mvvm-viewmodel-implementation",{"title":2500,"path":2501,"stem":2502},"View та Controller: Зв'язування з ViewModel через FXML","\u002Fjava\u002Fpr2\u002Fmvvm-view-controller","04.java\u002Fpr2\u002F29.mvvm-view-controller",{"title":2504,"path":2505,"stem":2506},"Інтеграція MVVM з Guice: Автоматична ін'єкція залежностей","\u002Fjava\u002Fpr2\u002Fmvvm-guice-integration","04.java\u002Fpr2\u002F30.mvvm-guice-integration",{"title":2508,"path":2509,"stem":2510},"Валідація та обробка помилок у MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-validation-error-handling","04.java\u002Fpr2\u002F31.mvvm-validation-error-handling",{"title":2512,"path":2513,"stem":2514},"Навігація та управління екранами у JavaFX MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-navigation-screen-management","04.java\u002Fpr2\u002F32.mvvm-navigation-screen-management",{"title":2516,"path":2517,"stem":2518},"Тестування JavaFX MVVM-додатків","\u002Fjava\u002Fpr2\u002Fmvvm-testing","04.java\u002Fpr2\u002F33.mvvm-testing",{"title":2520,"path":2521,"stem":2522},"Стилізація та теми у JavaFX: CSS та User Experience","\u002Fjava\u002Fpr2\u002Fjavafx-styling-themes","04.java\u002Fpr2\u002F34.javafx-styling-themes",{"title":2524,"path":2525,"stem":2526},"AtlantaFX: Сучасні теми для JavaFX додатків","\u002Fjava\u002Fpr2\u002Fatlantafx-modern-themes","04.java\u002Fpr2\u002F35.atlantafx-modern-themes",{"title":2528,"path":2529,"stem":2530},"Пакування та розповсюдження JavaFX-додатків","\u002Fjava\u002Fpr2\u002Fjar-packaging-distribution","04.java\u002Fpr2\u002F36.jar-packaging-distribution",{"title":2532,"icon":2533,"path":2534,"stem":2535,"children":2536,"page":59},"Python","i-devicon-python","\u002Fpython","05.python",[2537,2541,2544,2548,2552,2556,2560,2564,2568],{"title":2538,"path":2539,"stem":2540},"Модулі, Пакети та Віртуальні Середовища","\u002Fpython\u002Fmodules-packages-venv","05.python\u002F00.modules-packages-venv",{"title":71,"path":2542,"stem":2543},"\u002Fpython\u002Fclasses-objects","05.python\u002F01.classes-objects",{"title":2545,"path":2546,"stem":2547},"Інкапсуляція, Керування Доступом та Властивості","\u002Fpython\u002Fencapsulation","05.python\u002F02.encapsulation",{"title":2549,"path":2550,"stem":2551},"Наслідування, MRO та суперсила super()","\u002Fpython\u002Finheritance-mro","05.python\u002F03.inheritance-mro",{"title":2553,"path":2554,"stem":2555},"Абстракція — ABC проти Статичних Протоколів (PEP 544)","\u002Fpython\u002Fabstraction-protocols","05.python\u002F04.abstraction-protocols",{"title":2557,"path":2558,"stem":2559},"Магічні методи (Dunder) та Емуляція протоколів","\u002Fpython\u002Fdunder-methods","05.python\u002F05.dunder-methods",{"title":2561,"path":2562,"stem":2563},"Декоратори та Керування життєвим циклом методів","\u002Fpython\u002Fdecorators-static-class","05.python\u002F06.decorators-static-class",{"title":2565,"path":2566,"stem":2567},"📦 Повний посібник з модулів, пакетів та віртуальних середовищ у Python","\u002Fpython\u002Flesson_9","05.python\u002Flesson_9",{"title":2569,"path":2570,"stem":2571},"[object Object]","\u002Fpython\u002Foop-plan","05.python\u002Foop-plan",{"title":2573,"icon":2574,"path":2575,"stem":2576,"children":2577,"page":59},"Бази даних","i-lucide-database","\u002Fdatabases","06.databases",[2578,2608,2631,2668,2697,2715,2749,2761,2770],{"title":2579,"icon":2580,"path":2581,"stem":2582,"children":2583,"page":59},"Intro","i-lucide-play","\u002Fdatabases\u002Fintro","06.databases\u002F01.intro",[2584,2588,2592,2596,2600,2604],{"title":2585,"path":2586,"stem":2587},"Введення в теорію баз даних","\u002Fdatabases\u002Fintro\u002Fintroduction-to-databases","06.databases\u002F01.intro\u002F01.introduction-to-databases",{"title":2589,"path":2590,"stem":2591},"Реляційна модель даних","\u002Fdatabases\u002Fintro\u002Frelational-model-theory","06.databases\u002F01.intro\u002F02.relational-model-theory",{"title":2593,"path":2594,"stem":2595},"ER-моделювання","\u002Fdatabases\u002Fintro\u002Fer-modeling","06.databases\u002F01.intro\u002F03.er-modeling",{"title":2597,"path":2598,"stem":2599},"Логічне проектування БД","\u002Fdatabases\u002Fintro\u002Flogical-schema","06.databases\u002F01.intro\u002F04.logical-schema",{"title":2601,"path":2602,"stem":2603},"Класифікація таблиць","\u002Fdatabases\u002Fintro\u002Ftable-classification","06.databases\u002F01.intro\u002F05.table-classification",{"title":2605,"path":2606,"stem":2607},"PlantUML для баз даних","\u002Fdatabases\u002Fintro\u002Fplantuml-diagrams","06.databases\u002F01.intro\u002F06.plantuml-diagrams",{"title":2609,"icon":2574,"path":2610,"stem":2611,"children":2612,"page":59},"MS SQL Server Start","\u002Fdatabases\u002Fms-sql-server-start","06.databases\u002F02.ms-sql-server-start",[2613,2617,2623,2627],{"title":2614,"path":2615,"stem":2616},"Типи даних у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fdata-types","06.databases\u002F02.ms-sql-server-start\u002F01.data-types",{"title":2618,"path":2619,"stem":2620,"children":2621},"Індекси у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-indexes","06.databases\u002F02.ms-sql-server-start\u002F02.sql-indexes",[2622],{"title":2618,"path":2619,"stem":2620},{"title":2624,"path":2625,"stem":2626},"Системні бази даних MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsystem-databases","06.databases\u002F02.ms-sql-server-start\u002F03.system-databases",{"title":2628,"path":2629,"stem":2630},"Огляд мови SQL та запитів","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-queries-overview","06.databases\u002F02.ms-sql-server-start\u002F04.sql-queries-overview",{"title":2632,"icon":2574,"path":2633,"stem":2634,"children":2635,"page":59},"SQL","\u002Fdatabases\u002Fsql","06.databases\u002F03.sql",[2636,2640,2644,2648,2652,2656,2660,2664],{"title":2637,"path":2638,"stem":2639},"Налаштування демонстраційної бази даних","\u002Fdatabases\u002Fsql\u002Fsample-database-setup","06.databases\u002F03.sql\u002F00.sample-database-setup",{"title":2641,"path":2642,"stem":2643},"DDL - Створення таблиць (CREATE TABLE)","\u002Fdatabases\u002Fsql\u002Fddl-create-table","06.databases\u002F03.sql\u002F01.ddl-create-table",{"title":2645,"path":2646,"stem":2647},"DDL - Зміна та видалення таблиць (ALTER, DROP)","\u002Fdatabases\u002Fsql\u002Fddl-alter-drop-table","06.databases\u002F03.sql\u002F02.ddl-alter-drop-table",{"title":2649,"path":2650,"stem":2651},"SELECT запити - Основи","\u002Fdatabases\u002Fsql\u002Fselect-queries-fundamentals","06.databases\u002F03.sql\u002F03.select-queries-fundamentals",{"title":2653,"path":2654,"stem":2655},"SELECT запити - Розширені можливості","\u002Fdatabases\u002Fsql\u002Fselect-queries-advanced","06.databases\u002F03.sql\u002F04.select-queries-advanced",{"title":2657,"path":2658,"stem":2659},"INSERT запити - Додавання даних","\u002Fdatabases\u002Fsql\u002Finsert-queries","06.databases\u002F03.sql\u002F05.insert-queries",{"title":2661,"path":2662,"stem":2663},"UPDATE та DELETE запити","\u002Fdatabases\u002Fsql\u002Fupdate-delete-queries","06.databases\u002F03.sql\u002F06.update-delete-queries",{"title":2665,"path":2666,"stem":2667},"Транзакції в SQL","\u002Fdatabases\u002Fsql\u002Ftransactions","06.databases\u002F03.sql\u002F07.transactions",{"title":2669,"icon":2574,"path":2670,"stem":2671,"children":2672,"page":59},"Multi Table Databases","\u002Fdatabases\u002Fmulti-table-databases","06.databases\u002F04.multi-table-databases",[2673,2677,2681,2685,2689,2693],{"title":2674,"path":2675,"stem":2676},"Зв'язки та нормалізація БД","\u002Fdatabases\u002Fmulti-table-databases\u002Frelationships-and-normalization","06.databases\u002F04.multi-table-databases\u002F00.relationships-and-normalization",{"title":2678,"path":2679,"stem":2680},"INNER JOIN - З'єднання таблиць","\u002Fdatabases\u002Fmulti-table-databases\u002Finner-join","06.databases\u002F04.multi-table-databases\u002F01.inner-join",{"title":2682,"path":2683,"stem":2684},"OUTER JOINs - LEFT, RIGHT, FULL","\u002Fdatabases\u002Fmulti-table-databases\u002Fouter-joins","06.databases\u002F04.multi-table-databases\u002F02.outer-joins",{"title":2686,"path":2687,"stem":2688},"CROSS та SELF JOINs","\u002Fdatabases\u002Fmulti-table-databases\u002Fcross-self-joins","06.databases\u002F04.multi-table-databases\u002F03.cross-self-joins",{"title":2690,"path":2691,"stem":2692},"Підзапити (Subqueries)","\u002Fdatabases\u002Fmulti-table-databases\u002Fsubqueries","06.databases\u002F04.multi-table-databases\u002F04.subqueries",{"title":2694,"path":2695,"stem":2696},"Агрегації з JOIN","\u002Fdatabases\u002Fmulti-table-databases\u002Faggregations-with-joins","06.databases\u002F04.multi-table-databases\u002F05.aggregations-with-joins",{"title":2698,"icon":2699,"path":2700,"stem":2701,"children":2702,"page":59},"Aggregate Functions","i-lucide-calculator","\u002Fdatabases\u002Faggregate-functions","06.databases\u002F05.aggregate-functions",[2703,2707,2711],{"title":2704,"path":2705,"stem":2706},"Функції агрегування в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fintroduction-aggregate-functions","06.databases\u002F05.aggregate-functions\u002F01.introduction-aggregate-functions",{"title":2708,"path":2709,"stem":2710},"Групування даних в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fgrouping-data","06.databases\u002F05.aggregate-functions\u002F02.grouping-data",{"title":2712,"path":2713,"stem":2714},"Підзапити з агрегатними функціями","\u002Fdatabases\u002Faggregate-functions\u002Fsubqueries-aggregates","06.databases\u002F05.aggregate-functions\u002F03.subqueries-aggregates",{"title":2716,"icon":2717,"path":2718,"stem":2719,"children":2720,"page":59},"Тригери та зберігаємі процедури","i-lucide-database-zap","\u002Fdatabases\u002Ftriggers-stored-procedures","06.databases\u002F07.triggers-stored-procedures",[2721,2725,2729,2733,2737,2741,2745],{"title":2722,"path":2723,"stem":2724},"DML-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fdml-triggers","06.databases\u002F07.triggers-stored-procedures\u002F01.dml-triggers",{"title":2726,"path":2727,"stem":2728},"DDL-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fddl-triggers","06.databases\u002F07.triggers-stored-procedures\u002F02.ddl-triggers",{"title":2730,"path":2731,"stem":2732},"Transact-SQL розширення","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransact-sql-extensions","06.databases\u002F07.triggers-stored-procedures\u002F03.transact-sql-extensions",{"title":2734,"path":2735,"stem":2736},"Транзакції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransactions","06.databases\u002F07.triggers-stored-procedures\u002F04.transactions",{"title":2738,"path":2739,"stem":2740},"Зберігаємі процедури","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fstored-procedures","06.databases\u002F07.triggers-stored-procedures\u002F05.stored-procedures",{"title":2742,"path":2743,"stem":2744},"Користувацькі функції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fuser-defined-functions","06.databases\u002F07.triggers-stored-procedures\u002F06.user-defined-functions",{"title":2746,"path":2747,"stem":2748},"Безпека баз даних","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fsecurity","06.databases\u002F07.triggers-stored-procedures\u002F08.security",{"title":2746,"icon":793,"path":2750,"stem":2751,"children":2752,"page":59},"\u002Fdatabases\u002Fsecurity","06.databases\u002F08.security",[2753,2757],{"title":2754,"path":2755,"stem":2756},"Вступ до безпеки баз даних","\u002Fdatabases\u002Fsecurity\u002Fintroduction","06.databases\u002F08.security\u002F01.introduction",{"title":2758,"path":2759,"stem":2760},"Системні представлення та метадані","\u002Fdatabases\u002Fsecurity\u002Fsystem-views","06.databases\u002F08.security\u002F02.system-views",{"title":2762,"icon":2763,"path":2764,"stem":2765,"children":2766,"page":59},"Резервне копіювання та відновлення","i-lucide-database-backup","\u002Fdatabases\u002Fbackup-recovery","06.databases\u002F09.backup-recovery",[2767],{"title":2762,"path":2768,"stem":2769},"\u002Fdatabases\u002Fbackup-recovery\u002Fbackup-restore","06.databases\u002F09.backup-recovery\u002F01.backup-restore",{"title":2771,"icon":2772,"path":2773,"stem":2774,"children":2775,"page":59},"Повнотекстовий пошук","i-lucide-search","\u002Fdatabases\u002Ffull-text-search","06.databases\u002F10.full-text-search",[2776],{"title":2771,"path":2777,"stem":2778},"\u002Fdatabases\u002Ffull-text-search\u002Ffull-text-search","06.databases\u002F10.full-text-search\u002F01.full-text-search",{"title":2780,"icon":2781,"path":2782,"stem":2783,"children":2784,"page":59},"Tools","i-lucide-wrench","\u002Ftools","07.tools",[2785,2861],{"title":2786,"icon":2787,"path":2788,"stem":2789,"children":2790},"Docker","i-simple-icons-docker","\u002Ftools\u002Fdocker","07.tools\u002F01.docker\u002Findex",[2791,2793,2797,2801,2805,2809,2813,2817,2821,2825,2829,2833,2837,2841,2845,2849,2853,2857],{"title":2792,"path":2788,"stem":2789},"Docker: від нуля до production",{"title":2794,"path":2795,"stem":2796},"Контейнеризація — від проблеми до рішення","\u002Ftools\u002Fdocker\u002Fcontainerization-concept","07.tools\u002F01.docker\u002F01.containerization-concept",{"title":2798,"path":2799,"stem":2800},"Docker — що це і навіщо?","\u002Ftools\u002Fdocker\u002Fdocker-what-and-why","07.tools\u002F01.docker\u002F02.docker-what-and-why",{"title":2802,"path":2803,"stem":2804},"Архітектура Docker Engine","\u002Ftools\u002Fdocker\u002Fdocker-architecture","07.tools\u002F01.docker\u002F03.docker-architecture",{"title":2806,"path":2807,"stem":2808},"Встановлення Docker","\u002Ftools\u002Fdocker\u002Finstallation","07.tools\u002F01.docker\u002F04.installation",{"title":2810,"path":2811,"stem":2812},"Перший контейнер — docker run","\u002Ftools\u002Fdocker\u002Ffirst-container","07.tools\u002F01.docker\u002F05.first-container",{"title":2814,"path":2815,"stem":2816},"Життєвий цикл контейнера","\u002Ftools\u002Fdocker\u002Fcontainer-lifecycle","07.tools\u002F01.docker\u002F06.container-lifecycle",{"title":2818,"path":2819,"stem":2820},"Docker Images — фундаментальні концепції","\u002Ftools\u002Fdocker\u002Fdocker-images-fundamentals","07.tools\u002F01.docker\u002F07.docker-images-fundamentals",{"title":2822,"path":2823,"stem":2824},"Dockerfile — основи","\u002Ftools\u002Fdocker\u002Fdockerfile-basics","07.tools\u002F01.docker\u002F08.dockerfile-basics",{"title":2826,"path":2827,"stem":2828},"Dockerfile — просунуті техніки","\u002Ftools\u002Fdocker\u002Fdockerfile-advanced","07.tools\u002F01.docker\u002F09.dockerfile-advanced",{"title":2830,"path":2831,"stem":2832},"Build Context та кешування шарів","\u002Ftools\u002Fdocker\u002Fbuild-context-and-cache","07.tools\u002F01.docker\u002F10.build-context-and-cache",{"title":2834,"path":2835,"stem":2836},"Реєстри Docker-образів","\u002Ftools\u002Fdocker\u002Fimage-registries","07.tools\u002F01.docker\u002F11.image-registries",{"title":2838,"path":2839,"stem":2840},"Контейнеризація .NET додатків","\u002Ftools\u002Fdocker\u002Fdotnet-containerization","07.tools\u002F01.docker\u002F12.dotnet-containerization",{"title":2842,"path":2843,"stem":2844},"Томи та збереження даних","\u002Ftools\u002Fdocker\u002Fvolumes-and-data","07.tools\u002F01.docker\u002F13.volumes-and-data",{"title":2846,"path":2847,"stem":2848},"Основи мережі в Docker","\u002Ftools\u002Fdocker\u002Fnetworking-basics","07.tools\u002F01.docker\u002F14.networking-basics",{"title":2850,"path":2851,"stem":2852},"Змінні оточення та конфігурація","\u002Ftools\u002Fdocker\u002Fenvironment-and-configuration","07.tools\u002F01.docker\u002F15.environment-and-configuration",{"title":2854,"path":2855,"stem":2856},"Docker Compose — оркестрація контейнерів","\u002Ftools\u002Fdocker\u002Fdocker-compose-basics","07.tools\u002F01.docker\u002F16.docker-compose-basics",{"title":2858,"path":2859,"stem":2860},"Docker Compose — Multi-Service застосунки","\u002Ftools\u002Fdocker\u002Fcompose-multi-service","07.tools\u002F01.docker\u002F17.compose-multi-service",{"title":2862,"icon":2863,"path":2864,"stem":2865,"children":2866},"Kubernetes","simple-icons:kubernetes","\u002Ftools\u002Fkubernetes","07.tools\u002F02.kubernetes\u002Findex",[2867,2869,2873,2877,2881,2885,2889,2893,2897],{"title":2868,"path":2864,"stem":2865},"Kubernetes: від розробки до production",{"title":2870,"path":2871,"stem":2872},"Kubernetes — коли Docker Compose більше не вистачає","\u002Ftools\u002Fkubernetes\u002Fwhy-kubernetes","07.tools\u002F02.kubernetes\u002F01.why-kubernetes",{"title":2874,"path":2875,"stem":2876},"Архітектура Kubernetes — анатомія кластера","\u002Ftools\u002Fkubernetes\u002Fkubernetes-architecture","07.tools\u002F02.kubernetes\u002F02.kubernetes-architecture",{"title":2878,"path":2879,"stem":2880},"Локальне середовище — minikube, kind та k3s","\u002Ftools\u002Fkubernetes\u002Flocal-environment","07.tools\u002F02.kubernetes\u002F03.local-environment",{"title":2882,"path":2883,"stem":2884},"Pod — атомарна одиниця Kubernetes","\u002Ftools\u002Fkubernetes\u002Fpods-and-containers","07.tools\u002F02.kubernetes\u002F04.pods-and-containers",{"title":2886,"path":2887,"stem":2888},"Патерни використання Pod","\u002Ftools\u002Fkubernetes\u002Fpod-patterns","07.tools\u002F02.kubernetes\u002F05.pod-patterns",{"title":2890,"path":2891,"stem":2892},"Deployment — декларативне управління Pod","\u002Ftools\u002Fkubernetes\u002Fdeployment-basics","07.tools\u002F02.kubernetes\u002F06.deployment-basics",{"title":2894,"path":2895,"stem":2896},"Rolling Updates та управління життєвим циклом Deployment","\u002Ftools\u002Fkubernetes\u002Fdeployment-rolling-updates","07.tools\u002F02.kubernetes\u002F07.deployment-rolling-updates",{"title":2898,"path":2899,"stem":2900},"Service — мережева абстракція для Pod","\u002Ftools\u002Fkubernetes\u002Fservices-networking","07.tools\u002F02.kubernetes\u002F08.services-networking",{"title":2902,"icon":2903,"path":2904,"stem":2905,"children":2906,"page":59},"Software Engineering","i-lucide-code-2","\u002Fsoftware-engineering","09.software-engineering",[2907,2911,2915,2919,2923,2927,2931,2935,2939,2943,2947],{"title":2908,"path":2909,"stem":2910},"1. Аналіз предметної області. Експертні знання та складність","\u002Fsoftware-engineering\u002Fintro-subdomains","09.software-engineering\u002F01.intro-subdomains",{"title":2912,"path":2913,"stem":2914},"2. Обмежені контексти. Інтеграція обмежених контекстів","\u002Fsoftware-engineering\u002Fintegrating-limited-contexts","09.software-engineering\u002F02.integrating-limited-contexts",{"title":2916,"path":2917,"stem":2918},"3. Реалізація простої бізнес-логіки","\u002Fsoftware-engineering\u002Fsimple","09.software-engineering\u002F03.simple",{"title":2920,"path":2921,"stem":2922},"4. Опрацювання складної бізнес-логіки","\u002Fsoftware-engineering\u002Fcomplex-business-logic","09.software-engineering\u002F04.complex-business-logic",{"title":2924,"path":2925,"stem":2926},"5. Моделювання фактора часу. Подієво-орієнтована архітектура.","\u002Fsoftware-engineering\u002Fmodelling-the-time-factor","09.software-engineering\u002F05.modelling-the-time-factor",{"title":2928,"path":2929,"stem":2930},"6. Архітектурні патерни","\u002Fsoftware-engineering\u002Farchitectural-patterns","09.software-engineering\u002F06.architectural-patterns",{"title":2932,"path":2933,"stem":2934},"Паттерни взаємодії","\u002Fsoftware-engineering\u002Fpatterns-of-interaction","09.software-engineering\u002F07.patterns-of-interaction",{"title":2936,"path":2937,"stem":2938},"Евристика проєктування","\u002Fsoftware-engineering\u002Fdesign-heuristics","09.software-engineering\u002F08.design-heuristics",{"title":2940,"path":2941,"stem":2942},"Еволюція проєктних рішень","\u002Fsoftware-engineering\u002Fevolution-of-design-solutions","09.software-engineering\u002F09.evolution-of-design-solutions",{"title":2944,"path":2945,"stem":2946},"EventStorming","\u002Fsoftware-engineering\u002Feventstorming","09.software-engineering\u002F10.eventstorming",{"title":2948,"path":2949,"stem":2950},"DDD на практиці","\u002Fsoftware-engineering\u002Fddd-in-practice","09.software-engineering\u002F11.ddd-in-practice",{"title":2952,"icon":943,"path":2953,"stem":2954,"children":2955,"page":59},"DDD","\u002Fddd","10.ddd",[2956,2960,2964,2968,2972,2976,2980,2984,2988,2992,2996,3000,3004],{"title":2957,"path":2958,"stem":2959},"Аналіз предметної області","\u002Fddd\u002Fdomain-analysis","10.ddd\u002F01.domain-analysis",{"title":2961,"path":2962,"stem":2963},"Експертні знання про предметну область","\u002Fddd\u002Fdomain-expert-knowledge","10.ddd\u002F02.domain-expert-knowledge",{"title":2965,"path":2966,"stem":2967},"Як осмислити складність предметної області","\u002Fddd\u002Fmanaging-domain-complexity","10.ddd\u002F03.managing-domain-complexity",{"title":2969,"path":2970,"stem":2971},"Інтеграція обмежених контекстів","\u002Fddd\u002Fbounded-context-integration","10.ddd\u002F04.bounded-context-integration",{"title":2973,"path":2974,"stem":2975},"Реалізація простої бізнес-логіки","\u002Fddd\u002Fsimple-business-logic","10.ddd\u002F05.simple-business-logic",{"title":2977,"path":2978,"stem":2979},"Обробка складної бізнес-логіки","\u002Fddd\u002Fcomplex-business-logic","10.ddd\u002F06.complex-business-logic",{"title":2981,"path":2982,"stem":2983},"Моделювання фактора часу","\u002Fddd\u002Ftime-modeling","10.ddd\u002F07.time-modeling",{"title":2985,"path":2986,"stem":2987},"Глава 8. Архітектурні Патерни","\u002Fddd\u002Farchitectural-patterns","10.ddd\u002F08.architectural-patterns",{"title":2989,"path":2990,"stem":2991},"Глава 9. Патерни Взаємодії","\u002Fddd\u002Finteraction-patterns","10.ddd\u002F09.interaction-patterns",{"title":2993,"path":2994,"stem":2995},"Глава 10. Проектні Евристики","\u002Fddd\u002Fdesign-heuristics","10.ddd\u002F10.design-heuristics",{"title":2997,"path":2998,"stem":2999},"Глава 11. Еволюція Проектних Рішень","\u002Fddd\u002Fevolution-of-design-decisions","10.ddd\u002F11.evolution-of-design-decisions",{"title":3001,"path":3002,"stem":3003},"Глава 12. EventStorming","\u002Fddd\u002Fevent-storming","10.ddd\u002F12.event-storming",{"title":3005,"path":3006,"stem":3007},"Глава 13. DDD на Практиці","\u002Fddd\u002Fddd-in-practice","10.ddd\u002F13.ddd-in-practice",{"title":3009,"icon":3010,"path":3011,"stem":3012,"children":3013,"page":59},"Media Streaming","i-lucide-video","\u002Fmedia-streaming","11.media-streaming",[3014,3018,3022,3026,3030,3034,3038],{"title":3015,"path":3016,"stem":3017},"01. Магія Стрімінгу: Що відбувається, коли ви натискаєте \"Play\"","\u002Fmedia-streaming\u002Fintroduction","11.media-streaming\u002F01.introduction",{"title":3019,"path":3020,"stem":3021},"02. Анатомія Медіа: Кодеки, Контейнери та Стиснення","\u002Fmedia-streaming\u002Faudio-video-anatomy","11.media-streaming\u002F02.audio-video-anatomy",{"title":3023,"path":3024,"stem":3025},"03. The Gym: FFmpeg Deep Dive","\u002Fmedia-streaming\u002Fffmpeg-gym","11.media-streaming\u002F03.ffmpeg-gym",{"title":3027,"path":3028,"stem":3029},"04. HLS Protocol: HTTP Live Streaming у Деталях","\u002Fmedia-streaming\u002Fhls-protocol","11.media-streaming\u002F04.hls-protocol",{"title":3031,"path":3032,"stem":3033},"05. DASH Protocol: Відкритий Стандарт","\u002Fmedia-streaming\u002Fdash-protocol","11.media-streaming\u002F05.dash-protocol",{"title":3035,"path":3036,"stem":3037},"06. Масштабування: CDN та Adaptive Bitrate","\u002Fmedia-streaming\u002Fcdn-and-adaptive-bitrate","11.media-streaming\u002F06.cdn-and-adaptive-bitrate",{"title":3039,"path":3040,"stem":3041},"07. Війна із Затримкою (Latency)","\u002Fmedia-streaming\u002Frealtime-latency","11.media-streaming\u002F07.realtime-latency",{"title":3043,"icon":3044,"path":3045,"stem":3046,"children":3047,"page":59},"HTML & CSS","i-devicon-html5","\u002Fhtml-css","12.html-css",[3048,3052,3056,3060,3064,3068,3072,3076,3080,3084,3088,3092,3096,3100,3104,3108,3112,3116,3120,3124,3128,3132,3136,3140,3144,3148,3152,3156,3160,3164],{"title":3049,"path":3050,"stem":3051},"Вступ до HTML. Структура документа","\u002Fhtml-css\u002Fintro-html-structure","12.html-css\u002F01.intro-html-structure",{"title":3053,"path":3054,"stem":3055},"Форматування тексту в HTML","\u002Fhtml-css\u002Fhtml-text-formatting","12.html-css\u002F02.html-text-formatting",{"title":3057,"path":3058,"stem":3059},"Посилання та зображення в HTML","\u002Fhtml-css\u002Fhtml-links-images","12.html-css\u002F03.html-links-images",{"title":3061,"path":3062,"stem":3063},"Списки та таблиці в HTML","\u002Fhtml-css\u002Fhtml-lists-tables","12.html-css\u002F04.html-lists-tables",{"title":3065,"path":3066,"stem":3067},"Форми в HTML","\u002Fhtml-css\u002Fhtml-forms","12.html-css\u002F05.html-forms",{"title":3069,"path":3070,"stem":3071},"Семантичні елементи HTML5","\u002Fhtml-css\u002Fhtml-semantic-elements","12.html-css\u002F06.html-semantic-elements",{"title":3073,"path":3074,"stem":3075},"Мультимедіа та розширені елементи HTML","\u002Fhtml-css\u002Fhtml-multimedia-advanced","12.html-css\u002F07.html-multimedia-advanced",{"title":3077,"path":3078,"stem":3079},"Мікророзмітка та SEO в HTML","\u002Fhtml-css\u002Fhtml-microdata-seo","12.html-css\u002F08.html-microdata-seo",{"title":3081,"path":3082,"stem":3083},"Вступ до CSS. Селектори та специфічність","\u002Fhtml-css\u002Fcss-intro-selectors","12.html-css\u002F09.css-intro-selectors",{"title":3085,"path":3086,"stem":3087},"Блокова модель CSS. Відступи. Box Sizing","\u002Fhtml-css\u002Fcss-box-model","12.html-css\u002F10.css-box-model",{"title":3089,"path":3090,"stem":3091},"Розміри у CSS: повний довідник одиниць і ключових слів","\u002Fhtml-css\u002F10a.css-sizing","12.html-css\u002F10a.css-sizing",{"title":3093,"path":3094,"stem":3095},"Типографіка в CSS. Шрифти та текст","\u002Fhtml-css\u002Fcss-typography","12.html-css\u002F11.css-typography",{"title":3097,"path":3098,"stem":3099},"Кольори та фони в CSS","\u002Fhtml-css\u002Fcss-colors-backgrounds","12.html-css\u002F12.css-colors-backgrounds",{"title":3101,"path":3102,"stem":3103},"Тіні та фільтри в CSS","\u002Fhtml-css\u002F12b.css-shadows-filters","12.html-css\u002F12b.css-shadows-filters",{"title":3105,"path":3106,"stem":3107},"CSS Flexbox: Фундамент гнучких макетів","\u002Fhtml-css\u002Fcss-flexbox-fundamentals","12.html-css\u002F13.css-flexbox-fundamentals",{"title":3109,"path":3110,"stem":3111},"CSS Flexbox: Вирівнювання та Позиціонування","\u002Fhtml-css\u002Fcss-flexbox-alignment-sizing-and-patterns","12.html-css\u002F14.css-flexbox-alignment-sizing-and-patterns",{"title":3113,"path":3114,"stem":3115},"CSS Grid. Двовимірний макет. Частина 1","\u002Fhtml-css\u002Fcss-layout-grid","12.html-css\u002F15.css-layout-grid",{"title":3117,"path":3118,"stem":3119},"CSS Grid. Двовимірний макет. Частина 2","\u002Fhtml-css\u002Fcss-layout-grid-advanced","12.html-css\u002F16.css-layout-grid-advanced",{"title":3121,"path":3122,"stem":3123},"Позиціонування в CSS. Z-index. Stacking Context","\u002Fhtml-css\u002Fcss-positioning","12.html-css\u002F17.css-positioning",{"title":3125,"path":3126,"stem":3127},"CSS Анімації та Переходи","\u002Fhtml-css\u002Fcss-animations-transitions","12.html-css\u002F18.css-animations-transitions",{"title":3129,"path":3130,"stem":3131},"Адаптивний дизайн. Media Queries. Частина 1","\u002Fhtml-css\u002Fcss-responsive-media-queries","12.html-css\u002F19.css-responsive-media-queries",{"title":3133,"path":3134,"stem":3135},"Адаптивний дизайн. Частина 2: clamp(), Container Queries, @layer","\u002Fhtml-css\u002Fcss-responsive-advanced","12.html-css\u002F20.css-responsive-advanced",{"title":3137,"path":3138,"stem":3139},"CSS Custom Properties. Методології. Сучасний CSS","\u002Fhtml-css\u002Fcss-variables-methodologies","12.html-css\u002F21.css-variables-methodologies",{"title":3141,"path":3142,"stem":3143},"Сучасний CSS 2023–2025: Нові можливості","\u002Fhtml-css\u002Fcss-modern-features","12.html-css\u002F22.css-modern-features",{"title":3145,"path":3146,"stem":3147},"CSS Nesting, @layer, @scope та @property: нативний препроцесор","\u002Fhtml-css\u002F22a.css-nesting-modern-syntax","12.html-css\u002F22a.css-nesting-modern-syntax",{"title":3149,"path":3150,"stem":3151},"CSS для форм та інтерактивних станів","\u002Fhtml-css\u002Fcss-forms-interactive-states","12.html-css\u002F23.css-forms-interactive-states",{"title":3153,"path":3154,"stem":3155},"Доступність у CSS (CSS Accessibility)","\u002Fhtml-css\u002Fcss-accessibility","12.html-css\u002F24.css-accessibility",{"title":3157,"path":3158,"stem":3159},"CSS-функції та сучасні sizing primitives","\u002Fhtml-css\u002Fcss-functions-sizing","12.html-css\u002F25.css-functions-sizing",{"title":3161,"path":3162,"stem":3163},"Rendering Pipeline і CSS Performance","\u002Fhtml-css\u002Fcss-rendering-performance","12.html-css\u002F26.css-rendering-performance",{"title":3165,"path":3166,"stem":3167},"CSS Best Practices: типові ситуації та правильні рішення","\u002Fhtml-css\u002Fcss-best-practices","12.html-css\u002F27.css-best-practices",{"title":3169,"path":3170,"stem":3171,"children":3172,"page":59},"AWS","\u002Faws","13.aws",[3173,3177,3181,3185,3189,3193,3197,3201,3205,3209,3213,3217,3221,3225,3229,3233,3237,3241],{"title":3174,"path":3175,"stem":3176},"Реєстрація AWS акаунту та студентські програми","\u002Faws\u002Faccount-registration","13.aws\u002F00.account-registration",{"title":3178,"path":3179,"stem":3180},"Вступ до хмарних обчислень та AWS","\u002Faws\u002Fintroduction-to-cloud","13.aws\u002F01.introduction-to-cloud",{"title":3182,"path":3183,"stem":3184},"AWS IAM — Identity and Access Management","\u002Faws\u002Fiam","13.aws\u002F02.iam",{"title":3186,"path":3187,"stem":3188},"AWS IAM CLI — Довідник команд","\u002Faws\u002F02a.iam-doc","13.aws\u002F02a.iam-doc",{"title":3190,"path":3191,"stem":3192},"Docker та контейнеризація в AWS — ECR, ECS та Fargate","\u002Faws\u002Fdocker-ecs","13.aws\u002F03.docker-ecs",{"title":3194,"path":3195,"stem":3196},"AWS ECR \u002F ECS CLI — Довідник команд","\u002Faws\u002F03a.docker-ecs-doc","13.aws\u002F03a.docker-ecs-doc",{"title":3198,"path":3199,"stem":3200},"Amazon EC2 — Elastic Compute Cloud","\u002Faws\u002Fec2","13.aws\u002F04.ec2",{"title":3202,"path":3203,"stem":3204},"AWS EC2 CLI — Довідник команд","\u002Faws\u002F04a.ec2-doc","13.aws\u002F04a.ec2-doc",{"title":3206,"path":3207,"stem":3208},"Elastic Load Balancing та Auto Scaling","\u002Faws\u002Falb-asg","13.aws\u002F05.alb-asg",{"title":3210,"path":3211,"stem":3212},"Amazon S3 — Simple Storage Service","\u002Faws\u002Fs3","13.aws\u002F06.s3",{"title":3214,"path":3215,"stem":3216},"Amazon CloudFront — Content Delivery Network","\u002Faws\u002Fcloudfront","13.aws\u002F07.cloudfront",{"title":3218,"path":3219,"stem":3220},"Amazon RDS — Relational Database Service","\u002Faws\u002Frds","13.aws\u002F08.rds",{"title":3222,"path":3223,"stem":3224},"Amazon DynamoDB — NoSQL Database","\u002Faws\u002Fdynamodb","13.aws\u002F09.dynamodb",{"title":3226,"path":3227,"stem":3228},"AWS Lambda та Serverless Compute","\u002Faws\u002Flambda","13.aws\u002F10.lambda",{"title":3230,"path":3231,"stem":3232},"Amazon Bedrock - Foundation Models, RAG та Agents","\u002Faws\u002Fbedrock","13.aws\u002F22.bedrock",{"title":3234,"path":3235,"stem":3236},"Amazon Rekognition - Комп'ютерний зір","\u002Faws\u002Frekognition","13.aws\u002F23.rekognition",{"title":3238,"path":3239,"stem":3240},"Amazon Textract - Інтелектуальний аналіз документів","\u002Faws\u002Ftextract","13.aws\u002F24.textract",{"title":3242,"path":3243,"stem":3244},"Amazon Polly, Transcribe, Comprehend та Translate","\u002Faws\u002Faudio-nlp-services","13.aws\u002F25.audio-nlp-services",{"title":3246,"path":3247,"stem":3248,"children":3249,"page":59},"Tailwind","\u002Ftailwind","21.tailwind",[3250,3254,3258,3262,3266,3270,3274,3278,3282,3286,3290,3294],{"title":3251,"path":3252,"stem":3253},"Що таке Tailwind CSS і навіщо він потрібен","\u002Ftailwind\u002Ftailwind-intro-philosophy","21.tailwind\u002F01.tailwind-intro-philosophy",{"title":3255,"path":3256,"stem":3257},"Встановлення та налаштування Tailwind CSS v4","\u002Ftailwind\u002Ftailwind-installation-setup","21.tailwind\u002F02.tailwind-installation-setup",{"title":3259,"path":3260,"stem":3261},"Utility-класи: основи та система Tailwind","\u002Ftailwind\u002Ftailwind-utility-classes-core","21.tailwind\u002F03.tailwind-utility-classes-core",{"title":3263,"path":3264,"stem":3265},"Layout: Flexbox та Grid через Tailwind","\u002Ftailwind\u002Ftailwind-flexbox-grid","21.tailwind\u002F04.tailwind-flexbox-grid",{"title":3267,"path":3268,"stem":3269},"Кастомізація теми через @theme у Tailwind v4","\u002Ftailwind\u002Ftailwind-theme-customization","21.tailwind\u002F05.tailwind-theme-customization",{"title":3271,"path":3272,"stem":3273},"Варіанти: hover, focus, responsive, dark mode та нові v4","\u002Ftailwind\u002Ftailwind-variants-states","21.tailwind\u002F06.tailwind-variants-states",{"title":3275,"path":3276,"stem":3277},"Типографіка та система кольорів у Tailwind v4","\u002Ftailwind\u002Ftailwind-typography-colors","21.tailwind\u002F07.tailwind-typography-colors",{"title":3279,"path":3280,"stem":3281},"Компоненти та повторюваність: @apply, @utility та патерни","\u002Ftailwind\u002Ftailwind-components-patterns","21.tailwind\u002F08.tailwind-components-patterns",{"title":3283,"path":3284,"stem":3285},"Темна тема та система дизайн-токенів у Tailwind v4","\u002Ftailwind\u002Ftailwind-dark-mode-theming","21.tailwind\u002F09.tailwind-dark-mode-theming",{"title":3287,"path":3288,"stem":3289},"Довільні значення та контейнерні запити у Tailwind v4","\u002Ftailwind\u002Ftailwind-arbitrary-container-queries","21.tailwind\u002F10.tailwind-arbitrary-container-queries",{"title":3291,"path":3292,"stem":3293},"Анімації, трансформації та 3D у Tailwind v4","\u002Ftailwind\u002Ftailwind-animations-transforms","21.tailwind\u002F11.tailwind-animations-transforms",{"title":3295,"path":3296,"stem":3297},"Tailwind CLI, PostCSS та інтеграція з фреймворками","\u002Ftailwind\u002Ftailwind-cli-tooling","21.tailwind\u002F12.tailwind-cli-tooling",{"title":3299,"path":3300,"stem":3301},"Тестування компонентів діаграм","\u002Ftest-components","98.test-components",{"id":3303,"title":1357,"body":3304,"description":9135,"extension":9136,"links":9137,"meta":9138,"navigation":3388,"path":1358,"seo":9139,"stem":1359,"__hash__":9140},"docs\u002F01.csharp\u002F11.aspnet\u002F13.monitoring\u002F02.health-checks.md",{"type":3305,"value":3306,"toc":9116},"minimark",[3307,3311,3320,3327,3330,3335,3340,3343,3351,3567,3571,3574,3590,3593,3597,3603,3605,3609,3620,3821,3828,3908,3917,3947,3949,3953,3956,4080,4094,4132,4138,4572,4627,4629,4636,4642,5132,5137,5195,5213,5216,5322,5324,5331,5334,5955,5961,5963,5970,5980,6166,6176,6179,6554,6562,6564,6568,6575,6774,6784,6789,7141,7147,7292,7294,7298,7304,7657,7664,7671,7785,7787,7791,7794,8941,8995,8997,9001,9008,9105,9112],[3308,3309,1357],"h1",{"id":3310},"health-checks-перший-рівень-observability",[3312,3313,3314,3315,3319],"p",{},"Перш ніж будувати складні дашборди метрик і налаштовувати distributed tracing, варто відповісти на найпростіше питання: ",[3316,3317,3318],"strong",{},"«Чи живий мій додаток прямо зараз?»"," Саме для цього існують Health Checks.",[3312,3321,3322,3323,3326],{},"Health Check — це механізм, за допомогою якого додаток ",[3316,3324,3325],{},"повідомляє про свій стан"," зовнішнім системам: балансувальнику навантаження, оркестратору контейнерів, системі моніторингу або черговому інженеру. На відміну від метрик, що відповідають на питання «як добре?», health check відповідає на бінарне питання: «продовжувати надсилати трафік чи ні?»",[3328,3329],"hr",{},[3331,3332,3334],"h2",{"id":3333},"навіщо-це-потрібно-три-сценарії-використання","Навіщо це потрібно: три сценарії використання",[3336,3337,3339],"h3",{"id":3338},"сценарій-1-load-balancer-і-маршрутизація-трафіку","Сценарій 1: Load Balancer і маршрутизація трафіку",[3312,3341,3342],{},"Уявіть два інстанси вашого ASP.NET додатку за балансувальником навантаження. Один інстанс не може підключитись до бази даних — його пул з'єднань вичерпано. Але процес ASP.NET живий, порт 8080 відповідає, HTTP 200 повертається. Балансувальник не знає про проблему і продовжує надсилати 50% трафіку на несправний інстанс.",[3312,3344,3345,3346,3350],{},"Без health checks: половина ваших користувачів отримує помилки бази даних.\nЗ health checks: балансувальник бачить ",[3347,3348,3349],"code",{},"Unhealthy",", виключає інстанс і весь трафік йде на здоровий.",[3352,3353,3354],"plant-uml",{},[3355,3356,3361],"pre",{"className":3357,"code":3358,"language":3359,"meta":3360,"style":3360},"language-plantuml shiki shiki-themes light-plus dark-plus dark-plus","@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\n\nactor \"Користувачі\" as U\n\nrectangle \"Load Balancer\\n(AWS ALB \u002F nginx)\" as LB #fef3c7\n\nrectangle \"Instance 1\\n:8080\" as I1 #bbf7d0 {\n    note as N1\n      GET \u002Fhealth → 200 Healthy\n      DB: OK ✓\n      Redis: OK ✓\n    end note\n}\n\nrectangle \"Instance 2\\n:8080\" as I2 #fecaca {\n    note as N2\n      GET \u002Fhealth → 503 Unhealthy\n      DB: Connection pool exhausted ✗\n      Redis: OK ✓\n    end note\n}\n\nU --> LB : запити\nLB --> I1 : 100% трафіку\nLB ..> I2 : excluded\\n(health check failed)\n\nnote bottom of LB\n  LB перевіряє \u002Fhealth кожні 10 сек.\n  Якщо 2 consecutive failures →\n  виключити з rotation.\nend note\n\n@enduml\n","plantuml","",[3347,3362,3363,3371,3377,3383,3390,3396,3401,3407,3412,3418,3424,3430,3436,3442,3448,3454,3459,3465,3471,3477,3483,3488,3493,3498,3503,3509,3515,3521,3526,3532,3538,3544,3550,3556,3561],{"__ignoreMap":3360},[3364,3365,3368],"span",{"class":3366,"line":3367},"line",1,[3364,3369,3370],{},"@startuml\n",[3364,3372,3374],{"class":3366,"line":3373},2,[3364,3375,3376],{},"skinparam style plain\n",[3364,3378,3380],{"class":3366,"line":3379},3,[3364,3381,3382],{},"skinparam backgroundColor #ffffff\n",[3364,3384,3386],{"class":3366,"line":3385},4,[3364,3387,3389],{"emptyLinePlaceholder":3388},true,"\n",[3364,3391,3393],{"class":3366,"line":3392},5,[3364,3394,3395],{},"actor \"Користувачі\" as U\n",[3364,3397,3399],{"class":3366,"line":3398},6,[3364,3400,3389],{"emptyLinePlaceholder":3388},[3364,3402,3404],{"class":3366,"line":3403},7,[3364,3405,3406],{},"rectangle \"Load Balancer\\n(AWS ALB \u002F nginx)\" as LB #fef3c7\n",[3364,3408,3410],{"class":3366,"line":3409},8,[3364,3411,3389],{"emptyLinePlaceholder":3388},[3364,3413,3415],{"class":3366,"line":3414},9,[3364,3416,3417],{},"rectangle \"Instance 1\\n:8080\" as I1 #bbf7d0 {\n",[3364,3419,3421],{"class":3366,"line":3420},10,[3364,3422,3423],{},"    note as N1\n",[3364,3425,3427],{"class":3366,"line":3426},11,[3364,3428,3429],{},"      GET \u002Fhealth → 200 Healthy\n",[3364,3431,3433],{"class":3366,"line":3432},12,[3364,3434,3435],{},"      DB: OK ✓\n",[3364,3437,3439],{"class":3366,"line":3438},13,[3364,3440,3441],{},"      Redis: OK ✓\n",[3364,3443,3445],{"class":3366,"line":3444},14,[3364,3446,3447],{},"    end note\n",[3364,3449,3451],{"class":3366,"line":3450},15,[3364,3452,3453],{},"}\n",[3364,3455,3457],{"class":3366,"line":3456},16,[3364,3458,3389],{"emptyLinePlaceholder":3388},[3364,3460,3462],{"class":3366,"line":3461},17,[3364,3463,3464],{},"rectangle \"Instance 2\\n:8080\" as I2 #fecaca {\n",[3364,3466,3468],{"class":3366,"line":3467},18,[3364,3469,3470],{},"    note as N2\n",[3364,3472,3474],{"class":3366,"line":3473},19,[3364,3475,3476],{},"      GET \u002Fhealth → 503 Unhealthy\n",[3364,3478,3480],{"class":3366,"line":3479},20,[3364,3481,3482],{},"      DB: Connection pool exhausted ✗\n",[3364,3484,3486],{"class":3366,"line":3485},21,[3364,3487,3441],{},[3364,3489,3491],{"class":3366,"line":3490},22,[3364,3492,3447],{},[3364,3494,3496],{"class":3366,"line":3495},23,[3364,3497,3453],{},[3364,3499,3501],{"class":3366,"line":3500},24,[3364,3502,3389],{"emptyLinePlaceholder":3388},[3364,3504,3506],{"class":3366,"line":3505},25,[3364,3507,3508],{},"U --> LB : запити\n",[3364,3510,3512],{"class":3366,"line":3511},26,[3364,3513,3514],{},"LB --> I1 : 100% трафіку\n",[3364,3516,3518],{"class":3366,"line":3517},27,[3364,3519,3520],{},"LB ..> I2 : excluded\\n(health check failed)\n",[3364,3522,3524],{"class":3366,"line":3523},28,[3364,3525,3389],{"emptyLinePlaceholder":3388},[3364,3527,3529],{"class":3366,"line":3528},29,[3364,3530,3531],{},"note bottom of LB\n",[3364,3533,3535],{"class":3366,"line":3534},30,[3364,3536,3537],{},"  LB перевіряє \u002Fhealth кожні 10 сек.\n",[3364,3539,3541],{"class":3366,"line":3540},31,[3364,3542,3543],{},"  Якщо 2 consecutive failures →\n",[3364,3545,3547],{"class":3366,"line":3546},32,[3364,3548,3549],{},"  виключити з rotation.\n",[3364,3551,3553],{"class":3366,"line":3552},33,[3364,3554,3555],{},"end note\n",[3364,3557,3559],{"class":3366,"line":3558},34,[3364,3560,3389],{"emptyLinePlaceholder":3388},[3364,3562,3564],{"class":3366,"line":3563},35,[3364,3565,3566],{},"@enduml\n",[3336,3568,3570],{"id":3569},"сценарій-2-kubernetes-liveness-та-readiness","Сценарій 2: Kubernetes liveness та readiness",[3312,3572,3573],{},"У Kubernetes кожен Pod має два типи перевірок:",[3575,3576,3577,3584],"ul",{},[3578,3579,3580,3583],"li",{},[3316,3581,3582],{},"Liveness probe"," — «чи живий процес?» Якщо ні → перезапустити Pod.",[3578,3585,3586,3589],{},[3316,3587,3588],{},"Readiness probe"," — «чи готовий Pod приймати трафік?» Якщо ні → виключити з Service endpoints, але не вбивати.",[3312,3591,3592],{},"Це тонка але критична різниця. Під час прогрівання додатку (завантаження кешу, міграції БД) Pod живий, але не готовий. Liveness → Healthy, Readiness → Unhealthy. Kubernetes чекає, поки прогрів завершиться, і лише тоді починає надсилати трафік.",[3336,3594,3596],{"id":3595},"сценарій-3-моніторинг-і-алерти","Сценарій 3: Моніторинг і алерти",[3312,3598,3599,3600,3602],{},"Health checks інтегруються з системами моніторингу: Prometheus може збирати статус health checks як метрику, Grafana Alerting може надіслати сповіщення коли статус змінився на ",[3347,3601,3349],{},". Це найпростіший і найшвидший спосіб налаштувати базовий алертинг.",[3328,3604],{},[3331,3606,3608],{"id":3607},"архітектура-health-checks-у-aspnet-core","Архітектура Health Checks у ASP.NET Core",[3312,3610,3611,3612,3615,3616,3619],{},"ASP.NET Core має вбудовану підтримку health checks через пакет ",[3347,3613,3614],{},"Microsoft.Extensions.Diagnostics.HealthChecks"," (вже є у .NET 10 без додаткових залежностей) та HTTP middleware з пакету ",[3347,3617,3618],{},"Microsoft.AspNetCore.Diagnostics.HealthChecks",".",[3352,3621,3622],{},[3355,3623,3625],{"className":3357,"code":3624,"language":3359,"meta":3360,"style":3360},"@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\n\nrectangle \"ASP.NET Core Pipeline\" as PIPELINE #f8fafc {\n\n    rectangle \"DI Container\" as DI #dbeafe {\n        rectangle \"IHealthCheckService\" as HCS #bfdbfe\n        rectangle \"HealthCheckRegistration[ ]\" as HCR #bfdbfe\n    }\n\n    rectangle \"Middleware Pipeline\" as MW #d1fae5 {\n        rectangle \"HealthCheckMiddleware\\n(MapHealthChecks)\" as HCM #bbf7d0\n    }\n}\n\nrectangle \"Health Checks\" as CHECKS #fef3c7 {\n    rectangle \"DatabaseHealthCheck\\n: IHealthCheck\" as DHC #fde68a\n    rectangle \"RedisHealthCheck\\n: IHealthCheck\" as RHC #fde68a\n    rectangle \"CustomBusinessCheck\\n: IHealthCheck\" as CHC #fde68a\n}\n\nrectangle \"External Systems\" as EXT #e5e7eb {\n    rectangle \"Load Balancer\\nGET \u002Fhealth\" as LB #f3f4f6\n    rectangle \"Kubernetes\\nliveness\u002Freadiness probes\" as K8S #f3f4f6\n    rectangle \"Prometheus\\nscrape \u002Fhealth\" as PROM #f3f4f6\n}\n\nDI --> HCS : реєструє\nHCR --> HCS : список перевірок\nCHECKS --> HCR : через AddHealthChecks()\nHCM --> HCS : викликає всі checks\nEXT --> HCM : HTTP GET\n\nnote right of HCM\n  Результат: JSON зі статусами\n  або просто 200\u002F503\n  залежно від конфігурації\nend note\n\n@enduml\n",[3347,3626,3627,3631,3635,3639,3643,3648,3652,3657,3662,3667,3672,3676,3681,3686,3690,3694,3698,3703,3708,3713,3718,3722,3726,3731,3736,3741,3746,3750,3754,3759,3764,3769,3774,3779,3783,3788,3794,3800,3806,3811,3816],{"__ignoreMap":3360},[3364,3628,3629],{"class":3366,"line":3367},[3364,3630,3370],{},[3364,3632,3633],{"class":3366,"line":3373},[3364,3634,3376],{},[3364,3636,3637],{"class":3366,"line":3379},[3364,3638,3382],{},[3364,3640,3641],{"class":3366,"line":3385},[3364,3642,3389],{"emptyLinePlaceholder":3388},[3364,3644,3645],{"class":3366,"line":3392},[3364,3646,3647],{},"rectangle \"ASP.NET Core Pipeline\" as PIPELINE #f8fafc {\n",[3364,3649,3650],{"class":3366,"line":3398},[3364,3651,3389],{"emptyLinePlaceholder":3388},[3364,3653,3654],{"class":3366,"line":3403},[3364,3655,3656],{},"    rectangle \"DI Container\" as DI #dbeafe {\n",[3364,3658,3659],{"class":3366,"line":3409},[3364,3660,3661],{},"        rectangle \"IHealthCheckService\" as HCS #bfdbfe\n",[3364,3663,3664],{"class":3366,"line":3414},[3364,3665,3666],{},"        rectangle \"HealthCheckRegistration[ ]\" as HCR #bfdbfe\n",[3364,3668,3669],{"class":3366,"line":3420},[3364,3670,3671],{},"    }\n",[3364,3673,3674],{"class":3366,"line":3426},[3364,3675,3389],{"emptyLinePlaceholder":3388},[3364,3677,3678],{"class":3366,"line":3432},[3364,3679,3680],{},"    rectangle \"Middleware Pipeline\" as MW #d1fae5 {\n",[3364,3682,3683],{"class":3366,"line":3438},[3364,3684,3685],{},"        rectangle \"HealthCheckMiddleware\\n(MapHealthChecks)\" as HCM #bbf7d0\n",[3364,3687,3688],{"class":3366,"line":3444},[3364,3689,3671],{},[3364,3691,3692],{"class":3366,"line":3450},[3364,3693,3453],{},[3364,3695,3696],{"class":3366,"line":3456},[3364,3697,3389],{"emptyLinePlaceholder":3388},[3364,3699,3700],{"class":3366,"line":3461},[3364,3701,3702],{},"rectangle \"Health Checks\" as CHECKS #fef3c7 {\n",[3364,3704,3705],{"class":3366,"line":3467},[3364,3706,3707],{},"    rectangle \"DatabaseHealthCheck\\n: IHealthCheck\" as DHC #fde68a\n",[3364,3709,3710],{"class":3366,"line":3473},[3364,3711,3712],{},"    rectangle \"RedisHealthCheck\\n: IHealthCheck\" as RHC #fde68a\n",[3364,3714,3715],{"class":3366,"line":3479},[3364,3716,3717],{},"    rectangle \"CustomBusinessCheck\\n: IHealthCheck\" as CHC #fde68a\n",[3364,3719,3720],{"class":3366,"line":3485},[3364,3721,3453],{},[3364,3723,3724],{"class":3366,"line":3490},[3364,3725,3389],{"emptyLinePlaceholder":3388},[3364,3727,3728],{"class":3366,"line":3495},[3364,3729,3730],{},"rectangle \"External Systems\" as EXT #e5e7eb {\n",[3364,3732,3733],{"class":3366,"line":3500},[3364,3734,3735],{},"    rectangle \"Load Balancer\\nGET \u002Fhealth\" as LB #f3f4f6\n",[3364,3737,3738],{"class":3366,"line":3505},[3364,3739,3740],{},"    rectangle \"Kubernetes\\nliveness\u002Freadiness probes\" as K8S #f3f4f6\n",[3364,3742,3743],{"class":3366,"line":3511},[3364,3744,3745],{},"    rectangle \"Prometheus\\nscrape \u002Fhealth\" as PROM #f3f4f6\n",[3364,3747,3748],{"class":3366,"line":3517},[3364,3749,3453],{},[3364,3751,3752],{"class":3366,"line":3523},[3364,3753,3389],{"emptyLinePlaceholder":3388},[3364,3755,3756],{"class":3366,"line":3528},[3364,3757,3758],{},"DI --> HCS : реєструє\n",[3364,3760,3761],{"class":3366,"line":3534},[3364,3762,3763],{},"HCR --> HCS : список перевірок\n",[3364,3765,3766],{"class":3366,"line":3540},[3364,3767,3768],{},"CHECKS --> HCR : через AddHealthChecks()\n",[3364,3770,3771],{"class":3366,"line":3546},[3364,3772,3773],{},"HCM --> HCS : викликає всі checks\n",[3364,3775,3776],{"class":3366,"line":3552},[3364,3777,3778],{},"EXT --> HCM : HTTP GET\n",[3364,3780,3781],{"class":3366,"line":3558},[3364,3782,3389],{"emptyLinePlaceholder":3388},[3364,3784,3785],{"class":3366,"line":3563},[3364,3786,3787],{},"note right of HCM\n",[3364,3789,3791],{"class":3366,"line":3790},36,[3364,3792,3793],{},"  Результат: JSON зі статусами\n",[3364,3795,3797],{"class":3366,"line":3796},37,[3364,3798,3799],{},"  або просто 200\u002F503\n",[3364,3801,3803],{"class":3366,"line":3802},38,[3364,3804,3805],{},"  залежно від конфігурації\n",[3364,3807,3809],{"class":3366,"line":3808},39,[3364,3810,3555],{},[3364,3812,3814],{"class":3366,"line":3813},40,[3364,3815,3389],{"emptyLinePlaceholder":3388},[3364,3817,3819],{"class":3366,"line":3818},41,[3364,3820,3566],{},[3312,3822,3823,3824,3827],{},"Центральний інтерфейс — ",[3347,3825,3826],{},"IHealthCheck",":",[3355,3829,3833],{"className":3830,"code":3831,"language":3832,"meta":3360,"style":3360},"language-csharp shiki shiki-themes light-plus dark-plus dark-plus","public interface IHealthCheck\n{\n    Task\u003CHealthCheckResult> CheckHealthAsync(\n        HealthCheckContext context,\n        CancellationToken cancellationToken = default);\n}\n","csharp",[3347,3834,3835,3848,3854,3875,3887,3904],{"__ignoreMap":3360},[3364,3836,3837,3841,3844],{"class":3366,"line":3367},[3364,3838,3840],{"class":3839},"su1O8","public",[3364,3842,3843],{"class":3839}," interface",[3364,3845,3847],{"class":3846},"sN1BT"," IHealthCheck\n",[3364,3849,3850],{"class":3366,"line":3373},[3364,3851,3853],{"class":3852},"sHH4Y","{\n",[3364,3855,3856,3859,3862,3865,3868,3872],{"class":3366,"line":3379},[3364,3857,3858],{"class":3846},"    Task",[3364,3860,3861],{"class":3852},"\u003C",[3364,3863,3864],{"class":3846},"HealthCheckResult",[3364,3866,3867],{"class":3852},"> ",[3364,3869,3871],{"class":3870},"s8Opu","CheckHealthAsync",[3364,3873,3874],{"class":3852},"(\n",[3364,3876,3877,3880,3884],{"class":3366,"line":3385},[3364,3878,3879],{"class":3846},"        HealthCheckContext",[3364,3881,3883],{"class":3882},"siwwj"," context",[3364,3885,3886],{"class":3852},",\n",[3364,3888,3889,3892,3895,3898,3901],{"class":3366,"line":3392},[3364,3890,3891],{"class":3846},"        CancellationToken",[3364,3893,3894],{"class":3882}," cancellationToken",[3364,3896,3897],{"class":3852}," = ",[3364,3899,3900],{"class":3839},"default",[3364,3902,3903],{"class":3852},");\n",[3364,3905,3906],{"class":3366,"line":3398},[3364,3907,3453],{"class":3852},[3312,3909,3910,3911,3913,3914,3916],{},"Метод ",[3347,3912,3871],{}," повертає ",[3347,3915,3864],{}," — одне з трьох значень:",[3918,3919,3920,3930,3938],"field-group",{},[3921,3922,3925,3926,3929],"field",{"name":3923,"type":3924},"HealthCheckResult.Healthy()","HealthStatus.Healthy","Сервіс працює нормально. HTTP відповідь: ",[3347,3927,3928],{},"200 OK",". Балансувальник і Kubernetes продовжують надсилати трафік.",[3921,3931,3934,3935,3937],{"name":3932,"type":3933},"HealthCheckResult.Degraded()","HealthStatus.Degraded","Сервіс функціонує, але з деградацією: підвищена latency, знижена пропускна здатність, non-critical залежність недоступна. HTTP відповідь: ",[3347,3936,3928],{}," (за замовчуванням). Трафік продовжується, але це сигнал для команди.",[3921,3939,3942,3943,3946],{"name":3940,"type":3941},"HealthCheckResult.Unhealthy()","HealthStatus.Unhealthy","Сервіс не здатний нормально обслуговувати запити: критична залежність (БД, черга) недоступна. HTTP відповідь: ",[3347,3944,3945],{},"503 Service Unavailable",". Балансувальник виключає інстанс.",[3328,3948],{},[3331,3950,3952],{"id":3951},"базова-реєстрація-та-перший-health-check","Базова реєстрація та перший health check",[3312,3954,3955],{},"Для початку реєструємо health checks у DI-контейнері та підключаємо middleware:",[3355,3957,3960],{"className":3830,"code":3958,"filename":3959,"language":3832,"meta":3360,"style":3360},"var builder = WebApplication.CreateBuilder(args);\n\n\u002F\u002F Крок 1: реєструємо сервіси health checks у DI\nbuilder.Services.AddHealthChecks();\n\nvar app = builder.Build();\n\n\u002F\u002F Крок 2: підключаємо middleware — додаємо ендпоінт \u002Fhealth\napp.MapHealthChecks(\"\u002Fhealth\");\n\napp.Run();\n","Program.cs",[3347,3961,3962,3988,3992,3998,4016,4020,4038,4042,4047,4065,4069],{"__ignoreMap":3360},[3364,3963,3964,3967,3970,3972,3975,3977,3980,3983,3986],{"class":3366,"line":3367},[3364,3965,3966],{"class":3839},"var",[3364,3968,3969],{"class":3882}," builder",[3364,3971,3897],{"class":3852},[3364,3973,3974],{"class":3882},"WebApplication",[3364,3976,3619],{"class":3852},[3364,3978,3979],{"class":3870},"CreateBuilder",[3364,3981,3982],{"class":3852},"(",[3364,3984,3985],{"class":3882},"args",[3364,3987,3903],{"class":3852},[3364,3989,3990],{"class":3366,"line":3373},[3364,3991,3389],{"emptyLinePlaceholder":3388},[3364,3993,3994],{"class":3366,"line":3379},[3364,3995,3997],{"class":3996},"spJ8K","\u002F\u002F Крок 1: реєструємо сервіси health checks у DI\n",[3364,3999,4000,4003,4005,4008,4010,4013],{"class":3366,"line":3385},[3364,4001,4002],{"class":3882},"builder",[3364,4004,3619],{"class":3852},[3364,4006,4007],{"class":3882},"Services",[3364,4009,3619],{"class":3852},[3364,4011,4012],{"class":3870},"AddHealthChecks",[3364,4014,4015],{"class":3852},"();\n",[3364,4017,4018],{"class":3366,"line":3392},[3364,4019,3389],{"emptyLinePlaceholder":3388},[3364,4021,4022,4024,4027,4029,4031,4033,4036],{"class":3366,"line":3398},[3364,4023,3966],{"class":3839},[3364,4025,4026],{"class":3882}," app",[3364,4028,3897],{"class":3852},[3364,4030,4002],{"class":3882},[3364,4032,3619],{"class":3852},[3364,4034,4035],{"class":3870},"Build",[3364,4037,4015],{"class":3852},[3364,4039,4040],{"class":3366,"line":3403},[3364,4041,3389],{"emptyLinePlaceholder":3388},[3364,4043,4044],{"class":3366,"line":3409},[3364,4045,4046],{"class":3996},"\u002F\u002F Крок 2: підключаємо middleware — додаємо ендпоінт \u002Fhealth\n",[3364,4048,4049,4052,4054,4057,4059,4063],{"class":3366,"line":3414},[3364,4050,4051],{"class":3882},"app",[3364,4053,3619],{"class":3852},[3364,4055,4056],{"class":3870},"MapHealthChecks",[3364,4058,3982],{"class":3852},[3364,4060,4062],{"class":4061},"sbdoH","\"\u002Fhealth\"",[3364,4064,3903],{"class":3852},[3364,4066,4067],{"class":3366,"line":3420},[3364,4068,3389],{"emptyLinePlaceholder":3388},[3364,4070,4071,4073,4075,4078],{"class":3366,"line":3426},[3364,4072,4051],{"class":3882},[3364,4074,3619],{"class":3852},[3364,4076,4077],{"class":3870},"Run",[3364,4079,4015],{"class":3852},[3312,4081,4082,4083,4086,4087,4089,4090,4093],{},"Запустіть і перевірте: ",[3347,4084,4085],{},"GET \u002Fhealth"," поверне ",[3347,4088,3928],{}," з тілом ",[3347,4091,4092],{},"Healthy",". Але це перевірка «нічого» — лише факт того, що процес живий.",[4095,4096,4098,4111,4119,4123,4126],"terminal-preview",{"title":4097},"curl \u002Fhealth",[4099,4100,4102,4107,4108],"div",{"className":4101},[3366],[3364,4103,4106],{"className":4104},[4105],"opacity-40","$"," ",[3316,4109,4110],{},"curl -i http:\u002F\u002Flocalhost:5000\u002Fhealth",[4099,4112,4114,4115],{"className":4113},[3366],"HTTP\u002F1.1 ",[3364,4116,3928],{"className":4117},[4118],"text-green-400",[4099,4120,4122],{"className":4121},[3366],"Content-Type: text\u002Fplain",[4099,4124],{"className":4125},[3366],[4099,4127,4129],{"className":4128},[3366],[3364,4130,4092],{"className":4131},[4118],[3312,4133,4134,4135,3827],{},"Щоб отримати детальну JSON-відповідь з інформацією про кожну перевірку, налаштуємо ",[3347,4136,4137],{},"ResponseWriter",[3355,4139,4141],{"className":3830,"code":4140,"filename":3959,"language":3832,"meta":3360,"style":3360},"using Microsoft.AspNetCore.Diagnostics.HealthChecks;\nusing Microsoft.Extensions.Diagnostics.HealthChecks;\nusing System.Text.Json;\n\napp.MapHealthChecks(\"\u002Fhealth\", new HealthCheckOptions\n{\n    ResponseWriter = async (context, report) =>\n    {\n        context.Response.ContentType = \"application\u002Fjson\";\n\n        var result = JsonSerializer.Serialize(new\n        {\n            status = report.Status.ToString(),\n            duration = report.TotalDuration.TotalMilliseconds,\n            checks = report.Entries.Select(e => new\n            {\n                name = e.Key,\n                status = e.Value.Status.ToString(),\n                description = e.Value.Description,\n                duration = e.Value.Duration.TotalMilliseconds,\n                exception = e.Value.Exception?.Message\n            })\n        }, new JsonSerializerOptions { WriteIndented = true });\n\n        await context.Response.WriteAsync(result);\n    }\n});\n",[3347,4142,4143,4170,4191,4210,4214,4235,4239,4263,4268,4290,4294,4317,4322,4344,4365,4394,4399,4415,4439,4459,4483,4507,4512,4536,4540,4563,4567],{"__ignoreMap":3360},[3364,4144,4145,4149,4152,4154,4157,4159,4162,4164,4167],{"class":3366,"line":3367},[3364,4146,4148],{"class":4147},"s8xlr","using",[3364,4150,4151],{"class":3846}," Microsoft",[3364,4153,3619],{"class":3852},[3364,4155,4156],{"class":3846},"AspNetCore",[3364,4158,3619],{"class":3852},[3364,4160,4161],{"class":3846},"Diagnostics",[3364,4163,3619],{"class":3852},[3364,4165,4166],{"class":3846},"HealthChecks",[3364,4168,4169],{"class":3852},";\n",[3364,4171,4172,4174,4176,4178,4181,4183,4185,4187,4189],{"class":3366,"line":3373},[3364,4173,4148],{"class":4147},[3364,4175,4151],{"class":3846},[3364,4177,3619],{"class":3852},[3364,4179,4180],{"class":3846},"Extensions",[3364,4182,3619],{"class":3852},[3364,4184,4161],{"class":3846},[3364,4186,3619],{"class":3852},[3364,4188,4166],{"class":3846},[3364,4190,4169],{"class":3852},[3364,4192,4193,4195,4198,4200,4203,4205,4208],{"class":3366,"line":3379},[3364,4194,4148],{"class":4147},[3364,4196,4197],{"class":3846}," System",[3364,4199,3619],{"class":3852},[3364,4201,4202],{"class":3846},"Text",[3364,4204,3619],{"class":3852},[3364,4206,4207],{"class":3846},"Json",[3364,4209,4169],{"class":3852},[3364,4211,4212],{"class":3366,"line":3385},[3364,4213,3389],{"emptyLinePlaceholder":3388},[3364,4215,4216,4218,4220,4222,4224,4226,4229,4232],{"class":3366,"line":3392},[3364,4217,4051],{"class":3882},[3364,4219,3619],{"class":3852},[3364,4221,4056],{"class":3870},[3364,4223,3982],{"class":3852},[3364,4225,4062],{"class":4061},[3364,4227,4228],{"class":3852},", ",[3364,4230,4231],{"class":3839},"new",[3364,4233,4234],{"class":3846}," HealthCheckOptions\n",[3364,4236,4237],{"class":3366,"line":3398},[3364,4238,3853],{"class":3852},[3364,4240,4241,4244,4246,4249,4252,4255,4257,4260],{"class":3366,"line":3403},[3364,4242,4243],{"class":3882},"    ResponseWriter",[3364,4245,3897],{"class":3852},[3364,4247,4248],{"class":3839},"async",[3364,4250,4251],{"class":3852}," (",[3364,4253,4254],{"class":3882},"context",[3364,4256,4228],{"class":3852},[3364,4258,4259],{"class":3882},"report",[3364,4261,4262],{"class":3852},") =>\n",[3364,4264,4265],{"class":3366,"line":3409},[3364,4266,4267],{"class":3852},"    {\n",[3364,4269,4270,4273,4275,4278,4280,4283,4285,4288],{"class":3366,"line":3414},[3364,4271,4272],{"class":3882},"        context",[3364,4274,3619],{"class":3852},[3364,4276,4277],{"class":3882},"Response",[3364,4279,3619],{"class":3852},[3364,4281,4282],{"class":3882},"ContentType",[3364,4284,3897],{"class":3852},[3364,4286,4287],{"class":4061},"\"application\u002Fjson\"",[3364,4289,4169],{"class":3852},[3364,4291,4292],{"class":3366,"line":3420},[3364,4293,3389],{"emptyLinePlaceholder":3388},[3364,4295,4296,4299,4302,4304,4307,4309,4312,4314],{"class":3366,"line":3426},[3364,4297,4298],{"class":3839},"        var",[3364,4300,4301],{"class":3882}," result",[3364,4303,3897],{"class":3852},[3364,4305,4306],{"class":3882},"JsonSerializer",[3364,4308,3619],{"class":3852},[3364,4310,4311],{"class":3870},"Serialize",[3364,4313,3982],{"class":3852},[3364,4315,4316],{"class":3839},"new\n",[3364,4318,4319],{"class":3366,"line":3432},[3364,4320,4321],{"class":3852},"        {\n",[3364,4323,4324,4327,4329,4331,4333,4336,4338,4341],{"class":3366,"line":3438},[3364,4325,4326],{"class":3882},"            status",[3364,4328,3897],{"class":3852},[3364,4330,4259],{"class":3882},[3364,4332,3619],{"class":3852},[3364,4334,4335],{"class":3882},"Status",[3364,4337,3619],{"class":3852},[3364,4339,4340],{"class":3870},"ToString",[3364,4342,4343],{"class":3852},"(),\n",[3364,4345,4346,4349,4351,4353,4355,4358,4360,4363],{"class":3366,"line":3444},[3364,4347,4348],{"class":3882},"            duration",[3364,4350,3897],{"class":3852},[3364,4352,4259],{"class":3882},[3364,4354,3619],{"class":3852},[3364,4356,4357],{"class":3882},"TotalDuration",[3364,4359,3619],{"class":3852},[3364,4361,4362],{"class":3882},"TotalMilliseconds",[3364,4364,3886],{"class":3852},[3364,4366,4367,4370,4372,4374,4376,4379,4381,4384,4386,4389,4392],{"class":3366,"line":3450},[3364,4368,4369],{"class":3882},"            checks",[3364,4371,3897],{"class":3852},[3364,4373,4259],{"class":3882},[3364,4375,3619],{"class":3852},[3364,4377,4378],{"class":3882},"Entries",[3364,4380,3619],{"class":3852},[3364,4382,4383],{"class":3870},"Select",[3364,4385,3982],{"class":3852},[3364,4387,4388],{"class":3882},"e",[3364,4390,4391],{"class":3852}," => ",[3364,4393,4316],{"class":3839},[3364,4395,4396],{"class":3366,"line":3456},[3364,4397,4398],{"class":3852},"            {\n",[3364,4400,4401,4404,4406,4408,4410,4413],{"class":3366,"line":3461},[3364,4402,4403],{"class":3882},"                name",[3364,4405,3897],{"class":3852},[3364,4407,4388],{"class":3882},[3364,4409,3619],{"class":3852},[3364,4411,4412],{"class":3882},"Key",[3364,4414,3886],{"class":3852},[3364,4416,4417,4420,4422,4424,4426,4429,4431,4433,4435,4437],{"class":3366,"line":3467},[3364,4418,4419],{"class":3882},"                status",[3364,4421,3897],{"class":3852},[3364,4423,4388],{"class":3882},[3364,4425,3619],{"class":3852},[3364,4427,4428],{"class":3882},"Value",[3364,4430,3619],{"class":3852},[3364,4432,4335],{"class":3882},[3364,4434,3619],{"class":3852},[3364,4436,4340],{"class":3870},[3364,4438,4343],{"class":3852},[3364,4440,4441,4444,4446,4448,4450,4452,4454,4457],{"class":3366,"line":3473},[3364,4442,4443],{"class":3882},"                description",[3364,4445,3897],{"class":3852},[3364,4447,4388],{"class":3882},[3364,4449,3619],{"class":3852},[3364,4451,4428],{"class":3882},[3364,4453,3619],{"class":3852},[3364,4455,4456],{"class":3882},"Description",[3364,4458,3886],{"class":3852},[3364,4460,4461,4464,4466,4468,4470,4472,4474,4477,4479,4481],{"class":3366,"line":3479},[3364,4462,4463],{"class":3882},"                duration",[3364,4465,3897],{"class":3852},[3364,4467,4388],{"class":3882},[3364,4469,3619],{"class":3852},[3364,4471,4428],{"class":3882},[3364,4473,3619],{"class":3852},[3364,4475,4476],{"class":3882},"Duration",[3364,4478,3619],{"class":3852},[3364,4480,4362],{"class":3882},[3364,4482,3886],{"class":3852},[3364,4484,4485,4488,4490,4492,4494,4496,4498,4501,4504],{"class":3366,"line":3485},[3364,4486,4487],{"class":3882},"                exception",[3364,4489,3897],{"class":3852},[3364,4491,4388],{"class":3882},[3364,4493,3619],{"class":3852},[3364,4495,4428],{"class":3882},[3364,4497,3619],{"class":3852},[3364,4499,4500],{"class":3882},"Exception",[3364,4502,4503],{"class":3852},"?.",[3364,4505,4506],{"class":3882},"Message\n",[3364,4508,4509],{"class":3366,"line":3490},[3364,4510,4511],{"class":3852},"            })\n",[3364,4513,4514,4517,4519,4522,4525,4528,4530,4533],{"class":3366,"line":3495},[3364,4515,4516],{"class":3852},"        }, ",[3364,4518,4231],{"class":3839},[3364,4520,4521],{"class":3846}," JsonSerializerOptions",[3364,4523,4524],{"class":3852}," { ",[3364,4526,4527],{"class":3882},"WriteIndented",[3364,4529,3897],{"class":3852},[3364,4531,4532],{"class":3839},"true",[3364,4534,4535],{"class":3852}," });\n",[3364,4537,4538],{"class":3366,"line":3500},[3364,4539,3389],{"emptyLinePlaceholder":3388},[3364,4541,4542,4545,4547,4549,4551,4553,4556,4558,4561],{"class":3366,"line":3505},[3364,4543,4544],{"class":3839},"        await",[3364,4546,3883],{"class":3882},[3364,4548,3619],{"class":3852},[3364,4550,4277],{"class":3882},[3364,4552,3619],{"class":3852},[3364,4554,4555],{"class":3870},"WriteAsync",[3364,4557,3982],{"class":3852},[3364,4559,4560],{"class":3882},"result",[3364,4562,3903],{"class":3852},[3364,4564,4565],{"class":3366,"line":3511},[3364,4566,3671],{"class":3852},[3364,4568,4569],{"class":3366,"line":3517},[3364,4570,4571],{"class":3852},"});\n",[4095,4573,4575,4584,4588,4603,4615,4623],{"title":4574},"curl \u002Fhealth (JSON format)",[4099,4576,4578,4107,4581],{"className":4577},[3366],[3364,4579,4106],{"className":4580},[4105],[3316,4582,4583],{},"curl http:\u002F\u002Flocalhost:5000\u002Fhealth | jq",[4099,4585,4587],{"className":4586},[3366],"{",[4099,4589,4591,4592,4597,4598,4602],{"className":4590},[3366],"  ",[3364,4593,4596],{"className":4594},[4595],"text-blue-400","\"status\"",": ",[3364,4599,4601],{"className":4600},[4118],"\"Healthy\"",",",[4099,4604,4591,4606,4597,4610,4602],{"className":4605},[3366],[3364,4607,4609],{"className":4608},[4595],"\"duration\"",[3364,4611,4614],{"className":4612},[4613],"text-yellow-400","12.4",[4099,4616,4591,4618,4622],{"className":4617},[3366],[3364,4619,4621],{"className":4620},[4595],"\"checks\"",": []",[4099,4624,4626],{"className":4625},[3366],"}",[3328,4628],{},[3331,4630,4632,4633,4635],{"id":4631},"кастомний-ihealthcheck-перевірка-бази-даних","Кастомний ",[3347,4634,3826],{},": перевірка бази даних",[3312,4637,4638,4639,4641],{},"Найважливіший health check для більшості додатків — перевірка підключення до бази даних. Реалізуємо його вручну через ",[3347,4640,3826],{},", щоб зрозуміти механізм зсередини:",[3355,4643,4646],{"className":3830,"code":4644,"filename":4645,"language":3832,"meta":3360,"style":3360},"using Microsoft.Extensions.Diagnostics.HealthChecks;\nusing Microsoft.Data.SqlClient;\n\npublic class DatabaseHealthCheck : IHealthCheck\n{\n    private readonly IConfiguration _configuration;\n\n    public DatabaseHealthCheck(IConfiguration configuration)\n    {\n        _configuration = configuration;\n    }\n\n    public async Task\u003CHealthCheckResult> CheckHealthAsync(\n        HealthCheckContext context,\n        CancellationToken cancellationToken = default)\n    {\n        var connectionString = _configuration.GetConnectionString(\"Default\");\n\n        try\n        {\n            await using var connection = new SqlConnection(connectionString);\n\n            \u002F\u002F Відкриваємо з'єднання та виконуємо мінімальний запит\n            await connection.OpenAsync(cancellationToken);\n            await using var command = connection.CreateCommand();\n            command.CommandText = \"SELECT 1\";\n            await command.ExecuteScalarAsync(cancellationToken);\n\n            return HealthCheckResult.Healthy(\"Database connection is OK\");\n        }\n        catch (SqlException ex) when (ex.Number == -2) \u002F\u002F timeout\n        {\n            return HealthCheckResult.Degraded(\n                \"Database responds slowly — connection timeout\",\n                exception: ex);\n        }\n        catch (Exception ex)\n        {\n            return HealthCheckResult.Unhealthy(\n                \"Database is unreachable\",\n                exception: ex);\n        }\n    }\n}\n","HealthChecks\u002FDatabaseHealthCheck.cs",[3347,4647,4648,4668,4686,4690,4706,4710,4726,4730,4748,4752,4764,4768,4772,4792,4800,4812,4816,4840,4844,4849,4853,4881,4885,4890,4908,4931,4948,4965,4969,4988,4993,5034,5038,5051,5058,5068,5072,5084,5088,5100,5107,5117,5122,5127],{"__ignoreMap":3360},[3364,4649,4650,4652,4654,4656,4658,4660,4662,4664,4666],{"class":3366,"line":3367},[3364,4651,4148],{"class":4147},[3364,4653,4151],{"class":3846},[3364,4655,3619],{"class":3852},[3364,4657,4180],{"class":3846},[3364,4659,3619],{"class":3852},[3364,4661,4161],{"class":3846},[3364,4663,3619],{"class":3852},[3364,4665,4166],{"class":3846},[3364,4667,4169],{"class":3852},[3364,4669,4670,4672,4674,4676,4679,4681,4684],{"class":3366,"line":3373},[3364,4671,4148],{"class":4147},[3364,4673,4151],{"class":3846},[3364,4675,3619],{"class":3852},[3364,4677,4678],{"class":3846},"Data",[3364,4680,3619],{"class":3852},[3364,4682,4683],{"class":3846},"SqlClient",[3364,4685,4169],{"class":3852},[3364,4687,4688],{"class":3366,"line":3379},[3364,4689,3389],{"emptyLinePlaceholder":3388},[3364,4691,4692,4694,4697,4700,4703],{"class":3366,"line":3385},[3364,4693,3840],{"class":3839},[3364,4695,4696],{"class":3839}," class",[3364,4698,4699],{"class":3846}," DatabaseHealthCheck",[3364,4701,4702],{"class":3852}," : ",[3364,4704,4705],{"class":3846},"IHealthCheck\n",[3364,4707,4708],{"class":3366,"line":3392},[3364,4709,3853],{"class":3852},[3364,4711,4712,4715,4718,4721,4724],{"class":3366,"line":3398},[3364,4713,4714],{"class":3839},"    private",[3364,4716,4717],{"class":3839}," readonly",[3364,4719,4720],{"class":3846}," IConfiguration",[3364,4722,4723],{"class":3882}," _configuration",[3364,4725,4169],{"class":3852},[3364,4727,4728],{"class":3366,"line":3403},[3364,4729,3389],{"emptyLinePlaceholder":3388},[3364,4731,4732,4735,4737,4739,4742,4745],{"class":3366,"line":3409},[3364,4733,4734],{"class":3839},"    public",[3364,4736,4699],{"class":3870},[3364,4738,3982],{"class":3852},[3364,4740,4741],{"class":3846},"IConfiguration",[3364,4743,4744],{"class":3882}," configuration",[3364,4746,4747],{"class":3852},")\n",[3364,4749,4750],{"class":3366,"line":3414},[3364,4751,4267],{"class":3852},[3364,4753,4754,4757,4759,4762],{"class":3366,"line":3420},[3364,4755,4756],{"class":3882},"        _configuration",[3364,4758,3897],{"class":3852},[3364,4760,4761],{"class":3882},"configuration",[3364,4763,4169],{"class":3852},[3364,4765,4766],{"class":3366,"line":3426},[3364,4767,3671],{"class":3852},[3364,4769,4770],{"class":3366,"line":3432},[3364,4771,3389],{"emptyLinePlaceholder":3388},[3364,4773,4774,4776,4779,4782,4784,4786,4788,4790],{"class":3366,"line":3438},[3364,4775,4734],{"class":3839},[3364,4777,4778],{"class":3839}," async",[3364,4780,4781],{"class":3846}," Task",[3364,4783,3861],{"class":3852},[3364,4785,3864],{"class":3846},[3364,4787,3867],{"class":3852},[3364,4789,3871],{"class":3870},[3364,4791,3874],{"class":3852},[3364,4793,4794,4796,4798],{"class":3366,"line":3444},[3364,4795,3879],{"class":3846},[3364,4797,3883],{"class":3882},[3364,4799,3886],{"class":3852},[3364,4801,4802,4804,4806,4808,4810],{"class":3366,"line":3450},[3364,4803,3891],{"class":3846},[3364,4805,3894],{"class":3882},[3364,4807,3897],{"class":3852},[3364,4809,3900],{"class":3839},[3364,4811,4747],{"class":3852},[3364,4813,4814],{"class":3366,"line":3456},[3364,4815,4267],{"class":3852},[3364,4817,4818,4820,4823,4825,4828,4830,4833,4835,4838],{"class":3366,"line":3461},[3364,4819,4298],{"class":3839},[3364,4821,4822],{"class":3882}," connectionString",[3364,4824,3897],{"class":3852},[3364,4826,4827],{"class":3882},"_configuration",[3364,4829,3619],{"class":3852},[3364,4831,4832],{"class":3870},"GetConnectionString",[3364,4834,3982],{"class":3852},[3364,4836,4837],{"class":4061},"\"Default\"",[3364,4839,3903],{"class":3852},[3364,4841,4842],{"class":3366,"line":3467},[3364,4843,3389],{"emptyLinePlaceholder":3388},[3364,4845,4846],{"class":3366,"line":3473},[3364,4847,4848],{"class":4147},"        try\n",[3364,4850,4851],{"class":3366,"line":3479},[3364,4852,4321],{"class":3852},[3364,4854,4855,4858,4861,4864,4867,4869,4871,4874,4876,4879],{"class":3366,"line":3485},[3364,4856,4857],{"class":3839},"            await",[3364,4859,4860],{"class":4147}," using",[3364,4862,4863],{"class":3839}," var",[3364,4865,4866],{"class":3882}," connection",[3364,4868,3897],{"class":3852},[3364,4870,4231],{"class":3839},[3364,4872,4873],{"class":3846}," SqlConnection",[3364,4875,3982],{"class":3852},[3364,4877,4878],{"class":3882},"connectionString",[3364,4880,3903],{"class":3852},[3364,4882,4883],{"class":3366,"line":3490},[3364,4884,3389],{"emptyLinePlaceholder":3388},[3364,4886,4887],{"class":3366,"line":3495},[3364,4888,4889],{"class":3996},"            \u002F\u002F Відкриваємо з'єднання та виконуємо мінімальний запит\n",[3364,4891,4892,4894,4896,4898,4901,4903,4906],{"class":3366,"line":3500},[3364,4893,4857],{"class":3839},[3364,4895,4866],{"class":3882},[3364,4897,3619],{"class":3852},[3364,4899,4900],{"class":3870},"OpenAsync",[3364,4902,3982],{"class":3852},[3364,4904,4905],{"class":3882},"cancellationToken",[3364,4907,3903],{"class":3852},[3364,4909,4910,4912,4914,4916,4919,4921,4924,4926,4929],{"class":3366,"line":3505},[3364,4911,4857],{"class":3839},[3364,4913,4860],{"class":4147},[3364,4915,4863],{"class":3839},[3364,4917,4918],{"class":3882}," command",[3364,4920,3897],{"class":3852},[3364,4922,4923],{"class":3882},"connection",[3364,4925,3619],{"class":3852},[3364,4927,4928],{"class":3870},"CreateCommand",[3364,4930,4015],{"class":3852},[3364,4932,4933,4936,4938,4941,4943,4946],{"class":3366,"line":3511},[3364,4934,4935],{"class":3882},"            command",[3364,4937,3619],{"class":3852},[3364,4939,4940],{"class":3882},"CommandText",[3364,4942,3897],{"class":3852},[3364,4944,4945],{"class":4061},"\"SELECT 1\"",[3364,4947,4169],{"class":3852},[3364,4949,4950,4952,4954,4956,4959,4961,4963],{"class":3366,"line":3517},[3364,4951,4857],{"class":3839},[3364,4953,4918],{"class":3882},[3364,4955,3619],{"class":3852},[3364,4957,4958],{"class":3870},"ExecuteScalarAsync",[3364,4960,3982],{"class":3852},[3364,4962,4905],{"class":3882},[3364,4964,3903],{"class":3852},[3364,4966,4967],{"class":3366,"line":3523},[3364,4968,3389],{"emptyLinePlaceholder":3388},[3364,4970,4971,4974,4977,4979,4981,4983,4986],{"class":3366,"line":3528},[3364,4972,4973],{"class":4147},"            return",[3364,4975,4976],{"class":3882}," HealthCheckResult",[3364,4978,3619],{"class":3852},[3364,4980,4092],{"class":3870},[3364,4982,3982],{"class":3852},[3364,4984,4985],{"class":4061},"\"Database connection is OK\"",[3364,4987,3903],{"class":3852},[3364,4989,4990],{"class":3366,"line":3534},[3364,4991,4992],{"class":3852},"        }\n",[3364,4994,4995,4998,5000,5003,5006,5009,5012,5014,5017,5019,5022,5025,5029,5031],{"class":3366,"line":3540},[3364,4996,4997],{"class":4147},"        catch",[3364,4999,4251],{"class":3852},[3364,5001,5002],{"class":3846},"SqlException",[3364,5004,5005],{"class":3882}," ex",[3364,5007,5008],{"class":3852},") ",[3364,5010,5011],{"class":4147},"when",[3364,5013,4251],{"class":3852},[3364,5015,5016],{"class":3882},"ex",[3364,5018,3619],{"class":3852},[3364,5020,5021],{"class":3882},"Number",[3364,5023,5024],{"class":3852}," == -",[3364,5026,5028],{"class":5027},"sJj4R","2",[3364,5030,5008],{"class":3852},[3364,5032,5033],{"class":3996},"\u002F\u002F timeout\n",[3364,5035,5036],{"class":3366,"line":3546},[3364,5037,4321],{"class":3852},[3364,5039,5040,5042,5044,5046,5049],{"class":3366,"line":3552},[3364,5041,4973],{"class":4147},[3364,5043,4976],{"class":3882},[3364,5045,3619],{"class":3852},[3364,5047,5048],{"class":3870},"Degraded",[3364,5050,3874],{"class":3852},[3364,5052,5053,5056],{"class":3366,"line":3558},[3364,5054,5055],{"class":4061},"                \"Database responds slowly — connection timeout\"",[3364,5057,3886],{"class":3852},[3364,5059,5060,5062,5064,5066],{"class":3366,"line":3563},[3364,5061,4487],{"class":3882},[3364,5063,4597],{"class":3852},[3364,5065,5016],{"class":3882},[3364,5067,3903],{"class":3852},[3364,5069,5070],{"class":3366,"line":3790},[3364,5071,4992],{"class":3852},[3364,5073,5074,5076,5078,5080,5082],{"class":3366,"line":3796},[3364,5075,4997],{"class":4147},[3364,5077,4251],{"class":3852},[3364,5079,4500],{"class":3846},[3364,5081,5005],{"class":3882},[3364,5083,4747],{"class":3852},[3364,5085,5086],{"class":3366,"line":3802},[3364,5087,4321],{"class":3852},[3364,5089,5090,5092,5094,5096,5098],{"class":3366,"line":3808},[3364,5091,4973],{"class":4147},[3364,5093,4976],{"class":3882},[3364,5095,3619],{"class":3852},[3364,5097,3349],{"class":3870},[3364,5099,3874],{"class":3852},[3364,5101,5102,5105],{"class":3366,"line":3813},[3364,5103,5104],{"class":4061},"                \"Database is unreachable\"",[3364,5106,3886],{"class":3852},[3364,5108,5109,5111,5113,5115],{"class":3366,"line":3818},[3364,5110,4487],{"class":3882},[3364,5112,4597],{"class":3852},[3364,5114,5016],{"class":3882},[3364,5116,3903],{"class":3852},[3364,5118,5120],{"class":3366,"line":5119},42,[3364,5121,4992],{"class":3852},[3364,5123,5125],{"class":3366,"line":5124},43,[3364,5126,3671],{"class":3852},[3364,5128,5130],{"class":3366,"line":5129},44,[3364,5131,3453],{"class":3852},[3312,5133,5134,5135,3827],{},"Реєстрація у ",[3347,5136,3959],{},[3355,5138,5140],{"className":3830,"code":5139,"filename":3959,"language":3832,"meta":3360,"style":3360},"builder.Services.AddHealthChecks()\n    .AddCheck\u003CDatabaseHealthCheck>(\"database\", tags: [\"db\", \"critical\"]);\n",[3347,5141,5142,5157],{"__ignoreMap":3360},[3364,5143,5144,5146,5148,5150,5152,5154],{"class":3366,"line":3367},[3364,5145,4002],{"class":3882},[3364,5147,3619],{"class":3852},[3364,5149,4007],{"class":3882},[3364,5151,3619],{"class":3852},[3364,5153,4012],{"class":3870},[3364,5155,5156],{"class":3852},"()\n",[3364,5158,5159,5162,5165,5167,5170,5173,5176,5178,5181,5184,5187,5189,5192],{"class":3366,"line":3373},[3364,5160,5161],{"class":3852},"    .",[3364,5163,5164],{"class":3870},"AddCheck",[3364,5166,3861],{"class":3852},[3364,5168,5169],{"class":3846},"DatabaseHealthCheck",[3364,5171,5172],{"class":3852},">(",[3364,5174,5175],{"class":4061},"\"database\"",[3364,5177,4228],{"class":3852},[3364,5179,5180],{"class":3882},"tags",[3364,5182,5183],{"class":3852},": [",[3364,5185,5186],{"class":4061},"\"db\"",[3364,5188,4228],{"class":3852},[3364,5190,5191],{"class":4061},"\"critical\"",[3364,5193,5194],{"class":3852},"]);\n",[5196,5197,5198,5199,5201,5202,5205,5206,5209,5210,3619],"note",{},"Параметр ",[3347,5200,5180],{}," — це мітки для групування перевірок. Пізніше побачимо, як виводити тільки ",[3347,5203,5204],{},"critical"," checks на ендпоінті ",[3347,5207,5208],{},"\u002Fhealth\u002Flive",", а всі — на ",[3347,5211,5212],{},"\u002Fhealth\u002Fready",[3312,5214,5215],{},"Тепер відповідь стає змістовнішою:",[4095,5217,5219,5227,5230,5239,5249,5255,5259,5270,5279,5289,5299,5311,5315,5319],{"title":5218},"curl \u002Fhealth з DatabaseHealthCheck",[4099,5220,5222,4107,5225],{"className":5221},[3366],[3364,5223,4106],{"className":5224},[4105],[3316,5226,4583],{},[4099,5228,4587],{"className":5229},[3366],[4099,5231,4591,5233,4597,5236,4602],{"className":5232},[3366],[3364,5234,4596],{"className":5235},[4595],[3364,5237,4601],{"className":5238},[4118],[4099,5240,4591,5242,4597,5245,4602],{"className":5241},[3366],[3364,5243,4609],{"className":5244},[4595],[3364,5246,5248],{"className":5247},[4613],"24.7",[4099,5250,4591,5252,5183],{"className":5251},[3366],[3364,5253,4621],{"className":5254},[4595],[4099,5256,5258],{"className":5257},[3366],"    {",[4099,5260,5262,5263,4597,5267,4602],{"className":5261},[3366],"      ",[3364,5264,5266],{"className":5265},[4595],"\"name\"",[3364,5268,5175],{"className":5269},[4118],[4099,5271,5262,5273,4597,5276,4602],{"className":5272},[3366],[3364,5274,4596],{"className":5275},[4595],[3364,5277,4601],{"className":5278},[4118],[4099,5280,5262,5282,4597,5286,4602],{"className":5281},[3366],[3364,5283,5285],{"className":5284},[4595],"\"description\"",[3364,5287,4985],{"className":5288},[4118],[4099,5290,5262,5292,4597,5295,4602],{"className":5291},[3366],[3364,5293,4609],{"className":5294},[4595],[3364,5296,5298],{"className":5297},[4613],"23.1",[4099,5300,5262,5302,4597,5306],{"className":5301},[3366],[3364,5303,5305],{"className":5304},[4595],"\"exception\"",[3364,5307,5310],{"className":5308},[5309],"text-gray-400","null",[4099,5312,5314],{"className":5313},[3366],"    }",[4099,5316,5318],{"className":5317},[3366],"  ]",[4099,5320,4626],{"className":5321},[3366],[3328,5323],{},[3331,5325,5327,5328,5330],{"id":5326},"кастомна-перевірка-памяті-degraded-у-дії","Кастомна перевірка пам'яті: ",[3347,5329,5048],{}," у дії",[3312,5332,5333],{},"Не всі проблеми бінарні. Підвищене споживання пам'яті — це ще не катастрофа, але сигнал тривоги. Реалізуємо check з трьома рівнями:",[3355,5335,5338],{"className":3830,"code":5336,"filename":5337,"language":3832,"meta":3360,"style":3360},"using Microsoft.Extensions.Diagnostics.HealthChecks;\n\npublic class MemoryHealthCheck : IHealthCheck\n{\n    \u002F\u002F Пороги конфігуруємо ззовні — не хардкодимо\n    private readonly long _degradedThresholdBytes;\n    private readonly long _unhealthyThresholdBytes;\n\n    public MemoryHealthCheck(IConfiguration configuration)\n    {\n        \u002F\u002F За замовчуванням: Degraded > 512 MB, Unhealthy > 1 GB\n        _degradedThresholdBytes = configuration\n            .GetValue\u003Clong>(\"HealthChecks:Memory:DegradedMB\", 512) * 1024 * 1024;\n        _unhealthyThresholdBytes = configuration\n            .GetValue\u003Clong>(\"HealthChecks:Memory:UnhealthyMB\", 1024) * 1024 * 1024;\n    }\n\n    public Task\u003CHealthCheckResult> CheckHealthAsync(\n        HealthCheckContext context,\n        CancellationToken cancellationToken = default)\n    {\n        var allocated = GC.GetTotalMemory(forceFullCollection: false);\n        var data = new Dictionary\u003Cstring, object>\n        {\n            [\"allocated_bytes\"] = allocated,\n            [\"allocated_mb\"] = allocated \u002F 1024 \u002F 1024,\n            [\"gen0_collections\"] = GC.CollectionCount(0),\n            [\"gen1_collections\"] = GC.CollectionCount(1),\n            [\"gen2_collections\"] = GC.CollectionCount(2),\n        };\n\n        if (allocated >= _unhealthyThresholdBytes)\n            return Task.FromResult(HealthCheckResult.Unhealthy(\n                $\"Memory usage critical: {allocated \u002F 1024 \u002F 1024} MB\", data: data));\n\n        if (allocated >= _degradedThresholdBytes)\n            return Task.FromResult(HealthCheckResult.Degraded(\n                $\"Memory usage elevated: {allocated \u002F 1024 \u002F 1024} MB\", data: data));\n\n        return Task.FromResult(HealthCheckResult.Healthy(\n            $\"Memory usage normal: {allocated \u002F 1024 \u002F 1024} MB\", data: data));\n    }\n}\n","HealthChecks\u002FMemoryHealthCheck.cs",[3347,5339,5340,5360,5364,5377,5381,5386,5400,5413,5417,5431,5435,5440,5450,5486,5495,5524,5528,5532,5548,5556,5568,5572,5601,5628,5632,5648,5670,5694,5716,5737,5742,5746,5763,5784,5821,5825,5840,5860,5891,5895,5916,5947,5951],{"__ignoreMap":3360},[3364,5341,5342,5344,5346,5348,5350,5352,5354,5356,5358],{"class":3366,"line":3367},[3364,5343,4148],{"class":4147},[3364,5345,4151],{"class":3846},[3364,5347,3619],{"class":3852},[3364,5349,4180],{"class":3846},[3364,5351,3619],{"class":3852},[3364,5353,4161],{"class":3846},[3364,5355,3619],{"class":3852},[3364,5357,4166],{"class":3846},[3364,5359,4169],{"class":3852},[3364,5361,5362],{"class":3366,"line":3373},[3364,5363,3389],{"emptyLinePlaceholder":3388},[3364,5365,5366,5368,5370,5373,5375],{"class":3366,"line":3379},[3364,5367,3840],{"class":3839},[3364,5369,4696],{"class":3839},[3364,5371,5372],{"class":3846}," MemoryHealthCheck",[3364,5374,4702],{"class":3852},[3364,5376,4705],{"class":3846},[3364,5378,5379],{"class":3366,"line":3385},[3364,5380,3853],{"class":3852},[3364,5382,5383],{"class":3366,"line":3392},[3364,5384,5385],{"class":3996},"    \u002F\u002F Пороги конфігуруємо ззовні — не хардкодимо\n",[3364,5387,5388,5390,5392,5395,5398],{"class":3366,"line":3398},[3364,5389,4714],{"class":3839},[3364,5391,4717],{"class":3839},[3364,5393,5394],{"class":3839}," long",[3364,5396,5397],{"class":3882}," _degradedThresholdBytes",[3364,5399,4169],{"class":3852},[3364,5401,5402,5404,5406,5408,5411],{"class":3366,"line":3403},[3364,5403,4714],{"class":3839},[3364,5405,4717],{"class":3839},[3364,5407,5394],{"class":3839},[3364,5409,5410],{"class":3882}," _unhealthyThresholdBytes",[3364,5412,4169],{"class":3852},[3364,5414,5415],{"class":3366,"line":3409},[3364,5416,3389],{"emptyLinePlaceholder":3388},[3364,5418,5419,5421,5423,5425,5427,5429],{"class":3366,"line":3414},[3364,5420,4734],{"class":3839},[3364,5422,5372],{"class":3870},[3364,5424,3982],{"class":3852},[3364,5426,4741],{"class":3846},[3364,5428,4744],{"class":3882},[3364,5430,4747],{"class":3852},[3364,5432,5433],{"class":3366,"line":3420},[3364,5434,4267],{"class":3852},[3364,5436,5437],{"class":3366,"line":3426},[3364,5438,5439],{"class":3996},"        \u002F\u002F За замовчуванням: Degraded > 512 MB, Unhealthy > 1 GB\n",[3364,5441,5442,5445,5447],{"class":3366,"line":3432},[3364,5443,5444],{"class":3882},"        _degradedThresholdBytes",[3364,5446,3897],{"class":3852},[3364,5448,5449],{"class":3882},"configuration\n",[3364,5451,5452,5455,5458,5460,5463,5465,5468,5470,5473,5476,5479,5482,5484],{"class":3366,"line":3438},[3364,5453,5454],{"class":3852},"            .",[3364,5456,5457],{"class":3870},"GetValue",[3364,5459,3861],{"class":3852},[3364,5461,5462],{"class":3839},"long",[3364,5464,5172],{"class":3852},[3364,5466,5467],{"class":4061},"\"HealthChecks:Memory:DegradedMB\"",[3364,5469,4228],{"class":3852},[3364,5471,5472],{"class":5027},"512",[3364,5474,5475],{"class":3852},") * ",[3364,5477,5478],{"class":5027},"1024",[3364,5480,5481],{"class":3852}," * ",[3364,5483,5478],{"class":5027},[3364,5485,4169],{"class":3852},[3364,5487,5488,5491,5493],{"class":3366,"line":3444},[3364,5489,5490],{"class":3882},"        _unhealthyThresholdBytes",[3364,5492,3897],{"class":3852},[3364,5494,5449],{"class":3882},[3364,5496,5497,5499,5501,5503,5505,5507,5510,5512,5514,5516,5518,5520,5522],{"class":3366,"line":3450},[3364,5498,5454],{"class":3852},[3364,5500,5457],{"class":3870},[3364,5502,3861],{"class":3852},[3364,5504,5462],{"class":3839},[3364,5506,5172],{"class":3852},[3364,5508,5509],{"class":4061},"\"HealthChecks:Memory:UnhealthyMB\"",[3364,5511,4228],{"class":3852},[3364,5513,5478],{"class":5027},[3364,5515,5475],{"class":3852},[3364,5517,5478],{"class":5027},[3364,5519,5481],{"class":3852},[3364,5521,5478],{"class":5027},[3364,5523,4169],{"class":3852},[3364,5525,5526],{"class":3366,"line":3456},[3364,5527,3671],{"class":3852},[3364,5529,5530],{"class":3366,"line":3461},[3364,5531,3389],{"emptyLinePlaceholder":3388},[3364,5533,5534,5536,5538,5540,5542,5544,5546],{"class":3366,"line":3467},[3364,5535,4734],{"class":3839},[3364,5537,4781],{"class":3846},[3364,5539,3861],{"class":3852},[3364,5541,3864],{"class":3846},[3364,5543,3867],{"class":3852},[3364,5545,3871],{"class":3870},[3364,5547,3874],{"class":3852},[3364,5549,5550,5552,5554],{"class":3366,"line":3473},[3364,5551,3879],{"class":3846},[3364,5553,3883],{"class":3882},[3364,5555,3886],{"class":3852},[3364,5557,5558,5560,5562,5564,5566],{"class":3366,"line":3479},[3364,5559,3891],{"class":3846},[3364,5561,3894],{"class":3882},[3364,5563,3897],{"class":3852},[3364,5565,3900],{"class":3839},[3364,5567,4747],{"class":3852},[3364,5569,5570],{"class":3366,"line":3485},[3364,5571,4267],{"class":3852},[3364,5573,5574,5576,5579,5581,5584,5586,5589,5591,5594,5596,5599],{"class":3366,"line":3490},[3364,5575,4298],{"class":3839},[3364,5577,5578],{"class":3882}," allocated",[3364,5580,3897],{"class":3852},[3364,5582,5583],{"class":3882},"GC",[3364,5585,3619],{"class":3852},[3364,5587,5588],{"class":3870},"GetTotalMemory",[3364,5590,3982],{"class":3852},[3364,5592,5593],{"class":3882},"forceFullCollection",[3364,5595,4597],{"class":3852},[3364,5597,5598],{"class":3839},"false",[3364,5600,3903],{"class":3852},[3364,5602,5603,5605,5608,5610,5612,5615,5617,5620,5622,5625],{"class":3366,"line":3495},[3364,5604,4298],{"class":3839},[3364,5606,5607],{"class":3882}," data",[3364,5609,3897],{"class":3852},[3364,5611,4231],{"class":3839},[3364,5613,5614],{"class":3846}," Dictionary",[3364,5616,3861],{"class":3852},[3364,5618,5619],{"class":3839},"string",[3364,5621,4228],{"class":3852},[3364,5623,5624],{"class":3839},"object",[3364,5626,5627],{"class":3852},">\n",[3364,5629,5630],{"class":3366,"line":3500},[3364,5631,4321],{"class":3852},[3364,5633,5634,5637,5640,5643,5646],{"class":3366,"line":3505},[3364,5635,5636],{"class":3852},"            [",[3364,5638,5639],{"class":4061},"\"allocated_bytes\"",[3364,5641,5642],{"class":3852},"] = ",[3364,5644,5645],{"class":3882},"allocated",[3364,5647,3886],{"class":3852},[3364,5649,5650,5652,5655,5657,5659,5662,5664,5666,5668],{"class":3366,"line":3511},[3364,5651,5636],{"class":3852},[3364,5653,5654],{"class":4061},"\"allocated_mb\"",[3364,5656,5642],{"class":3852},[3364,5658,5645],{"class":3882},[3364,5660,5661],{"class":3852}," \u002F ",[3364,5663,5478],{"class":5027},[3364,5665,5661],{"class":3852},[3364,5667,5478],{"class":5027},[3364,5669,3886],{"class":3852},[3364,5671,5672,5674,5677,5679,5681,5683,5686,5688,5691],{"class":3366,"line":3517},[3364,5673,5636],{"class":3852},[3364,5675,5676],{"class":4061},"\"gen0_collections\"",[3364,5678,5642],{"class":3852},[3364,5680,5583],{"class":3882},[3364,5682,3619],{"class":3852},[3364,5684,5685],{"class":3870},"CollectionCount",[3364,5687,3982],{"class":3852},[3364,5689,5690],{"class":5027},"0",[3364,5692,5693],{"class":3852},"),\n",[3364,5695,5696,5698,5701,5703,5705,5707,5709,5711,5714],{"class":3366,"line":3523},[3364,5697,5636],{"class":3852},[3364,5699,5700],{"class":4061},"\"gen1_collections\"",[3364,5702,5642],{"class":3852},[3364,5704,5583],{"class":3882},[3364,5706,3619],{"class":3852},[3364,5708,5685],{"class":3870},[3364,5710,3982],{"class":3852},[3364,5712,5713],{"class":5027},"1",[3364,5715,5693],{"class":3852},[3364,5717,5718,5720,5723,5725,5727,5729,5731,5733,5735],{"class":3366,"line":3528},[3364,5719,5636],{"class":3852},[3364,5721,5722],{"class":4061},"\"gen2_collections\"",[3364,5724,5642],{"class":3852},[3364,5726,5583],{"class":3882},[3364,5728,3619],{"class":3852},[3364,5730,5685],{"class":3870},[3364,5732,3982],{"class":3852},[3364,5734,5028],{"class":5027},[3364,5736,5693],{"class":3852},[3364,5738,5739],{"class":3366,"line":3534},[3364,5740,5741],{"class":3852},"        };\n",[3364,5743,5744],{"class":3366,"line":3540},[3364,5745,3389],{"emptyLinePlaceholder":3388},[3364,5747,5748,5751,5753,5755,5758,5761],{"class":3366,"line":3546},[3364,5749,5750],{"class":4147},"        if",[3364,5752,4251],{"class":3852},[3364,5754,5645],{"class":3882},[3364,5756,5757],{"class":3852}," >= ",[3364,5759,5760],{"class":3882},"_unhealthyThresholdBytes",[3364,5762,4747],{"class":3852},[3364,5764,5765,5767,5769,5771,5774,5776,5778,5780,5782],{"class":3366,"line":3552},[3364,5766,4973],{"class":4147},[3364,5768,4781],{"class":3882},[3364,5770,3619],{"class":3852},[3364,5772,5773],{"class":3870},"FromResult",[3364,5775,3982],{"class":3852},[3364,5777,3864],{"class":3882},[3364,5779,3619],{"class":3852},[3364,5781,3349],{"class":3870},[3364,5783,3874],{"class":3852},[3364,5785,5786,5789,5792,5794,5797,5800,5802,5804,5806,5809,5811,5814,5816,5818],{"class":3366,"line":3558},[3364,5787,5788],{"class":4061},"                $\"Memory usage critical: ",[3364,5790,4587],{"class":5791},"sD7JJ",[3364,5793,5645],{"class":3882},[3364,5795,5796],{"class":3852}," \u002F",[3364,5798,5799],{"class":5027}," 1024",[3364,5801,5796],{"class":3852},[3364,5803,5799],{"class":5027},[3364,5805,4626],{"class":5791},[3364,5807,5808],{"class":4061}," MB\"",[3364,5810,4228],{"class":3852},[3364,5812,5813],{"class":3882},"data",[3364,5815,4597],{"class":3852},[3364,5817,5813],{"class":3882},[3364,5819,5820],{"class":3852},"));\n",[3364,5822,5823],{"class":3366,"line":3563},[3364,5824,3389],{"emptyLinePlaceholder":3388},[3364,5826,5827,5829,5831,5833,5835,5838],{"class":3366,"line":3790},[3364,5828,5750],{"class":4147},[3364,5830,4251],{"class":3852},[3364,5832,5645],{"class":3882},[3364,5834,5757],{"class":3852},[3364,5836,5837],{"class":3882},"_degradedThresholdBytes",[3364,5839,4747],{"class":3852},[3364,5841,5842,5844,5846,5848,5850,5852,5854,5856,5858],{"class":3366,"line":3796},[3364,5843,4973],{"class":4147},[3364,5845,4781],{"class":3882},[3364,5847,3619],{"class":3852},[3364,5849,5773],{"class":3870},[3364,5851,3982],{"class":3852},[3364,5853,3864],{"class":3882},[3364,5855,3619],{"class":3852},[3364,5857,5048],{"class":3870},[3364,5859,3874],{"class":3852},[3364,5861,5862,5865,5867,5869,5871,5873,5875,5877,5879,5881,5883,5885,5887,5889],{"class":3366,"line":3802},[3364,5863,5864],{"class":4061},"                $\"Memory usage elevated: ",[3364,5866,4587],{"class":5791},[3364,5868,5645],{"class":3882},[3364,5870,5796],{"class":3852},[3364,5872,5799],{"class":5027},[3364,5874,5796],{"class":3852},[3364,5876,5799],{"class":5027},[3364,5878,4626],{"class":5791},[3364,5880,5808],{"class":4061},[3364,5882,4228],{"class":3852},[3364,5884,5813],{"class":3882},[3364,5886,4597],{"class":3852},[3364,5888,5813],{"class":3882},[3364,5890,5820],{"class":3852},[3364,5892,5893],{"class":3366,"line":3808},[3364,5894,3389],{"emptyLinePlaceholder":3388},[3364,5896,5897,5900,5902,5904,5906,5908,5910,5912,5914],{"class":3366,"line":3813},[3364,5898,5899],{"class":4147},"        return",[3364,5901,4781],{"class":3882},[3364,5903,3619],{"class":3852},[3364,5905,5773],{"class":3870},[3364,5907,3982],{"class":3852},[3364,5909,3864],{"class":3882},[3364,5911,3619],{"class":3852},[3364,5913,4092],{"class":3870},[3364,5915,3874],{"class":3852},[3364,5917,5918,5921,5923,5925,5927,5929,5931,5933,5935,5937,5939,5941,5943,5945],{"class":3366,"line":3818},[3364,5919,5920],{"class":4061},"            $\"Memory usage normal: ",[3364,5922,4587],{"class":5791},[3364,5924,5645],{"class":3882},[3364,5926,5796],{"class":3852},[3364,5928,5799],{"class":5027},[3364,5930,5796],{"class":3852},[3364,5932,5799],{"class":5027},[3364,5934,4626],{"class":5791},[3364,5936,5808],{"class":4061},[3364,5938,4228],{"class":3852},[3364,5940,5813],{"class":3882},[3364,5942,4597],{"class":3852},[3364,5944,5813],{"class":3882},[3364,5946,5820],{"class":3852},[3364,5948,5949],{"class":3366,"line":5119},[3364,5950,3671],{"class":3852},[3364,5952,5953],{"class":3366,"line":5124},[3364,5954,3453],{"class":3852},[3312,5956,5957,5958,5960],{},"Зверніть увагу на параметр ",[3347,5959,5813],{}," — словник додаткових даних, що повертається разом з результатом. Ці дані з'являться у JSON-відповіді health check ендпоінту і доступні в UI.",[3328,5962],{},[3331,5964,5966,5967],{"id":5965},"community-бібліотека-aspnetcorehealthchecks","Community-бібліотека: ",[3347,5968,5969],{},"AspNetCore.HealthChecks.*",[3312,5971,5972,5973,5975,5976,5979],{},"Писати ",[3347,5974,3826],{}," вручну для кожної залежності — рутина. Спільнота створила набір готових перевірок: ",[3316,5977,5978],{},"AspNetCore.HealthChecks"," (автор: Xabaril). Це набір окремих NuGet-пакетів, по одному на кожну технологію:",[3355,5981,5986],{"className":5982,"code":5983,"filename":5984,"language":5985,"meta":3360,"style":3360},"language-xml shiki shiki-themes light-plus dark-plus dark-plus","\u003CPackageReference Include=\"AspNetCore.HealthChecks.SqlServer\" Version=\"8.*\" \u002F>\n\u003CPackageReference Include=\"AspNetCore.HealthChecks.Redis\" Version=\"8.*\" \u002F>\n\u003CPackageReference Include=\"AspNetCore.HealthChecks.RabbitMQ\" Version=\"8.*\" \u002F>\n\u003CPackageReference Include=\"AspNetCore.HealthChecks.Npgsql\" Version=\"8.*\" \u002F>\n\u003CPackageReference Include=\"AspNetCore.HealthChecks.Uris\" Version=\"8.*\" \u002F>\n\u003CPackageReference Include=\"AspNetCore.HealthChecks.UI\" Version=\"8.*\" \u002F>\n\u003CPackageReference Include=\"AspNetCore.HealthChecks.UI.Client\" Version=\"8.*\" \u002F>\n\u003CPackageReference Include=\"AspNetCore.HealthChecks.UI.InMemory.Storage\" Version=\"8.*\" \u002F>\n","MyApi.csproj","xml",[3347,5987,5988,6019,6040,6061,6082,6103,6124,6145],{"__ignoreMap":3360},[3364,5989,5990,5993,5997,6001,6004,6008,6011,6013,6016],{"class":3366,"line":3367},[3364,5991,3861],{"class":5992},"s0P7L",[3364,5994,5996],{"class":5995},"sKtos","PackageReference",[3364,5998,6000],{"class":5999},"sa4r_"," Include",[3364,6002,6003],{"class":3852},"=",[3364,6005,6007],{"class":6006},"su9tN","\"AspNetCore.HealthChecks.SqlServer\"",[3364,6009,6010],{"class":5999}," Version",[3364,6012,6003],{"class":3852},[3364,6014,6015],{"class":6006},"\"8.*\"",[3364,6017,6018],{"class":5992}," \u002F>\n",[3364,6020,6021,6023,6025,6027,6029,6032,6034,6036,6038],{"class":3366,"line":3373},[3364,6022,3861],{"class":5992},[3364,6024,5996],{"class":5995},[3364,6026,6000],{"class":5999},[3364,6028,6003],{"class":3852},[3364,6030,6031],{"class":6006},"\"AspNetCore.HealthChecks.Redis\"",[3364,6033,6010],{"class":5999},[3364,6035,6003],{"class":3852},[3364,6037,6015],{"class":6006},[3364,6039,6018],{"class":5992},[3364,6041,6042,6044,6046,6048,6050,6053,6055,6057,6059],{"class":3366,"line":3379},[3364,6043,3861],{"class":5992},[3364,6045,5996],{"class":5995},[3364,6047,6000],{"class":5999},[3364,6049,6003],{"class":3852},[3364,6051,6052],{"class":6006},"\"AspNetCore.HealthChecks.RabbitMQ\"",[3364,6054,6010],{"class":5999},[3364,6056,6003],{"class":3852},[3364,6058,6015],{"class":6006},[3364,6060,6018],{"class":5992},[3364,6062,6063,6065,6067,6069,6071,6074,6076,6078,6080],{"class":3366,"line":3385},[3364,6064,3861],{"class":5992},[3364,6066,5996],{"class":5995},[3364,6068,6000],{"class":5999},[3364,6070,6003],{"class":3852},[3364,6072,6073],{"class":6006},"\"AspNetCore.HealthChecks.Npgsql\"",[3364,6075,6010],{"class":5999},[3364,6077,6003],{"class":3852},[3364,6079,6015],{"class":6006},[3364,6081,6018],{"class":5992},[3364,6083,6084,6086,6088,6090,6092,6095,6097,6099,6101],{"class":3366,"line":3392},[3364,6085,3861],{"class":5992},[3364,6087,5996],{"class":5995},[3364,6089,6000],{"class":5999},[3364,6091,6003],{"class":3852},[3364,6093,6094],{"class":6006},"\"AspNetCore.HealthChecks.Uris\"",[3364,6096,6010],{"class":5999},[3364,6098,6003],{"class":3852},[3364,6100,6015],{"class":6006},[3364,6102,6018],{"class":5992},[3364,6104,6105,6107,6109,6111,6113,6116,6118,6120,6122],{"class":3366,"line":3398},[3364,6106,3861],{"class":5992},[3364,6108,5996],{"class":5995},[3364,6110,6000],{"class":5999},[3364,6112,6003],{"class":3852},[3364,6114,6115],{"class":6006},"\"AspNetCore.HealthChecks.UI\"",[3364,6117,6010],{"class":5999},[3364,6119,6003],{"class":3852},[3364,6121,6015],{"class":6006},[3364,6123,6018],{"class":5992},[3364,6125,6126,6128,6130,6132,6134,6137,6139,6141,6143],{"class":3366,"line":3403},[3364,6127,3861],{"class":5992},[3364,6129,5996],{"class":5995},[3364,6131,6000],{"class":5999},[3364,6133,6003],{"class":3852},[3364,6135,6136],{"class":6006},"\"AspNetCore.HealthChecks.UI.Client\"",[3364,6138,6010],{"class":5999},[3364,6140,6003],{"class":3852},[3364,6142,6015],{"class":6006},[3364,6144,6018],{"class":5992},[3364,6146,6147,6149,6151,6153,6155,6158,6160,6162,6164],{"class":3366,"line":3409},[3364,6148,3861],{"class":5992},[3364,6150,5996],{"class":5995},[3364,6152,6000],{"class":5999},[3364,6154,6003],{"class":3852},[3364,6156,6157],{"class":6006},"\"AspNetCore.HealthChecks.UI.InMemory.Storage\"",[3364,6159,6010],{"class":5999},[3364,6161,6003],{"class":3852},[3364,6163,6015],{"class":6006},[3364,6165,6018],{"class":5992},[5196,6167,6168,6169,6172,6173,3619],{},"Версія ",[3347,6170,6171],{},"8.*"," сумісна з .NET 8, 9 та 10 — бібліотека не прив'язана до конкретного runtime, лише до ",[3347,6174,6175],{},"Microsoft.AspNetCore.App",[3312,6177,6178],{},"Після встановлення реєстрація стає декларативною:",[3355,6180,6182],{"className":3830,"code":6181,"filename":3959,"language":3832,"meta":3360,"style":3360},"builder.Services.AddHealthChecks()\n    \u002F\u002F SQL Server: виконує SELECT 1 проти вашої БД\n    .AddSqlServer(\n        connectionString: builder.Configuration.GetConnectionString(\"Default\")!,\n        name: \"sql-server\",\n        tags: [\"db\", \"critical\"])\n\n    \u002F\u002F PostgreSQL (якщо використовуєте Npgsql)\n    .AddNpgsql(\n        connectionString: builder.Configuration.GetConnectionString(\"Postgres\")!,\n        name: \"postgres\",\n        tags: [\"db\", \"critical\"])\n\n    \u002F\u002F Redis: PING команда\n    .AddRedis(\n        redisConnectionString: builder.Configuration.GetConnectionString(\"Redis\")!,\n        name: \"redis\",\n        tags: [\"cache\"])\n\n    \u002F\u002F RabbitMQ: перевірка стану connection\n    .AddRabbitMQ(\n        rabbitConnectionString: builder.Configuration.GetConnectionString(\"RabbitMQ\")!,\n        name: \"rabbitmq\",\n        tags: [\"messaging\"])\n\n    \u002F\u002F Зовнішній HTTP ендпоінт: GET та перевірка статус-коду\n    .AddUrlGroup(\n        uri: new Uri(\"https:\u002F\u002Fapi.stripe.com\u002Fv1\u002F\"),\n        name: \"stripe-api\",\n        tags: [\"external\"])\n\n    \u002F\u002F Наш власний check пам'яті\n    .AddCheck\u003CMemoryHealthCheck>(\"memory\", tags: [\"system\"]);\n",[3347,6183,6184,6198,6203,6212,6237,6249,6265,6269,6274,6283,6306,6317,6331,6335,6340,6349,6373,6384,6395,6399,6404,6413,6437,6448,6459,6463,6468,6477,6496,6507,6518,6522,6527],{"__ignoreMap":3360},[3364,6185,6186,6188,6190,6192,6194,6196],{"class":3366,"line":3367},[3364,6187,4002],{"class":3882},[3364,6189,3619],{"class":3852},[3364,6191,4007],{"class":3882},[3364,6193,3619],{"class":3852},[3364,6195,4012],{"class":3870},[3364,6197,5156],{"class":3852},[3364,6199,6200],{"class":3366,"line":3373},[3364,6201,6202],{"class":3996},"    \u002F\u002F SQL Server: виконує SELECT 1 проти вашої БД\n",[3364,6204,6205,6207,6210],{"class":3366,"line":3379},[3364,6206,5161],{"class":3852},[3364,6208,6209],{"class":3870},"AddSqlServer",[3364,6211,3874],{"class":3852},[3364,6213,6214,6217,6219,6221,6223,6226,6228,6230,6232,6234],{"class":3366,"line":3385},[3364,6215,6216],{"class":3882},"        connectionString",[3364,6218,4597],{"class":3852},[3364,6220,4002],{"class":3882},[3364,6222,3619],{"class":3852},[3364,6224,6225],{"class":3882},"Configuration",[3364,6227,3619],{"class":3852},[3364,6229,4832],{"class":3870},[3364,6231,3982],{"class":3852},[3364,6233,4837],{"class":4061},[3364,6235,6236],{"class":3852},")!,\n",[3364,6238,6239,6242,6244,6247],{"class":3366,"line":3392},[3364,6240,6241],{"class":3882},"        name",[3364,6243,4597],{"class":3852},[3364,6245,6246],{"class":4061},"\"sql-server\"",[3364,6248,3886],{"class":3852},[3364,6250,6251,6254,6256,6258,6260,6262],{"class":3366,"line":3398},[3364,6252,6253],{"class":3882},"        tags",[3364,6255,5183],{"class":3852},[3364,6257,5186],{"class":4061},[3364,6259,4228],{"class":3852},[3364,6261,5191],{"class":4061},[3364,6263,6264],{"class":3852},"])\n",[3364,6266,6267],{"class":3366,"line":3403},[3364,6268,3389],{"emptyLinePlaceholder":3388},[3364,6270,6271],{"class":3366,"line":3409},[3364,6272,6273],{"class":3996},"    \u002F\u002F PostgreSQL (якщо використовуєте Npgsql)\n",[3364,6275,6276,6278,6281],{"class":3366,"line":3414},[3364,6277,5161],{"class":3852},[3364,6279,6280],{"class":3870},"AddNpgsql",[3364,6282,3874],{"class":3852},[3364,6284,6285,6287,6289,6291,6293,6295,6297,6299,6301,6304],{"class":3366,"line":3420},[3364,6286,6216],{"class":3882},[3364,6288,4597],{"class":3852},[3364,6290,4002],{"class":3882},[3364,6292,3619],{"class":3852},[3364,6294,6225],{"class":3882},[3364,6296,3619],{"class":3852},[3364,6298,4832],{"class":3870},[3364,6300,3982],{"class":3852},[3364,6302,6303],{"class":4061},"\"Postgres\"",[3364,6305,6236],{"class":3852},[3364,6307,6308,6310,6312,6315],{"class":3366,"line":3426},[3364,6309,6241],{"class":3882},[3364,6311,4597],{"class":3852},[3364,6313,6314],{"class":4061},"\"postgres\"",[3364,6316,3886],{"class":3852},[3364,6318,6319,6321,6323,6325,6327,6329],{"class":3366,"line":3432},[3364,6320,6253],{"class":3882},[3364,6322,5183],{"class":3852},[3364,6324,5186],{"class":4061},[3364,6326,4228],{"class":3852},[3364,6328,5191],{"class":4061},[3364,6330,6264],{"class":3852},[3364,6332,6333],{"class":3366,"line":3438},[3364,6334,3389],{"emptyLinePlaceholder":3388},[3364,6336,6337],{"class":3366,"line":3444},[3364,6338,6339],{"class":3996},"    \u002F\u002F Redis: PING команда\n",[3364,6341,6342,6344,6347],{"class":3366,"line":3450},[3364,6343,5161],{"class":3852},[3364,6345,6346],{"class":3870},"AddRedis",[3364,6348,3874],{"class":3852},[3364,6350,6351,6354,6356,6358,6360,6362,6364,6366,6368,6371],{"class":3366,"line":3456},[3364,6352,6353],{"class":3882},"        redisConnectionString",[3364,6355,4597],{"class":3852},[3364,6357,4002],{"class":3882},[3364,6359,3619],{"class":3852},[3364,6361,6225],{"class":3882},[3364,6363,3619],{"class":3852},[3364,6365,4832],{"class":3870},[3364,6367,3982],{"class":3852},[3364,6369,6370],{"class":4061},"\"Redis\"",[3364,6372,6236],{"class":3852},[3364,6374,6375,6377,6379,6382],{"class":3366,"line":3461},[3364,6376,6241],{"class":3882},[3364,6378,4597],{"class":3852},[3364,6380,6381],{"class":4061},"\"redis\"",[3364,6383,3886],{"class":3852},[3364,6385,6386,6388,6390,6393],{"class":3366,"line":3467},[3364,6387,6253],{"class":3882},[3364,6389,5183],{"class":3852},[3364,6391,6392],{"class":4061},"\"cache\"",[3364,6394,6264],{"class":3852},[3364,6396,6397],{"class":3366,"line":3473},[3364,6398,3389],{"emptyLinePlaceholder":3388},[3364,6400,6401],{"class":3366,"line":3479},[3364,6402,6403],{"class":3996},"    \u002F\u002F RabbitMQ: перевірка стану connection\n",[3364,6405,6406,6408,6411],{"class":3366,"line":3485},[3364,6407,5161],{"class":3852},[3364,6409,6410],{"class":3870},"AddRabbitMQ",[3364,6412,3874],{"class":3852},[3364,6414,6415,6418,6420,6422,6424,6426,6428,6430,6432,6435],{"class":3366,"line":3490},[3364,6416,6417],{"class":3882},"        rabbitConnectionString",[3364,6419,4597],{"class":3852},[3364,6421,4002],{"class":3882},[3364,6423,3619],{"class":3852},[3364,6425,6225],{"class":3882},[3364,6427,3619],{"class":3852},[3364,6429,4832],{"class":3870},[3364,6431,3982],{"class":3852},[3364,6433,6434],{"class":4061},"\"RabbitMQ\"",[3364,6436,6236],{"class":3852},[3364,6438,6439,6441,6443,6446],{"class":3366,"line":3495},[3364,6440,6241],{"class":3882},[3364,6442,4597],{"class":3852},[3364,6444,6445],{"class":4061},"\"rabbitmq\"",[3364,6447,3886],{"class":3852},[3364,6449,6450,6452,6454,6457],{"class":3366,"line":3500},[3364,6451,6253],{"class":3882},[3364,6453,5183],{"class":3852},[3364,6455,6456],{"class":4061},"\"messaging\"",[3364,6458,6264],{"class":3852},[3364,6460,6461],{"class":3366,"line":3505},[3364,6462,3389],{"emptyLinePlaceholder":3388},[3364,6464,6465],{"class":3366,"line":3511},[3364,6466,6467],{"class":3996},"    \u002F\u002F Зовнішній HTTP ендпоінт: GET та перевірка статус-коду\n",[3364,6469,6470,6472,6475],{"class":3366,"line":3517},[3364,6471,5161],{"class":3852},[3364,6473,6474],{"class":3870},"AddUrlGroup",[3364,6476,3874],{"class":3852},[3364,6478,6479,6482,6484,6486,6489,6491,6494],{"class":3366,"line":3523},[3364,6480,6481],{"class":3882},"        uri",[3364,6483,4597],{"class":3852},[3364,6485,4231],{"class":3839},[3364,6487,6488],{"class":3846}," Uri",[3364,6490,3982],{"class":3852},[3364,6492,6493],{"class":4061},"\"https:\u002F\u002Fapi.stripe.com\u002Fv1\u002F\"",[3364,6495,5693],{"class":3852},[3364,6497,6498,6500,6502,6505],{"class":3366,"line":3528},[3364,6499,6241],{"class":3882},[3364,6501,4597],{"class":3852},[3364,6503,6504],{"class":4061},"\"stripe-api\"",[3364,6506,3886],{"class":3852},[3364,6508,6509,6511,6513,6516],{"class":3366,"line":3534},[3364,6510,6253],{"class":3882},[3364,6512,5183],{"class":3852},[3364,6514,6515],{"class":4061},"\"external\"",[3364,6517,6264],{"class":3852},[3364,6519,6520],{"class":3366,"line":3540},[3364,6521,3389],{"emptyLinePlaceholder":3388},[3364,6523,6524],{"class":3366,"line":3546},[3364,6525,6526],{"class":3996},"    \u002F\u002F Наш власний check пам'яті\n",[3364,6528,6529,6531,6533,6535,6538,6540,6543,6545,6547,6549,6552],{"class":3366,"line":3552},[3364,6530,5161],{"class":3852},[3364,6532,5164],{"class":3870},[3364,6534,3861],{"class":3852},[3364,6536,6537],{"class":3846},"MemoryHealthCheck",[3364,6539,5172],{"class":3852},[3364,6541,6542],{"class":4061},"\"memory\"",[3364,6544,4228],{"class":3852},[3364,6546,5180],{"class":3882},[3364,6548,5183],{"class":3852},[3364,6550,6551],{"class":4061},"\"system\"",[3364,6553,5194],{"class":3852},[6555,6556,6557,6558,6561],"tip",{},"Завжди визначайте ",[3347,6559,6560],{},"name"," явно — це ім'я з'явиться у JSON-відповіді та HealthCheckUI. Без явного імені використовується ім'я типу, що ускладнює читання.",[3328,6563],{},[3331,6565,6567],{"id":6566},"liveness-та-readiness-патерн-для-kubernetes-і-docker","Liveness та Readiness: патерн для Kubernetes і Docker",[3312,6569,6570,6571,6574],{},"Один ендпоінт ",[3347,6572,6573],{},"\u002Fhealth"," — це добре для початку, але недостатньо для production. Kubernetes (і Docker Healthcheck) розрізняють два типи перевірок, і вони мають принципово різну семантику.",[3352,6576,6577],{},[3355,6578,6580],{"className":3357,"code":6579,"language":3359,"meta":3360,"style":3360},"@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\n\ntitle \"Liveness vs Readiness: різна семантика\"\n\nrectangle \"Kubernetes Pod\" as POD #f8fafc {\n\n    rectangle \"Liveness Probe\\nGET \u002Fhealth\u002Flive\" as LIVE #dbeafe {\n        note as NL\n          Питання: \"Чи живий процес?\"\n          Відповідь Unhealthy → **KILL + RESTART**\n\n          Що перевіряємо:\n          • Процес не застряг у deadlock\n          • Немає infinite loop\n          • Базові ресурси доступні\n          (не зовнішні залежності!)\n        end note\n    }\n\n    rectangle \"Readiness Probe\\nGET \u002Fhealth\u002Fready\" as READY #d1fae5 {\n        note as NR\n          Питання: \"Чи готовий до трафіку?\"\n          Відповідь Unhealthy → **виключити з Service**\n          (Pod залишається живим)\n\n          Що перевіряємо:\n          • БД доступна\n          • Redis доступний\n          • Кеш прогрітий\n          • Зовнішні API відповідають\n        end note\n    }\n}\n\nrectangle \"Kubernetes Service\" as SVC #bbf7d0\n\nPOD --> SVC : трафік лише якщо\\nReadiness = Healthy\nLIVE ..> POD : failure → restart\n\n@enduml\n",[3347,6581,6582,6586,6590,6594,6598,6603,6607,6612,6616,6621,6626,6631,6636,6640,6645,6650,6655,6660,6665,6670,6674,6678,6683,6688,6693,6698,6703,6707,6711,6716,6721,6726,6731,6735,6739,6743,6747,6752,6756,6761,6766,6770],{"__ignoreMap":3360},[3364,6583,6584],{"class":3366,"line":3367},[3364,6585,3370],{},[3364,6587,6588],{"class":3366,"line":3373},[3364,6589,3376],{},[3364,6591,6592],{"class":3366,"line":3379},[3364,6593,3382],{},[3364,6595,6596],{"class":3366,"line":3385},[3364,6597,3389],{"emptyLinePlaceholder":3388},[3364,6599,6600],{"class":3366,"line":3392},[3364,6601,6602],{},"title \"Liveness vs Readiness: різна семантика\"\n",[3364,6604,6605],{"class":3366,"line":3398},[3364,6606,3389],{"emptyLinePlaceholder":3388},[3364,6608,6609],{"class":3366,"line":3403},[3364,6610,6611],{},"rectangle \"Kubernetes Pod\" as POD #f8fafc {\n",[3364,6613,6614],{"class":3366,"line":3409},[3364,6615,3389],{"emptyLinePlaceholder":3388},[3364,6617,6618],{"class":3366,"line":3414},[3364,6619,6620],{},"    rectangle \"Liveness Probe\\nGET \u002Fhealth\u002Flive\" as LIVE #dbeafe {\n",[3364,6622,6623],{"class":3366,"line":3420},[3364,6624,6625],{},"        note as NL\n",[3364,6627,6628],{"class":3366,"line":3426},[3364,6629,6630],{},"          Питання: \"Чи живий процес?\"\n",[3364,6632,6633],{"class":3366,"line":3432},[3364,6634,6635],{},"          Відповідь Unhealthy → **KILL + RESTART**\n",[3364,6637,6638],{"class":3366,"line":3438},[3364,6639,3389],{"emptyLinePlaceholder":3388},[3364,6641,6642],{"class":3366,"line":3444},[3364,6643,6644],{},"          Що перевіряємо:\n",[3364,6646,6647],{"class":3366,"line":3450},[3364,6648,6649],{},"          • Процес не застряг у deadlock\n",[3364,6651,6652],{"class":3366,"line":3456},[3364,6653,6654],{},"          • Немає infinite loop\n",[3364,6656,6657],{"class":3366,"line":3461},[3364,6658,6659],{},"          • Базові ресурси доступні\n",[3364,6661,6662],{"class":3366,"line":3467},[3364,6663,6664],{},"          (не зовнішні залежності!)\n",[3364,6666,6667],{"class":3366,"line":3473},[3364,6668,6669],{},"        end note\n",[3364,6671,6672],{"class":3366,"line":3479},[3364,6673,3671],{},[3364,6675,6676],{"class":3366,"line":3485},[3364,6677,3389],{"emptyLinePlaceholder":3388},[3364,6679,6680],{"class":3366,"line":3490},[3364,6681,6682],{},"    rectangle \"Readiness Probe\\nGET \u002Fhealth\u002Fready\" as READY #d1fae5 {\n",[3364,6684,6685],{"class":3366,"line":3495},[3364,6686,6687],{},"        note as NR\n",[3364,6689,6690],{"class":3366,"line":3500},[3364,6691,6692],{},"          Питання: \"Чи готовий до трафіку?\"\n",[3364,6694,6695],{"class":3366,"line":3505},[3364,6696,6697],{},"          Відповідь Unhealthy → **виключити з Service**\n",[3364,6699,6700],{"class":3366,"line":3511},[3364,6701,6702],{},"          (Pod залишається живим)\n",[3364,6704,6705],{"class":3366,"line":3517},[3364,6706,3389],{"emptyLinePlaceholder":3388},[3364,6708,6709],{"class":3366,"line":3523},[3364,6710,6644],{},[3364,6712,6713],{"class":3366,"line":3528},[3364,6714,6715],{},"          • БД доступна\n",[3364,6717,6718],{"class":3366,"line":3534},[3364,6719,6720],{},"          • Redis доступний\n",[3364,6722,6723],{"class":3366,"line":3540},[3364,6724,6725],{},"          • Кеш прогрітий\n",[3364,6727,6728],{"class":3366,"line":3546},[3364,6729,6730],{},"          • Зовнішні API відповідають\n",[3364,6732,6733],{"class":3366,"line":3552},[3364,6734,6669],{},[3364,6736,6737],{"class":3366,"line":3558},[3364,6738,3671],{},[3364,6740,6741],{"class":3366,"line":3563},[3364,6742,3453],{},[3364,6744,6745],{"class":3366,"line":3790},[3364,6746,3389],{"emptyLinePlaceholder":3388},[3364,6748,6749],{"class":3366,"line":3796},[3364,6750,6751],{},"rectangle \"Kubernetes Service\" as SVC #bbf7d0\n",[3364,6753,6754],{"class":3366,"line":3802},[3364,6755,3389],{"emptyLinePlaceholder":3388},[3364,6757,6758],{"class":3366,"line":3808},[3364,6759,6760],{},"POD --> SVC : трафік лише якщо\\nReadiness = Healthy\n",[3364,6762,6763],{"class":3366,"line":3813},[3364,6764,6765],{},"LIVE ..> POD : failure → restart\n",[3364,6767,6768],{"class":3366,"line":3818},[3364,6769,3389],{"emptyLinePlaceholder":3388},[3364,6771,6772],{"class":3366,"line":5119},[3364,6773,3566],{},[3312,6775,6776,6779,6780,6783],{},[3316,6777,6778],{},"Чому не перевіряти БД у liveness?"," Якщо liveness probe перевіряє базу даних і база тимчасово недоступна — Kubernetes вб'є і перезапустить всі поди одночасно. Після перезапуску вони знову не пройдуть liveness (бо база ще недоступна) → знову перезапуск → ",[3316,6781,6782],{},"crashloop",". Добре структурований додаток переживе недоступність бази — він просто не приймає трафік (readiness = unhealthy), але залишається живим і відновиться автоматично.",[3312,6785,6786,6787,3827],{},"Реалізація двох окремих ендпоінтів через ",[3347,6788,5180],{},[3355,6790,6792],{"className":3830,"code":6791,"filename":3959,"language":3832,"meta":3360,"style":3360},"builder.Services.AddHealthChecks()\n    .AddCheck\u003CMemoryHealthCheck>(\"memory\", tags: [\"live\"])           \u002F\u002F liveness\n    .AddSqlServer(connStr, name: \"sql-server\", tags: [\"ready\", \"critical\"])  \u002F\u002F readiness\n    .AddRedis(redisConnStr, name: \"redis\", tags: [\"ready\"])          \u002F\u002F readiness\n    .AddUrlGroup(new Uri(\"https:\u002F\u002Fapi.stripe.com\"), name: \"stripe\",\n        tags: [\"ready\", \"external\"]);                                \u002F\u002F readiness\n\n\u002F\u002F Liveness: тільки перевірки з тегом \"live\"\napp.MapHealthChecks(\"\u002Fhealth\u002Flive\", new HealthCheckOptions\n{\n    Predicate = check => check.Tags.Contains(\"live\"),\n    ResponseWriter = WriteJsonResponse\n});\n\n\u002F\u002F Readiness: тільки перевірки з тегом \"ready\"\napp.MapHealthChecks(\"\u002Fhealth\u002Fready\", new HealthCheckOptions\n{\n    Predicate = check => check.Tags.Contains(\"ready\"),\n    ResponseWriter = WriteJsonResponse\n});\n\n\u002F\u002F Загальний ендпоінт: всі перевірки (для людей, не для Kubernetes)\napp.MapHealthChecks(\"\u002Fhealth\", new HealthCheckOptions\n{\n    ResponseWriter = WriteJsonResponse\n});\n",[3347,6793,6794,6808,6837,6875,6907,6936,6953,6957,6962,6981,6985,7015,7024,7028,7032,7037,7056,7060,7086,7094,7098,7102,7107,7125,7129,7137],{"__ignoreMap":3360},[3364,6795,6796,6798,6800,6802,6804,6806],{"class":3366,"line":3367},[3364,6797,4002],{"class":3882},[3364,6799,3619],{"class":3852},[3364,6801,4007],{"class":3882},[3364,6803,3619],{"class":3852},[3364,6805,4012],{"class":3870},[3364,6807,5156],{"class":3852},[3364,6809,6810,6812,6814,6816,6818,6820,6822,6824,6826,6828,6831,6834],{"class":3366,"line":3373},[3364,6811,5161],{"class":3852},[3364,6813,5164],{"class":3870},[3364,6815,3861],{"class":3852},[3364,6817,6537],{"class":3846},[3364,6819,5172],{"class":3852},[3364,6821,6542],{"class":4061},[3364,6823,4228],{"class":3852},[3364,6825,5180],{"class":3882},[3364,6827,5183],{"class":3852},[3364,6829,6830],{"class":4061},"\"live\"",[3364,6832,6833],{"class":3852},"])           ",[3364,6835,6836],{"class":3996},"\u002F\u002F liveness\n",[3364,6838,6839,6841,6843,6845,6848,6850,6852,6854,6856,6858,6860,6862,6865,6867,6869,6872],{"class":3366,"line":3379},[3364,6840,5161],{"class":3852},[3364,6842,6209],{"class":3870},[3364,6844,3982],{"class":3852},[3364,6846,6847],{"class":3882},"connStr",[3364,6849,4228],{"class":3852},[3364,6851,6560],{"class":3882},[3364,6853,4597],{"class":3852},[3364,6855,6246],{"class":4061},[3364,6857,4228],{"class":3852},[3364,6859,5180],{"class":3882},[3364,6861,5183],{"class":3852},[3364,6863,6864],{"class":4061},"\"ready\"",[3364,6866,4228],{"class":3852},[3364,6868,5191],{"class":4061},[3364,6870,6871],{"class":3852},"])  ",[3364,6873,6874],{"class":3996},"\u002F\u002F readiness\n",[3364,6876,6877,6879,6881,6883,6886,6888,6890,6892,6894,6896,6898,6900,6902,6905],{"class":3366,"line":3385},[3364,6878,5161],{"class":3852},[3364,6880,6346],{"class":3870},[3364,6882,3982],{"class":3852},[3364,6884,6885],{"class":3882},"redisConnStr",[3364,6887,4228],{"class":3852},[3364,6889,6560],{"class":3882},[3364,6891,4597],{"class":3852},[3364,6893,6381],{"class":4061},[3364,6895,4228],{"class":3852},[3364,6897,5180],{"class":3882},[3364,6899,5183],{"class":3852},[3364,6901,6864],{"class":4061},[3364,6903,6904],{"class":3852},"])          ",[3364,6906,6874],{"class":3996},[3364,6908,6909,6911,6913,6915,6917,6919,6921,6924,6927,6929,6931,6934],{"class":3366,"line":3392},[3364,6910,5161],{"class":3852},[3364,6912,6474],{"class":3870},[3364,6914,3982],{"class":3852},[3364,6916,4231],{"class":3839},[3364,6918,6488],{"class":3846},[3364,6920,3982],{"class":3852},[3364,6922,6923],{"class":4061},"\"https:\u002F\u002Fapi.stripe.com\"",[3364,6925,6926],{"class":3852},"), ",[3364,6928,6560],{"class":3882},[3364,6930,4597],{"class":3852},[3364,6932,6933],{"class":4061},"\"stripe\"",[3364,6935,3886],{"class":3852},[3364,6937,6938,6940,6942,6944,6946,6948,6951],{"class":3366,"line":3398},[3364,6939,6253],{"class":3882},[3364,6941,5183],{"class":3852},[3364,6943,6864],{"class":4061},[3364,6945,4228],{"class":3852},[3364,6947,6515],{"class":4061},[3364,6949,6950],{"class":3852},"]);                                ",[3364,6952,6874],{"class":3996},[3364,6954,6955],{"class":3366,"line":3403},[3364,6956,3389],{"emptyLinePlaceholder":3388},[3364,6958,6959],{"class":3366,"line":3409},[3364,6960,6961],{"class":3996},"\u002F\u002F Liveness: тільки перевірки з тегом \"live\"\n",[3364,6963,6964,6966,6968,6970,6972,6975,6977,6979],{"class":3366,"line":3414},[3364,6965,4051],{"class":3882},[3364,6967,3619],{"class":3852},[3364,6969,4056],{"class":3870},[3364,6971,3982],{"class":3852},[3364,6973,6974],{"class":4061},"\"\u002Fhealth\u002Flive\"",[3364,6976,4228],{"class":3852},[3364,6978,4231],{"class":3839},[3364,6980,4234],{"class":3846},[3364,6982,6983],{"class":3366,"line":3420},[3364,6984,3853],{"class":3852},[3364,6986,6987,6990,6992,6995,6997,6999,7001,7004,7006,7009,7011,7013],{"class":3366,"line":3426},[3364,6988,6989],{"class":3882},"    Predicate",[3364,6991,3897],{"class":3852},[3364,6993,6994],{"class":3882},"check",[3364,6996,4391],{"class":3852},[3364,6998,6994],{"class":3882},[3364,7000,3619],{"class":3852},[3364,7002,7003],{"class":3882},"Tags",[3364,7005,3619],{"class":3852},[3364,7007,7008],{"class":3870},"Contains",[3364,7010,3982],{"class":3852},[3364,7012,6830],{"class":4061},[3364,7014,5693],{"class":3852},[3364,7016,7017,7019,7021],{"class":3366,"line":3432},[3364,7018,4243],{"class":3882},[3364,7020,3897],{"class":3852},[3364,7022,7023],{"class":3882},"WriteJsonResponse\n",[3364,7025,7026],{"class":3366,"line":3438},[3364,7027,4571],{"class":3852},[3364,7029,7030],{"class":3366,"line":3444},[3364,7031,3389],{"emptyLinePlaceholder":3388},[3364,7033,7034],{"class":3366,"line":3450},[3364,7035,7036],{"class":3996},"\u002F\u002F Readiness: тільки перевірки з тегом \"ready\"\n",[3364,7038,7039,7041,7043,7045,7047,7050,7052,7054],{"class":3366,"line":3456},[3364,7040,4051],{"class":3882},[3364,7042,3619],{"class":3852},[3364,7044,4056],{"class":3870},[3364,7046,3982],{"class":3852},[3364,7048,7049],{"class":4061},"\"\u002Fhealth\u002Fready\"",[3364,7051,4228],{"class":3852},[3364,7053,4231],{"class":3839},[3364,7055,4234],{"class":3846},[3364,7057,7058],{"class":3366,"line":3461},[3364,7059,3853],{"class":3852},[3364,7061,7062,7064,7066,7068,7070,7072,7074,7076,7078,7080,7082,7084],{"class":3366,"line":3467},[3364,7063,6989],{"class":3882},[3364,7065,3897],{"class":3852},[3364,7067,6994],{"class":3882},[3364,7069,4391],{"class":3852},[3364,7071,6994],{"class":3882},[3364,7073,3619],{"class":3852},[3364,7075,7003],{"class":3882},[3364,7077,3619],{"class":3852},[3364,7079,7008],{"class":3870},[3364,7081,3982],{"class":3852},[3364,7083,6864],{"class":4061},[3364,7085,5693],{"class":3852},[3364,7087,7088,7090,7092],{"class":3366,"line":3473},[3364,7089,4243],{"class":3882},[3364,7091,3897],{"class":3852},[3364,7093,7023],{"class":3882},[3364,7095,7096],{"class":3366,"line":3479},[3364,7097,4571],{"class":3852},[3364,7099,7100],{"class":3366,"line":3485},[3364,7101,3389],{"emptyLinePlaceholder":3388},[3364,7103,7104],{"class":3366,"line":3490},[3364,7105,7106],{"class":3996},"\u002F\u002F Загальний ендпоінт: всі перевірки (для людей, не для Kubernetes)\n",[3364,7108,7109,7111,7113,7115,7117,7119,7121,7123],{"class":3366,"line":3495},[3364,7110,4051],{"class":3882},[3364,7112,3619],{"class":3852},[3364,7114,4056],{"class":3870},[3364,7116,3982],{"class":3852},[3364,7118,4062],{"class":4061},[3364,7120,4228],{"class":3852},[3364,7122,4231],{"class":3839},[3364,7124,4234],{"class":3846},[3364,7126,7127],{"class":3366,"line":3500},[3364,7128,3853],{"class":3852},[3364,7130,7131,7133,7135],{"class":3366,"line":3505},[3364,7132,4243],{"class":3882},[3364,7134,3897],{"class":3852},[3364,7136,7023],{"class":3882},[3364,7138,7139],{"class":3366,"line":3511},[3364,7140,4571],{"class":3852},[3312,7142,7143,7144,3827],{},"Конфігурація Kubernetes у ",[3347,7145,7146],{},"deployment.yaml",[3355,7148,7153],{"className":7149,"code":7150,"filename":7151,"language":7152,"meta":3360,"style":3360},"language-yaml shiki shiki-themes light-plus dark-plus dark-plus","livenessProbe:\n    httpGet:\n        path: \u002Fhealth\u002Flive\n        port: 8080\n    initialDelaySeconds: 10 # чекати 10с після старту перед першою перевіркою\n    periodSeconds: 15 # перевіряти кожні 15с\n    failureThreshold: 3 # 3 consecutive failures → restart\n\nreadinessProbe:\n    httpGet:\n        path: \u002Fhealth\u002Fready\n        port: 8080\n    initialDelaySeconds: 5\n    periodSeconds: 10\n    failureThreshold: 2 # 2 failures → виключити з endpoints\n","k8s\u002Fdeployment.yaml","yaml",[3347,7154,7155,7163,7170,7180,7190,7203,7216,7229,7233,7240,7246,7255,7263,7272,7281],{"__ignoreMap":3360},[3364,7156,7157,7160],{"class":3366,"line":3367},[3364,7158,7159],{"class":5995},"livenessProbe",[3364,7161,7162],{"class":3852},":\n",[3364,7164,7165,7168],{"class":3366,"line":3373},[3364,7166,7167],{"class":5995},"    httpGet",[3364,7169,7162],{"class":3852},[3364,7171,7172,7175,7177],{"class":3366,"line":3379},[3364,7173,7174],{"class":5995},"        path",[3364,7176,4597],{"class":3852},[3364,7178,7179],{"class":6006},"\u002Fhealth\u002Flive\n",[3364,7181,7182,7185,7187],{"class":3366,"line":3385},[3364,7183,7184],{"class":5995},"        port",[3364,7186,4597],{"class":3852},[3364,7188,7189],{"class":5027},"8080\n",[3364,7191,7192,7195,7197,7200],{"class":3366,"line":3392},[3364,7193,7194],{"class":5995},"    initialDelaySeconds",[3364,7196,4597],{"class":3852},[3364,7198,7199],{"class":5027},"10",[3364,7201,7202],{"class":3996}," # чекати 10с після старту перед першою перевіркою\n",[3364,7204,7205,7208,7210,7213],{"class":3366,"line":3398},[3364,7206,7207],{"class":5995},"    periodSeconds",[3364,7209,4597],{"class":3852},[3364,7211,7212],{"class":5027},"15",[3364,7214,7215],{"class":3996}," # перевіряти кожні 15с\n",[3364,7217,7218,7221,7223,7226],{"class":3366,"line":3403},[3364,7219,7220],{"class":5995},"    failureThreshold",[3364,7222,4597],{"class":3852},[3364,7224,7225],{"class":5027},"3",[3364,7227,7228],{"class":3996}," # 3 consecutive failures → restart\n",[3364,7230,7231],{"class":3366,"line":3409},[3364,7232,3389],{"emptyLinePlaceholder":3388},[3364,7234,7235,7238],{"class":3366,"line":3414},[3364,7236,7237],{"class":5995},"readinessProbe",[3364,7239,7162],{"class":3852},[3364,7241,7242,7244],{"class":3366,"line":3420},[3364,7243,7167],{"class":5995},[3364,7245,7162],{"class":3852},[3364,7247,7248,7250,7252],{"class":3366,"line":3426},[3364,7249,7174],{"class":5995},[3364,7251,4597],{"class":3852},[3364,7253,7254],{"class":6006},"\u002Fhealth\u002Fready\n",[3364,7256,7257,7259,7261],{"class":3366,"line":3432},[3364,7258,7184],{"class":5995},[3364,7260,4597],{"class":3852},[3364,7262,7189],{"class":5027},[3364,7264,7265,7267,7269],{"class":3366,"line":3438},[3364,7266,7194],{"class":5995},[3364,7268,4597],{"class":3852},[3364,7270,7271],{"class":5027},"5\n",[3364,7273,7274,7276,7278],{"class":3366,"line":3444},[3364,7275,7207],{"class":5995},[3364,7277,4597],{"class":3852},[3364,7279,7280],{"class":5027},"10\n",[3364,7282,7283,7285,7287,7289],{"class":3366,"line":3450},[3364,7284,7220],{"class":5995},[3364,7286,4597],{"class":3852},[3364,7288,5028],{"class":5027},[3364,7290,7291],{"class":3996}," # 2 failures → виключити з endpoints\n",[3328,7293],{},[3331,7295,7297],{"id":7296},"healthcheckui-веб-інтерфейс-для-health-checks","HealthCheckUI: веб-інтерфейс для health checks",[3312,7299,7300,7303],{},[3347,7301,7302],{},"AspNetCore.HealthChecks.UI"," — це готовий веб-дашборд, що автоматично опитує ваші ендпоінти і відображає статус у зручному вигляді з графіком змін у часі.",[3355,7305,7307],{"className":3830,"code":7306,"filename":3959,"language":3832,"meta":3360,"style":3360},"builder.Services\n    .AddHealthChecks()\n    .AddSqlServer(connStr, name: \"sql-server\", tags: [\"ready\", \"critical\"])\n    .AddRedis(redisConnStr, name: \"redis\", tags: [\"ready\"])\n    .AddCheck\u003CMemoryHealthCheck>(\"memory\", tags: [\"live\"]);\n\n\u002F\u002F Реєструємо UI з in-memory сховищем (для розробки)\nbuilder.Services\n    .AddHealthChecksUI(options =>\n    {\n        options.SetEvaluationTimeInSeconds(15);     \u002F\u002F перевіряти кожні 15с\n        options.MaximumHistoryEntriesPerEndpoint(50); \u002F\u002F зберігати 50 записів\n        options.AddHealthCheckEndpoint(\"Production API\", \"\u002Fhealth\");\n    })\n    .AddInMemoryStorage();\n\nvar app = builder.Build();\n\n\u002F\u002F Реєструємо сам ендпоінт \u002Fhealth з форматом для UI\napp.MapHealthChecks(\"\u002Fhealth\", new HealthCheckOptions\n{\n    ResponseWriter = UIResponseWriter.WriteHealthCheckUIResponse  \u002F\u002F ← спеціальний writer\n});\n\n\u002F\u002F Монтуємо UI за адресою \u002Fhealthui\napp.MapHealthChecksUI(options =>\n{\n    options.UIPath = \"\u002Fhealthui\";\n    options.ApiPath = \"\u002Fhealthui-api\";\n});\n",[3347,7308,7309,7318,7326,7358,7386,7410,7414,7419,7427,7442,7446,7466,7486,7506,7511,7520,7524,7540,7544,7549,7567,7571,7588,7592,7596,7601,7616,7620,7637,7653],{"__ignoreMap":3360},[3364,7310,7311,7313,7315],{"class":3366,"line":3367},[3364,7312,4002],{"class":3882},[3364,7314,3619],{"class":3852},[3364,7316,7317],{"class":3882},"Services\n",[3364,7319,7320,7322,7324],{"class":3366,"line":3373},[3364,7321,5161],{"class":3852},[3364,7323,4012],{"class":3870},[3364,7325,5156],{"class":3852},[3364,7327,7328,7330,7332,7334,7336,7338,7340,7342,7344,7346,7348,7350,7352,7354,7356],{"class":3366,"line":3379},[3364,7329,5161],{"class":3852},[3364,7331,6209],{"class":3870},[3364,7333,3982],{"class":3852},[3364,7335,6847],{"class":3882},[3364,7337,4228],{"class":3852},[3364,7339,6560],{"class":3882},[3364,7341,4597],{"class":3852},[3364,7343,6246],{"class":4061},[3364,7345,4228],{"class":3852},[3364,7347,5180],{"class":3882},[3364,7349,5183],{"class":3852},[3364,7351,6864],{"class":4061},[3364,7353,4228],{"class":3852},[3364,7355,5191],{"class":4061},[3364,7357,6264],{"class":3852},[3364,7359,7360,7362,7364,7366,7368,7370,7372,7374,7376,7378,7380,7382,7384],{"class":3366,"line":3385},[3364,7361,5161],{"class":3852},[3364,7363,6346],{"class":3870},[3364,7365,3982],{"class":3852},[3364,7367,6885],{"class":3882},[3364,7369,4228],{"class":3852},[3364,7371,6560],{"class":3882},[3364,7373,4597],{"class":3852},[3364,7375,6381],{"class":4061},[3364,7377,4228],{"class":3852},[3364,7379,5180],{"class":3882},[3364,7381,5183],{"class":3852},[3364,7383,6864],{"class":4061},[3364,7385,6264],{"class":3852},[3364,7387,7388,7390,7392,7394,7396,7398,7400,7402,7404,7406,7408],{"class":3366,"line":3392},[3364,7389,5161],{"class":3852},[3364,7391,5164],{"class":3870},[3364,7393,3861],{"class":3852},[3364,7395,6537],{"class":3846},[3364,7397,5172],{"class":3852},[3364,7399,6542],{"class":4061},[3364,7401,4228],{"class":3852},[3364,7403,5180],{"class":3882},[3364,7405,5183],{"class":3852},[3364,7407,6830],{"class":4061},[3364,7409,5194],{"class":3852},[3364,7411,7412],{"class":3366,"line":3398},[3364,7413,3389],{"emptyLinePlaceholder":3388},[3364,7415,7416],{"class":3366,"line":3403},[3364,7417,7418],{"class":3996},"\u002F\u002F Реєструємо UI з in-memory сховищем (для розробки)\n",[3364,7420,7421,7423,7425],{"class":3366,"line":3409},[3364,7422,4002],{"class":3882},[3364,7424,3619],{"class":3852},[3364,7426,7317],{"class":3882},[3364,7428,7429,7431,7434,7436,7439],{"class":3366,"line":3414},[3364,7430,5161],{"class":3852},[3364,7432,7433],{"class":3870},"AddHealthChecksUI",[3364,7435,3982],{"class":3852},[3364,7437,7438],{"class":3882},"options",[3364,7440,7441],{"class":3852}," =>\n",[3364,7443,7444],{"class":3366,"line":3420},[3364,7445,4267],{"class":3852},[3364,7447,7448,7451,7453,7456,7458,7460,7463],{"class":3366,"line":3426},[3364,7449,7450],{"class":3882},"        options",[3364,7452,3619],{"class":3852},[3364,7454,7455],{"class":3870},"SetEvaluationTimeInSeconds",[3364,7457,3982],{"class":3852},[3364,7459,7212],{"class":5027},[3364,7461,7462],{"class":3852},");     ",[3364,7464,7465],{"class":3996},"\u002F\u002F перевіряти кожні 15с\n",[3364,7467,7468,7470,7472,7475,7477,7480,7483],{"class":3366,"line":3432},[3364,7469,7450],{"class":3882},[3364,7471,3619],{"class":3852},[3364,7473,7474],{"class":3870},"MaximumHistoryEntriesPerEndpoint",[3364,7476,3982],{"class":3852},[3364,7478,7479],{"class":5027},"50",[3364,7481,7482],{"class":3852},"); ",[3364,7484,7485],{"class":3996},"\u002F\u002F зберігати 50 записів\n",[3364,7487,7488,7490,7492,7495,7497,7500,7502,7504],{"class":3366,"line":3438},[3364,7489,7450],{"class":3882},[3364,7491,3619],{"class":3852},[3364,7493,7494],{"class":3870},"AddHealthCheckEndpoint",[3364,7496,3982],{"class":3852},[3364,7498,7499],{"class":4061},"\"Production API\"",[3364,7501,4228],{"class":3852},[3364,7503,4062],{"class":4061},[3364,7505,3903],{"class":3852},[3364,7507,7508],{"class":3366,"line":3444},[3364,7509,7510],{"class":3852},"    })\n",[3364,7512,7513,7515,7518],{"class":3366,"line":3450},[3364,7514,5161],{"class":3852},[3364,7516,7517],{"class":3870},"AddInMemoryStorage",[3364,7519,4015],{"class":3852},[3364,7521,7522],{"class":3366,"line":3456},[3364,7523,3389],{"emptyLinePlaceholder":3388},[3364,7525,7526,7528,7530,7532,7534,7536,7538],{"class":3366,"line":3461},[3364,7527,3966],{"class":3839},[3364,7529,4026],{"class":3882},[3364,7531,3897],{"class":3852},[3364,7533,4002],{"class":3882},[3364,7535,3619],{"class":3852},[3364,7537,4035],{"class":3870},[3364,7539,4015],{"class":3852},[3364,7541,7542],{"class":3366,"line":3467},[3364,7543,3389],{"emptyLinePlaceholder":3388},[3364,7545,7546],{"class":3366,"line":3473},[3364,7547,7548],{"class":3996},"\u002F\u002F Реєструємо сам ендпоінт \u002Fhealth з форматом для UI\n",[3364,7550,7551,7553,7555,7557,7559,7561,7563,7565],{"class":3366,"line":3479},[3364,7552,4051],{"class":3882},[3364,7554,3619],{"class":3852},[3364,7556,4056],{"class":3870},[3364,7558,3982],{"class":3852},[3364,7560,4062],{"class":4061},[3364,7562,4228],{"class":3852},[3364,7564,4231],{"class":3839},[3364,7566,4234],{"class":3846},[3364,7568,7569],{"class":3366,"line":3485},[3364,7570,3853],{"class":3852},[3364,7572,7573,7575,7577,7580,7582,7585],{"class":3366,"line":3490},[3364,7574,4243],{"class":3882},[3364,7576,3897],{"class":3852},[3364,7578,7579],{"class":3882},"UIResponseWriter",[3364,7581,3619],{"class":3852},[3364,7583,7584],{"class":3882},"WriteHealthCheckUIResponse",[3364,7586,7587],{"class":3996},"  \u002F\u002F ← спеціальний writer\n",[3364,7589,7590],{"class":3366,"line":3495},[3364,7591,4571],{"class":3852},[3364,7593,7594],{"class":3366,"line":3500},[3364,7595,3389],{"emptyLinePlaceholder":3388},[3364,7597,7598],{"class":3366,"line":3505},[3364,7599,7600],{"class":3996},"\u002F\u002F Монтуємо UI за адресою \u002Fhealthui\n",[3364,7602,7603,7605,7607,7610,7612,7614],{"class":3366,"line":3511},[3364,7604,4051],{"class":3882},[3364,7606,3619],{"class":3852},[3364,7608,7609],{"class":3870},"MapHealthChecksUI",[3364,7611,3982],{"class":3852},[3364,7613,7438],{"class":3882},[3364,7615,7441],{"class":3852},[3364,7617,7618],{"class":3366,"line":3517},[3364,7619,3853],{"class":3852},[3364,7621,7622,7625,7627,7630,7632,7635],{"class":3366,"line":3523},[3364,7623,7624],{"class":3882},"    options",[3364,7626,3619],{"class":3852},[3364,7628,7629],{"class":3882},"UIPath",[3364,7631,3897],{"class":3852},[3364,7633,7634],{"class":4061},"\"\u002Fhealthui\"",[3364,7636,4169],{"class":3852},[3364,7638,7639,7641,7643,7646,7648,7651],{"class":3366,"line":3528},[3364,7640,7624],{"class":3882},[3364,7642,3619],{"class":3852},[3364,7644,7645],{"class":3882},"ApiPath",[3364,7647,3897],{"class":3852},[3364,7649,7650],{"class":4061},"\"\u002Fhealthui-api\"",[3364,7652,4169],{"class":3852},[3364,7654,7655],{"class":3366,"line":3534},[3364,7656,4571],{"class":3852},[7658,7659,7660,7663],"warning",{},[3347,7661,7662],{},"HealthCheckUI"," за замовчуванням доступний без автентифікації. У production обмежте доступ через IP filtering, BasicAuth або вимкніть зовнішній доступ (expose тільки всередині cluster).",[3312,7665,7666,7667,7670],{},"Після запуску відкрийте ",[3347,7668,7669],{},"http:\u002F\u002Flocalhost:5000\u002Fhealthui"," — ви побачите дашборд:",[3352,7672,7673],{},[3355,7674,7676],{"className":3357,"code":7675,"language":3359,"meta":3360,"style":3360},"@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\n\ntitle \"HealthCheckUI: зовнішній вигляд\"\n\nrectangle \"Health Checks UI\\nlocalhost:5000\u002Fhealthui\" as UI #f8fafc {\n\n    rectangle \"Production API\\n● Healthy\" as EP1 #bbf7d0 {\n        rectangle \"sql-server   ✓ Healthy   23ms\" as R1 #d1fae5\n        rectangle \"redis        ✓ Healthy    4ms\" as R2 #d1fae5\n        rectangle \"memory       ✓ Healthy    1ms\\n412 MB \u002F 512 MB threshold\" as R3 #d1fae5\n    }\n\n    rectangle \"History Graph\\n(остання година)\" as HIST #e0e7ff {\n        note as NH\n          ▁▁▁▁▁▂▂▁▁▁▁▁▁▁▂▁▁▁ ← зміни статусу у часі\n          Можна побачити коли\n          і на скільки падав сервіс\n        end note\n    }\n}\n\n@enduml\n",[3347,7677,7678,7682,7686,7690,7694,7699,7703,7708,7712,7717,7722,7727,7732,7736,7740,7745,7750,7755,7760,7765,7769,7773,7777,7781],{"__ignoreMap":3360},[3364,7679,7680],{"class":3366,"line":3367},[3364,7681,3370],{},[3364,7683,7684],{"class":3366,"line":3373},[3364,7685,3376],{},[3364,7687,7688],{"class":3366,"line":3379},[3364,7689,3382],{},[3364,7691,7692],{"class":3366,"line":3385},[3364,7693,3389],{"emptyLinePlaceholder":3388},[3364,7695,7696],{"class":3366,"line":3392},[3364,7697,7698],{},"title \"HealthCheckUI: зовнішній вигляд\"\n",[3364,7700,7701],{"class":3366,"line":3398},[3364,7702,3389],{"emptyLinePlaceholder":3388},[3364,7704,7705],{"class":3366,"line":3403},[3364,7706,7707],{},"rectangle \"Health Checks UI\\nlocalhost:5000\u002Fhealthui\" as UI #f8fafc {\n",[3364,7709,7710],{"class":3366,"line":3409},[3364,7711,3389],{"emptyLinePlaceholder":3388},[3364,7713,7714],{"class":3366,"line":3414},[3364,7715,7716],{},"    rectangle \"Production API\\n● Healthy\" as EP1 #bbf7d0 {\n",[3364,7718,7719],{"class":3366,"line":3420},[3364,7720,7721],{},"        rectangle \"sql-server   ✓ Healthy   23ms\" as R1 #d1fae5\n",[3364,7723,7724],{"class":3366,"line":3426},[3364,7725,7726],{},"        rectangle \"redis        ✓ Healthy    4ms\" as R2 #d1fae5\n",[3364,7728,7729],{"class":3366,"line":3432},[3364,7730,7731],{},"        rectangle \"memory       ✓ Healthy    1ms\\n412 MB \u002F 512 MB threshold\" as R3 #d1fae5\n",[3364,7733,7734],{"class":3366,"line":3438},[3364,7735,3671],{},[3364,7737,7738],{"class":3366,"line":3444},[3364,7739,3389],{"emptyLinePlaceholder":3388},[3364,7741,7742],{"class":3366,"line":3450},[3364,7743,7744],{},"    rectangle \"History Graph\\n(остання година)\" as HIST #e0e7ff {\n",[3364,7746,7747],{"class":3366,"line":3456},[3364,7748,7749],{},"        note as NH\n",[3364,7751,7752],{"class":3366,"line":3461},[3364,7753,7754],{},"          ▁▁▁▁▁▂▂▁▁▁▁▁▁▁▂▁▁▁ ← зміни статусу у часі\n",[3364,7756,7757],{"class":3366,"line":3467},[3364,7758,7759],{},"          Можна побачити коли\n",[3364,7761,7762],{"class":3366,"line":3473},[3364,7763,7764],{},"          і на скільки падав сервіс\n",[3364,7766,7767],{"class":3366,"line":3479},[3364,7768,6669],{},[3364,7770,7771],{"class":3366,"line":3485},[3364,7772,3671],{},[3364,7774,7775],{"class":3366,"line":3490},[3364,7776,3453],{},[3364,7778,7779],{"class":3366,"line":3495},[3364,7780,3389],{"emptyLinePlaceholder":3388},[3364,7782,7783],{"class":3366,"line":3500},[3364,7784,3566],{},[3328,7786],{},[3331,7788,7790],{"id":7789},"повний-приклад-minimal-api-з-трьома-checks-ui","Повний приклад: Minimal API з трьома checks + UI",[3312,7792,7793],{},"Зберемо все разом у повноцінний приклад. Структура проєкту:",[7795,7796,7797,8463,8890],"code-tree",{},[3355,7798,7800],{"className":3830,"code":7799,"filename":3959,"language":3832,"meta":3360,"style":3360},"using AspNetCore.HealthChecks.UI.Client;\nusing Microsoft.AspNetCore.Diagnostics.HealthChecks;\n\nvar builder = WebApplication.CreateBuilder(args);\n\nbuilder.Services\n    .AddHealthChecks()\n    .AddSqlServer(\n        connectionString: builder.Configuration.GetConnectionString(\"Default\")!,\n        name: \"sql-server\",\n        failureStatus: Microsoft.Extensions.Diagnostics.HealthChecks.HealthStatus.Unhealthy,\n        tags: [\"ready\", \"critical\"])\n    .AddRedis(\n        redisConnectionString: builder.Configuration.GetConnectionString(\"Redis\")!,\n        name: \"redis\",\n        failureStatus: Microsoft.Extensions.Diagnostics.HealthChecks.HealthStatus.Degraded,\n        tags: [\"ready\"])\n    .AddCheck\u003CMemoryHealthCheck>(\n        name: \"memory\",\n        tags: [\"live\", \"system\"]);\n\nbuilder.Services\n    .AddHealthChecksUI(options =>\n    {\n        options.SetEvaluationTimeInSeconds(30);\n        options.MaximumHistoryEntriesPerEndpoint(60);\n        options.AddHealthCheckEndpoint(\"API\", \"\u002Fhealth\");\n    })\n    .AddInMemoryStorage();\n\nvar app = builder.Build();\n\napp.MapHealthChecks(\"\u002Fhealth\u002Flive\", new HealthCheckOptions\n{\n    Predicate = r => r.Tags.Contains(\"live\"),\n    ResponseWriter = UIResponseWriter.WriteHealthCheckUIResponse\n});\n\napp.MapHealthChecks(\"\u002Fhealth\u002Fready\", new HealthCheckOptions\n{\n    Predicate = r => r.Tags.Contains(\"ready\"),\n    ResponseWriter = UIResponseWriter.WriteHealthCheckUIResponse\n});\n\napp.MapHealthChecks(\"\u002Fhealth\", new HealthCheckOptions\n{\n    ResponseWriter = UIResponseWriter.WriteHealthCheckUIResponse\n});\n\napp.MapHealthChecksUI(o => o.UIPath = \"\u002Fhealthui\");\n\napp.MapGet(\"\u002F\", () => \"Hello, World!\");\n\napp.Run();\n",[3347,7801,7802,7825,7845,7849,7869,7873,7881,7889,7897,7919,7929,7962,7976,7984,8006,8016,8046,8056,8069,8079,8093,8097,8105,8117,8121,8136,8151,8170,8174,8182,8186,8202,8206,8224,8228,8255,8268,8272,8276,8294,8298,8324,8336,8340,8344,8363,8368,8381,8386,8391,8419,8424,8447,8452],{"__ignoreMap":3360},[3364,7803,7804,7806,7809,7811,7813,7815,7818,7820,7823],{"class":3366,"line":3367},[3364,7805,4148],{"class":4147},[3364,7807,7808],{"class":3846}," AspNetCore",[3364,7810,3619],{"class":3852},[3364,7812,4166],{"class":3846},[3364,7814,3619],{"class":3852},[3364,7816,7817],{"class":3846},"UI",[3364,7819,3619],{"class":3852},[3364,7821,7822],{"class":3846},"Client",[3364,7824,4169],{"class":3852},[3364,7826,7827,7829,7831,7833,7835,7837,7839,7841,7843],{"class":3366,"line":3373},[3364,7828,4148],{"class":4147},[3364,7830,4151],{"class":3846},[3364,7832,3619],{"class":3852},[3364,7834,4156],{"class":3846},[3364,7836,3619],{"class":3852},[3364,7838,4161],{"class":3846},[3364,7840,3619],{"class":3852},[3364,7842,4166],{"class":3846},[3364,7844,4169],{"class":3852},[3364,7846,7847],{"class":3366,"line":3379},[3364,7848,3389],{"emptyLinePlaceholder":3388},[3364,7850,7851,7853,7855,7857,7859,7861,7863,7865,7867],{"class":3366,"line":3385},[3364,7852,3966],{"class":3839},[3364,7854,3969],{"class":3882},[3364,7856,3897],{"class":3852},[3364,7858,3974],{"class":3882},[3364,7860,3619],{"class":3852},[3364,7862,3979],{"class":3870},[3364,7864,3982],{"class":3852},[3364,7866,3985],{"class":3882},[3364,7868,3903],{"class":3852},[3364,7870,7871],{"class":3366,"line":3392},[3364,7872,3389],{"emptyLinePlaceholder":3388},[3364,7874,7875,7877,7879],{"class":3366,"line":3398},[3364,7876,4002],{"class":3882},[3364,7878,3619],{"class":3852},[3364,7880,7317],{"class":3882},[3364,7882,7883,7885,7887],{"class":3366,"line":3403},[3364,7884,5161],{"class":3852},[3364,7886,4012],{"class":3870},[3364,7888,5156],{"class":3852},[3364,7890,7891,7893,7895],{"class":3366,"line":3409},[3364,7892,5161],{"class":3852},[3364,7894,6209],{"class":3870},[3364,7896,3874],{"class":3852},[3364,7898,7899,7901,7903,7905,7907,7909,7911,7913,7915,7917],{"class":3366,"line":3414},[3364,7900,6216],{"class":3882},[3364,7902,4597],{"class":3852},[3364,7904,4002],{"class":3882},[3364,7906,3619],{"class":3852},[3364,7908,6225],{"class":3882},[3364,7910,3619],{"class":3852},[3364,7912,4832],{"class":3870},[3364,7914,3982],{"class":3852},[3364,7916,4837],{"class":4061},[3364,7918,6236],{"class":3852},[3364,7920,7921,7923,7925,7927],{"class":3366,"line":3420},[3364,7922,6241],{"class":3882},[3364,7924,4597],{"class":3852},[3364,7926,6246],{"class":4061},[3364,7928,3886],{"class":3852},[3364,7930,7931,7934,7936,7939,7941,7943,7945,7947,7949,7951,7953,7956,7958,7960],{"class":3366,"line":3426},[3364,7932,7933],{"class":3882},"        failureStatus",[3364,7935,4597],{"class":3852},[3364,7937,7938],{"class":3882},"Microsoft",[3364,7940,3619],{"class":3852},[3364,7942,4180],{"class":3882},[3364,7944,3619],{"class":3852},[3364,7946,4161],{"class":3882},[3364,7948,3619],{"class":3852},[3364,7950,4166],{"class":3882},[3364,7952,3619],{"class":3852},[3364,7954,7955],{"class":3882},"HealthStatus",[3364,7957,3619],{"class":3852},[3364,7959,3349],{"class":3882},[3364,7961,3886],{"class":3852},[3364,7963,7964,7966,7968,7970,7972,7974],{"class":3366,"line":3432},[3364,7965,6253],{"class":3882},[3364,7967,5183],{"class":3852},[3364,7969,6864],{"class":4061},[3364,7971,4228],{"class":3852},[3364,7973,5191],{"class":4061},[3364,7975,6264],{"class":3852},[3364,7977,7978,7980,7982],{"class":3366,"line":3438},[3364,7979,5161],{"class":3852},[3364,7981,6346],{"class":3870},[3364,7983,3874],{"class":3852},[3364,7985,7986,7988,7990,7992,7994,7996,7998,8000,8002,8004],{"class":3366,"line":3444},[3364,7987,6353],{"class":3882},[3364,7989,4597],{"class":3852},[3364,7991,4002],{"class":3882},[3364,7993,3619],{"class":3852},[3364,7995,6225],{"class":3882},[3364,7997,3619],{"class":3852},[3364,7999,4832],{"class":3870},[3364,8001,3982],{"class":3852},[3364,8003,6370],{"class":4061},[3364,8005,6236],{"class":3852},[3364,8007,8008,8010,8012,8014],{"class":3366,"line":3450},[3364,8009,6241],{"class":3882},[3364,8011,4597],{"class":3852},[3364,8013,6381],{"class":4061},[3364,8015,3886],{"class":3852},[3364,8017,8018,8020,8022,8024,8026,8028,8030,8032,8034,8036,8038,8040,8042,8044],{"class":3366,"line":3456},[3364,8019,7933],{"class":3882},[3364,8021,4597],{"class":3852},[3364,8023,7938],{"class":3882},[3364,8025,3619],{"class":3852},[3364,8027,4180],{"class":3882},[3364,8029,3619],{"class":3852},[3364,8031,4161],{"class":3882},[3364,8033,3619],{"class":3852},[3364,8035,4166],{"class":3882},[3364,8037,3619],{"class":3852},[3364,8039,7955],{"class":3882},[3364,8041,3619],{"class":3852},[3364,8043,5048],{"class":3882},[3364,8045,3886],{"class":3852},[3364,8047,8048,8050,8052,8054],{"class":3366,"line":3461},[3364,8049,6253],{"class":3882},[3364,8051,5183],{"class":3852},[3364,8053,6864],{"class":4061},[3364,8055,6264],{"class":3852},[3364,8057,8058,8060,8062,8064,8066],{"class":3366,"line":3467},[3364,8059,5161],{"class":3852},[3364,8061,5164],{"class":3870},[3364,8063,3861],{"class":3852},[3364,8065,6537],{"class":3846},[3364,8067,8068],{"class":3852},">(\n",[3364,8070,8071,8073,8075,8077],{"class":3366,"line":3473},[3364,8072,6241],{"class":3882},[3364,8074,4597],{"class":3852},[3364,8076,6542],{"class":4061},[3364,8078,3886],{"class":3852},[3364,8080,8081,8083,8085,8087,8089,8091],{"class":3366,"line":3479},[3364,8082,6253],{"class":3882},[3364,8084,5183],{"class":3852},[3364,8086,6830],{"class":4061},[3364,8088,4228],{"class":3852},[3364,8090,6551],{"class":4061},[3364,8092,5194],{"class":3852},[3364,8094,8095],{"class":3366,"line":3485},[3364,8096,3389],{"emptyLinePlaceholder":3388},[3364,8098,8099,8101,8103],{"class":3366,"line":3490},[3364,8100,4002],{"class":3882},[3364,8102,3619],{"class":3852},[3364,8104,7317],{"class":3882},[3364,8106,8107,8109,8111,8113,8115],{"class":3366,"line":3495},[3364,8108,5161],{"class":3852},[3364,8110,7433],{"class":3870},[3364,8112,3982],{"class":3852},[3364,8114,7438],{"class":3882},[3364,8116,7441],{"class":3852},[3364,8118,8119],{"class":3366,"line":3500},[3364,8120,4267],{"class":3852},[3364,8122,8123,8125,8127,8129,8131,8134],{"class":3366,"line":3505},[3364,8124,7450],{"class":3882},[3364,8126,3619],{"class":3852},[3364,8128,7455],{"class":3870},[3364,8130,3982],{"class":3852},[3364,8132,8133],{"class":5027},"30",[3364,8135,3903],{"class":3852},[3364,8137,8138,8140,8142,8144,8146,8149],{"class":3366,"line":3511},[3364,8139,7450],{"class":3882},[3364,8141,3619],{"class":3852},[3364,8143,7474],{"class":3870},[3364,8145,3982],{"class":3852},[3364,8147,8148],{"class":5027},"60",[3364,8150,3903],{"class":3852},[3364,8152,8153,8155,8157,8159,8161,8164,8166,8168],{"class":3366,"line":3517},[3364,8154,7450],{"class":3882},[3364,8156,3619],{"class":3852},[3364,8158,7494],{"class":3870},[3364,8160,3982],{"class":3852},[3364,8162,8163],{"class":4061},"\"API\"",[3364,8165,4228],{"class":3852},[3364,8167,4062],{"class":4061},[3364,8169,3903],{"class":3852},[3364,8171,8172],{"class":3366,"line":3523},[3364,8173,7510],{"class":3852},[3364,8175,8176,8178,8180],{"class":3366,"line":3528},[3364,8177,5161],{"class":3852},[3364,8179,7517],{"class":3870},[3364,8181,4015],{"class":3852},[3364,8183,8184],{"class":3366,"line":3534},[3364,8185,3389],{"emptyLinePlaceholder":3388},[3364,8187,8188,8190,8192,8194,8196,8198,8200],{"class":3366,"line":3540},[3364,8189,3966],{"class":3839},[3364,8191,4026],{"class":3882},[3364,8193,3897],{"class":3852},[3364,8195,4002],{"class":3882},[3364,8197,3619],{"class":3852},[3364,8199,4035],{"class":3870},[3364,8201,4015],{"class":3852},[3364,8203,8204],{"class":3366,"line":3546},[3364,8205,3389],{"emptyLinePlaceholder":3388},[3364,8207,8208,8210,8212,8214,8216,8218,8220,8222],{"class":3366,"line":3552},[3364,8209,4051],{"class":3882},[3364,8211,3619],{"class":3852},[3364,8213,4056],{"class":3870},[3364,8215,3982],{"class":3852},[3364,8217,6974],{"class":4061},[3364,8219,4228],{"class":3852},[3364,8221,4231],{"class":3839},[3364,8223,4234],{"class":3846},[3364,8225,8226],{"class":3366,"line":3558},[3364,8227,3853],{"class":3852},[3364,8229,8230,8232,8234,8237,8239,8241,8243,8245,8247,8249,8251,8253],{"class":3366,"line":3563},[3364,8231,6989],{"class":3882},[3364,8233,3897],{"class":3852},[3364,8235,8236],{"class":3882},"r",[3364,8238,4391],{"class":3852},[3364,8240,8236],{"class":3882},[3364,8242,3619],{"class":3852},[3364,8244,7003],{"class":3882},[3364,8246,3619],{"class":3852},[3364,8248,7008],{"class":3870},[3364,8250,3982],{"class":3852},[3364,8252,6830],{"class":4061},[3364,8254,5693],{"class":3852},[3364,8256,8257,8259,8261,8263,8265],{"class":3366,"line":3790},[3364,8258,4243],{"class":3882},[3364,8260,3897],{"class":3852},[3364,8262,7579],{"class":3882},[3364,8264,3619],{"class":3852},[3364,8266,8267],{"class":3882},"WriteHealthCheckUIResponse\n",[3364,8269,8270],{"class":3366,"line":3796},[3364,8271,4571],{"class":3852},[3364,8273,8274],{"class":3366,"line":3802},[3364,8275,3389],{"emptyLinePlaceholder":3388},[3364,8277,8278,8280,8282,8284,8286,8288,8290,8292],{"class":3366,"line":3808},[3364,8279,4051],{"class":3882},[3364,8281,3619],{"class":3852},[3364,8283,4056],{"class":3870},[3364,8285,3982],{"class":3852},[3364,8287,7049],{"class":4061},[3364,8289,4228],{"class":3852},[3364,8291,4231],{"class":3839},[3364,8293,4234],{"class":3846},[3364,8295,8296],{"class":3366,"line":3813},[3364,8297,3853],{"class":3852},[3364,8299,8300,8302,8304,8306,8308,8310,8312,8314,8316,8318,8320,8322],{"class":3366,"line":3818},[3364,8301,6989],{"class":3882},[3364,8303,3897],{"class":3852},[3364,8305,8236],{"class":3882},[3364,8307,4391],{"class":3852},[3364,8309,8236],{"class":3882},[3364,8311,3619],{"class":3852},[3364,8313,7003],{"class":3882},[3364,8315,3619],{"class":3852},[3364,8317,7008],{"class":3870},[3364,8319,3982],{"class":3852},[3364,8321,6864],{"class":4061},[3364,8323,5693],{"class":3852},[3364,8325,8326,8328,8330,8332,8334],{"class":3366,"line":5119},[3364,8327,4243],{"class":3882},[3364,8329,3897],{"class":3852},[3364,8331,7579],{"class":3882},[3364,8333,3619],{"class":3852},[3364,8335,8267],{"class":3882},[3364,8337,8338],{"class":3366,"line":5124},[3364,8339,4571],{"class":3852},[3364,8341,8342],{"class":3366,"line":5129},[3364,8343,3389],{"emptyLinePlaceholder":3388},[3364,8345,8347,8349,8351,8353,8355,8357,8359,8361],{"class":3366,"line":8346},45,[3364,8348,4051],{"class":3882},[3364,8350,3619],{"class":3852},[3364,8352,4056],{"class":3870},[3364,8354,3982],{"class":3852},[3364,8356,4062],{"class":4061},[3364,8358,4228],{"class":3852},[3364,8360,4231],{"class":3839},[3364,8362,4234],{"class":3846},[3364,8364,8366],{"class":3366,"line":8365},46,[3364,8367,3853],{"class":3852},[3364,8369,8371,8373,8375,8377,8379],{"class":3366,"line":8370},47,[3364,8372,4243],{"class":3882},[3364,8374,3897],{"class":3852},[3364,8376,7579],{"class":3882},[3364,8378,3619],{"class":3852},[3364,8380,8267],{"class":3882},[3364,8382,8384],{"class":3366,"line":8383},48,[3364,8385,4571],{"class":3852},[3364,8387,8389],{"class":3366,"line":8388},49,[3364,8390,3389],{"emptyLinePlaceholder":3388},[3364,8392,8394,8396,8398,8400,8402,8405,8407,8409,8411,8413,8415,8417],{"class":3366,"line":8393},50,[3364,8395,4051],{"class":3882},[3364,8397,3619],{"class":3852},[3364,8399,7609],{"class":3870},[3364,8401,3982],{"class":3852},[3364,8403,8404],{"class":3882},"o",[3364,8406,4391],{"class":3852},[3364,8408,8404],{"class":3882},[3364,8410,3619],{"class":3852},[3364,8412,7629],{"class":3882},[3364,8414,3897],{"class":3852},[3364,8416,7634],{"class":4061},[3364,8418,3903],{"class":3852},[3364,8420,8422],{"class":3366,"line":8421},51,[3364,8423,3389],{"emptyLinePlaceholder":3388},[3364,8425,8427,8429,8431,8434,8436,8439,8442,8445],{"class":3366,"line":8426},52,[3364,8428,4051],{"class":3882},[3364,8430,3619],{"class":3852},[3364,8432,8433],{"class":3870},"MapGet",[3364,8435,3982],{"class":3852},[3364,8437,8438],{"class":4061},"\"\u002F\"",[3364,8440,8441],{"class":3852},", () => ",[3364,8443,8444],{"class":4061},"\"Hello, World!\"",[3364,8446,3903],{"class":3852},[3364,8448,8450],{"class":3366,"line":8449},53,[3364,8451,3389],{"emptyLinePlaceholder":3388},[3364,8453,8455,8457,8459,8461],{"class":3366,"line":8454},54,[3364,8456,4051],{"class":3882},[3364,8458,3619],{"class":3852},[3364,8460,4077],{"class":3870},[3364,8462,4015],{"class":3852},[3355,8464,8466],{"className":3830,"code":8465,"filename":5337,"language":3832,"meta":3360,"style":3360},"using Microsoft.Extensions.Diagnostics.HealthChecks;\n\npublic class MemoryHealthCheck : IHealthCheck\n{\n    private const long DegradedThreshold = 512L * 1024 * 1024;  \u002F\u002F 512 MB\n    private const long UnhealthyThreshold = 1024L * 1024 * 1024; \u002F\u002F 1 GB\n\n    public Task\u003CHealthCheckResult> CheckHealthAsync(\n        HealthCheckContext context,\n        CancellationToken cancellationToken = default)\n    {\n        var allocated = GC.GetTotalMemory(forceFullCollection: false);\n        var data = new Dictionary\u003Cstring, object>\n        {\n            [\"allocated_mb\"] = allocated \u002F 1024 \u002F 1024,\n        };\n\n        if (allocated >= UnhealthyThreshold)\n            return Task.FromResult(HealthCheckResult.Unhealthy(\n                $\"Memory critical: {allocated \u002F 1024 \u002F 1024} MB\", data: data));\n\n        if (allocated >= DegradedThreshold)\n            return Task.FromResult(HealthCheckResult.Degraded(\n                $\"Memory elevated: {allocated \u002F 1024 \u002F 1024} MB\", data: data));\n\n        return Task.FromResult(HealthCheckResult.Healthy(\n            $\"Memory OK: {allocated \u002F 1024 \u002F 1024} MB\", data: data));\n    }\n}\n",[3347,8467,8468,8488,8492,8504,8508,8539,8569,8573,8589,8597,8609,8613,8637,8659,8663,8683,8687,8691,8706,8726,8757,8761,8776,8796,8827,8831,8851,8882,8886],{"__ignoreMap":3360},[3364,8469,8470,8472,8474,8476,8478,8480,8482,8484,8486],{"class":3366,"line":3367},[3364,8471,4148],{"class":4147},[3364,8473,4151],{"class":3846},[3364,8475,3619],{"class":3852},[3364,8477,4180],{"class":3846},[3364,8479,3619],{"class":3852},[3364,8481,4161],{"class":3846},[3364,8483,3619],{"class":3852},[3364,8485,4166],{"class":3846},[3364,8487,4169],{"class":3852},[3364,8489,8490],{"class":3366,"line":3373},[3364,8491,3389],{"emptyLinePlaceholder":3388},[3364,8493,8494,8496,8498,8500,8502],{"class":3366,"line":3379},[3364,8495,3840],{"class":3839},[3364,8497,4696],{"class":3839},[3364,8499,5372],{"class":3846},[3364,8501,4702],{"class":3852},[3364,8503,4705],{"class":3846},[3364,8505,8506],{"class":3366,"line":3385},[3364,8507,3853],{"class":3852},[3364,8509,8510,8512,8515,8517,8520,8522,8525,8527,8529,8531,8533,8536],{"class":3366,"line":3392},[3364,8511,4714],{"class":3839},[3364,8513,8514],{"class":3839}," const",[3364,8516,5394],{"class":3839},[3364,8518,8519],{"class":3882}," DegradedThreshold",[3364,8521,3897],{"class":3852},[3364,8523,8524],{"class":5027},"512L",[3364,8526,5481],{"class":3852},[3364,8528,5478],{"class":5027},[3364,8530,5481],{"class":3852},[3364,8532,5478],{"class":5027},[3364,8534,8535],{"class":3852},";  ",[3364,8537,8538],{"class":3996},"\u002F\u002F 512 MB\n",[3364,8540,8541,8543,8545,8547,8550,8552,8555,8557,8559,8561,8563,8566],{"class":3366,"line":3398},[3364,8542,4714],{"class":3839},[3364,8544,8514],{"class":3839},[3364,8546,5394],{"class":3839},[3364,8548,8549],{"class":3882}," UnhealthyThreshold",[3364,8551,3897],{"class":3852},[3364,8553,8554],{"class":5027},"1024L",[3364,8556,5481],{"class":3852},[3364,8558,5478],{"class":5027},[3364,8560,5481],{"class":3852},[3364,8562,5478],{"class":5027},[3364,8564,8565],{"class":3852},"; ",[3364,8567,8568],{"class":3996},"\u002F\u002F 1 GB\n",[3364,8570,8571],{"class":3366,"line":3403},[3364,8572,3389],{"emptyLinePlaceholder":3388},[3364,8574,8575,8577,8579,8581,8583,8585,8587],{"class":3366,"line":3409},[3364,8576,4734],{"class":3839},[3364,8578,4781],{"class":3846},[3364,8580,3861],{"class":3852},[3364,8582,3864],{"class":3846},[3364,8584,3867],{"class":3852},[3364,8586,3871],{"class":3870},[3364,8588,3874],{"class":3852},[3364,8590,8591,8593,8595],{"class":3366,"line":3414},[3364,8592,3879],{"class":3846},[3364,8594,3883],{"class":3882},[3364,8596,3886],{"class":3852},[3364,8598,8599,8601,8603,8605,8607],{"class":3366,"line":3420},[3364,8600,3891],{"class":3846},[3364,8602,3894],{"class":3882},[3364,8604,3897],{"class":3852},[3364,8606,3900],{"class":3839},[3364,8608,4747],{"class":3852},[3364,8610,8611],{"class":3366,"line":3426},[3364,8612,4267],{"class":3852},[3364,8614,8615,8617,8619,8621,8623,8625,8627,8629,8631,8633,8635],{"class":3366,"line":3432},[3364,8616,4298],{"class":3839},[3364,8618,5578],{"class":3882},[3364,8620,3897],{"class":3852},[3364,8622,5583],{"class":3882},[3364,8624,3619],{"class":3852},[3364,8626,5588],{"class":3870},[3364,8628,3982],{"class":3852},[3364,8630,5593],{"class":3882},[3364,8632,4597],{"class":3852},[3364,8634,5598],{"class":3839},[3364,8636,3903],{"class":3852},[3364,8638,8639,8641,8643,8645,8647,8649,8651,8653,8655,8657],{"class":3366,"line":3438},[3364,8640,4298],{"class":3839},[3364,8642,5607],{"class":3882},[3364,8644,3897],{"class":3852},[3364,8646,4231],{"class":3839},[3364,8648,5614],{"class":3846},[3364,8650,3861],{"class":3852},[3364,8652,5619],{"class":3839},[3364,8654,4228],{"class":3852},[3364,8656,5624],{"class":3839},[3364,8658,5627],{"class":3852},[3364,8660,8661],{"class":3366,"line":3444},[3364,8662,4321],{"class":3852},[3364,8664,8665,8667,8669,8671,8673,8675,8677,8679,8681],{"class":3366,"line":3450},[3364,8666,5636],{"class":3852},[3364,8668,5654],{"class":4061},[3364,8670,5642],{"class":3852},[3364,8672,5645],{"class":3882},[3364,8674,5661],{"class":3852},[3364,8676,5478],{"class":5027},[3364,8678,5661],{"class":3852},[3364,8680,5478],{"class":5027},[3364,8682,3886],{"class":3852},[3364,8684,8685],{"class":3366,"line":3456},[3364,8686,5741],{"class":3852},[3364,8688,8689],{"class":3366,"line":3461},[3364,8690,3389],{"emptyLinePlaceholder":3388},[3364,8692,8693,8695,8697,8699,8701,8704],{"class":3366,"line":3467},[3364,8694,5750],{"class":4147},[3364,8696,4251],{"class":3852},[3364,8698,5645],{"class":3882},[3364,8700,5757],{"class":3852},[3364,8702,8703],{"class":3882},"UnhealthyThreshold",[3364,8705,4747],{"class":3852},[3364,8707,8708,8710,8712,8714,8716,8718,8720,8722,8724],{"class":3366,"line":3473},[3364,8709,4973],{"class":4147},[3364,8711,4781],{"class":3882},[3364,8713,3619],{"class":3852},[3364,8715,5773],{"class":3870},[3364,8717,3982],{"class":3852},[3364,8719,3864],{"class":3882},[3364,8721,3619],{"class":3852},[3364,8723,3349],{"class":3870},[3364,8725,3874],{"class":3852},[3364,8727,8728,8731,8733,8735,8737,8739,8741,8743,8745,8747,8749,8751,8753,8755],{"class":3366,"line":3479},[3364,8729,8730],{"class":4061},"                $\"Memory critical: ",[3364,8732,4587],{"class":5791},[3364,8734,5645],{"class":3882},[3364,8736,5796],{"class":3852},[3364,8738,5799],{"class":5027},[3364,8740,5796],{"class":3852},[3364,8742,5799],{"class":5027},[3364,8744,4626],{"class":5791},[3364,8746,5808],{"class":4061},[3364,8748,4228],{"class":3852},[3364,8750,5813],{"class":3882},[3364,8752,4597],{"class":3852},[3364,8754,5813],{"class":3882},[3364,8756,5820],{"class":3852},[3364,8758,8759],{"class":3366,"line":3485},[3364,8760,3389],{"emptyLinePlaceholder":3388},[3364,8762,8763,8765,8767,8769,8771,8774],{"class":3366,"line":3490},[3364,8764,5750],{"class":4147},[3364,8766,4251],{"class":3852},[3364,8768,5645],{"class":3882},[3364,8770,5757],{"class":3852},[3364,8772,8773],{"class":3882},"DegradedThreshold",[3364,8775,4747],{"class":3852},[3364,8777,8778,8780,8782,8784,8786,8788,8790,8792,8794],{"class":3366,"line":3495},[3364,8779,4973],{"class":4147},[3364,8781,4781],{"class":3882},[3364,8783,3619],{"class":3852},[3364,8785,5773],{"class":3870},[3364,8787,3982],{"class":3852},[3364,8789,3864],{"class":3882},[3364,8791,3619],{"class":3852},[3364,8793,5048],{"class":3870},[3364,8795,3874],{"class":3852},[3364,8797,8798,8801,8803,8805,8807,8809,8811,8813,8815,8817,8819,8821,8823,8825],{"class":3366,"line":3500},[3364,8799,8800],{"class":4061},"                $\"Memory elevated: ",[3364,8802,4587],{"class":5791},[3364,8804,5645],{"class":3882},[3364,8806,5796],{"class":3852},[3364,8808,5799],{"class":5027},[3364,8810,5796],{"class":3852},[3364,8812,5799],{"class":5027},[3364,8814,4626],{"class":5791},[3364,8816,5808],{"class":4061},[3364,8818,4228],{"class":3852},[3364,8820,5813],{"class":3882},[3364,8822,4597],{"class":3852},[3364,8824,5813],{"class":3882},[3364,8826,5820],{"class":3852},[3364,8828,8829],{"class":3366,"line":3505},[3364,8830,3389],{"emptyLinePlaceholder":3388},[3364,8832,8833,8835,8837,8839,8841,8843,8845,8847,8849],{"class":3366,"line":3511},[3364,8834,5899],{"class":4147},[3364,8836,4781],{"class":3882},[3364,8838,3619],{"class":3852},[3364,8840,5773],{"class":3870},[3364,8842,3982],{"class":3852},[3364,8844,3864],{"class":3882},[3364,8846,3619],{"class":3852},[3364,8848,4092],{"class":3870},[3364,8850,3874],{"class":3852},[3364,8852,8853,8856,8858,8860,8862,8864,8866,8868,8870,8872,8874,8876,8878,8880],{"class":3366,"line":3517},[3364,8854,8855],{"class":4061},"            $\"Memory OK: ",[3364,8857,4587],{"class":5791},[3364,8859,5645],{"class":3882},[3364,8861,5796],{"class":3852},[3364,8863,5799],{"class":5027},[3364,8865,5796],{"class":3852},[3364,8867,5799],{"class":5027},[3364,8869,4626],{"class":5791},[3364,8871,5808],{"class":4061},[3364,8873,4228],{"class":3852},[3364,8875,5813],{"class":3882},[3364,8877,4597],{"class":3852},[3364,8879,5813],{"class":3882},[3364,8881,5820],{"class":3852},[3364,8883,8884],{"class":3366,"line":3523},[3364,8885,3671],{"class":3852},[3364,8887,8888],{"class":3366,"line":3528},[3364,8889,3453],{"class":3852},[3355,8891,8896],{"className":8892,"code":8893,"filename":8894,"language":8895,"meta":3360,"style":3360},"language-json shiki shiki-themes light-plus dark-plus dark-plus","{\n    \"ConnectionStrings\": {\n        \"Default\": \"Server=localhost;Database=MyDb;User Id=sa;Password=YourPass;\",\n        \"Redis\": \"localhost:6379\"\n    }\n}\n","appsettings.json","json",[3347,8897,8898,8902,8911,8923,8933,8937],{"__ignoreMap":3360},[3364,8899,8900],{"class":3366,"line":3367},[3364,8901,3853],{"class":3852},[3364,8903,8904,8908],{"class":3366,"line":3373},[3364,8905,8907],{"class":8906},"sLwNe","    \"ConnectionStrings\"",[3364,8909,8910],{"class":3852},": {\n",[3364,8912,8913,8916,8918,8921],{"class":3366,"line":3379},[3364,8914,8915],{"class":8906},"        \"Default\"",[3364,8917,4597],{"class":3852},[3364,8919,8920],{"class":4061},"\"Server=localhost;Database=MyDb;User Id=sa;Password=YourPass;\"",[3364,8922,3886],{"class":3852},[3364,8924,8925,8928,8930],{"class":3366,"line":3385},[3364,8926,8927],{"class":8906},"        \"Redis\"",[3364,8929,4597],{"class":3852},[3364,8931,8932],{"class":4061},"\"localhost:6379\"\n",[3364,8934,8935],{"class":3366,"line":3392},[3364,8936,3671],{"class":3852},[3364,8938,8939],{"class":3366,"line":3398},[3364,8940,3453],{"class":3852},[4095,8942,8944,8953,8959,8965,8971,8977,8983,8989],{"title":8943},"Результат GET \u002Fhealth",[4099,8945,8947,4107,8950],{"className":8946},[3366],[3364,8948,4106],{"className":8949},[4105],[3316,8951,8952],{},"curl http:\u002F\u002Flocalhost:5000\u002Fhealth | jq .status,.checks[].name,.checks[].status",[4099,8954,8956],{"className":8955},[3366],[3364,8957,4601],{"className":8958},[4118],[4099,8960,8962],{"className":8961},[3366],[3364,8963,6246],{"className":8964},[4118],[4099,8966,8968],{"className":8967},[3366],[3364,8969,4601],{"className":8970},[4118],[4099,8972,8974],{"className":8973},[3366],[3364,8975,6381],{"className":8976},[4118],[4099,8978,8980],{"className":8979},[3366],[3364,8981,4601],{"className":8982},[4118],[4099,8984,8986],{"className":8985},[3366],[3364,8987,6542],{"className":8988},[4118],[4099,8990,8992],{"className":8991},[3366],[3364,8993,4601],{"className":8994},[4118],[3328,8996],{},[3331,8998,9000],{"id":8999},"підсумок","Підсумок",[3312,9002,9003,9004,9007],{},"Health Checks — це ",[3316,9005,9006],{},"перший і найпростіший"," рівень observability, який потрібно налаштувати у будь-якому ASP.NET Core додатку. Без них Load Balancer і Kubernetes не знають, коли ваш сервіс несправний, і продовжують надсилати трафік на зламані інстанси.",[9009,9010,9011,9024],"table",{},[9012,9013,9014],"thead",{},[9015,9016,9017,9021],"tr",{},[9018,9019,9020],"th",{},"Що",[9018,9022,9023],{},"Як",[9025,9026,9027,9042,9052,9062,9079,9092],"tbody",{},[9015,9028,9029,9033],{},[9030,9031,9032],"td",{},"Базова реєстрація",[9030,9034,9035,9038,9039],{},[3347,9036,9037],{},"services.AddHealthChecks()"," + ",[3347,9040,9041],{},"app.MapHealthChecks(\"\u002Fhealth\")",[9015,9043,9044,9047],{},[9030,9045,9046],{},"Кастомна перевірка",[9030,9048,9049,9050],{},"Реалізувати ",[3347,9051,3826],{},[9015,9053,9054,9057],{},[9030,9055,9056],{},"Готові перевірки (DB, Redis)",[9030,9058,9059,9061],{},[3347,9060,5969],{}," NuGet пакети",[9015,9063,9064,9067],{},[9030,9065,9066],{},"Kubernetes liveness",[9030,9068,9069,9072,9073,9076,9077],{},[3347,9070,9071],{},"MapHealthChecks(\"\u002Fhealth\u002Flive\")"," з ",[3347,9074,9075],{},"Predicate"," по тегу ",[3347,9078,6830],{},[9015,9080,9081,9084],{},[9030,9082,9083],{},"Kubernetes readiness",[9030,9085,9086,9089,9090],{},[3347,9087,9088],{},"MapHealthChecks(\"\u002Fhealth\u002Fready\")"," з тегом ",[3347,9091,6864],{},[9015,9093,9094,9097],{},[9030,9095,9096],{},"Веб-дашборд",[9030,9098,9099,9038,9102],{},[3347,9100,9101],{},"AddHealthChecksUI().AddInMemoryStorage()",[3347,9103,9104],{},"MapHealthChecksUI()",[5196,9106,9107,9108,9111],{},"На наступному кроці переходимо до ",[3316,9109,9110],{},"метрик"," — числових вимірів у часі. Якщо health checks дають бінарну відповідь «живий\u002Fмертвий», метрики дадуть відповідь «наскільки добре живий і що саме сповільнюється».",[9113,9114,9115],"style",{},"html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sN1BT, html code.shiki .sN1BT{--shiki-light:#267F99;--shiki-default:#4EC9B0;--shiki-dark:#4EC9B0}html pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .s8xlr, html code.shiki .s8xlr{--shiki-light:#AF00DB;--shiki-default:#C586C0;--shiki-dark:#C586C0}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html pre.shiki code .sD7JJ, html code.shiki .sD7JJ{--shiki-light:#000000FF;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .s0P7L, html code.shiki .s0P7L{--shiki-light:#800000;--shiki-default:#808080;--shiki-dark:#808080}html pre.shiki code .sKtos, html code.shiki .sKtos{--shiki-light:#800000;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sa4r_, html code.shiki .sa4r_{--shiki-light:#E50000;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .su9tN, html code.shiki .su9tN{--shiki-light:#0000FF;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .sLwNe, html code.shiki .sLwNe{--shiki-light:#0451A5;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}",{"title":3360,"searchDepth":3373,"depth":3373,"links":9117},[9118,9123,9124,9125,9127,9129,9131,9132,9133,9134],{"id":3333,"depth":3373,"text":3334,"children":9119},[9120,9121,9122],{"id":3338,"depth":3379,"text":3339},{"id":3569,"depth":3379,"text":3570},{"id":3595,"depth":3379,"text":3596},{"id":3607,"depth":3373,"text":3608},{"id":3951,"depth":3373,"text":3952},{"id":4631,"depth":3373,"text":9126},"Кастомний IHealthCheck: перевірка бази даних",{"id":5326,"depth":3373,"text":9128},"Кастомна перевірка пам'яті: Degraded у дії",{"id":5965,"depth":3373,"text":9130},"Community-бібліотека: AspNetCore.HealthChecks.*",{"id":6566,"depth":3373,"text":6567},{"id":7296,"depth":3373,"text":7297},{"id":7789,"depth":3373,"text":7790},{"id":8999,"depth":3373,"text":9000},"Повний розгляд ASP.NET Core Health Checks у .NET 10: IHealthCheck інтерфейс, вбудовані та кастомні перевірки, community-бібліотека AspNetCore.HealthChecks, HealthCheckUI, патерн liveness\u002Freadiness для Kubernetes та Docker.","md",null,{},{"title":1357,"description":9135},"_-FObsFmpJogXDcKsYaNtX6xj3-sUW5BGkUapkkmjYU",[9142,9144],{"title":1353,"path":1354,"stem":1355,"description":9143,"children":-1},"Фундаментальний вступ до observability: що це таке, чим відрізняється від моніторингу, три стовпи (метрики, логи, трейси) та четвертий — профілювання. Огляд LGTM-стеку як інструментарію курсу.",{"title":1361,"path":1362,"stem":1363,"description":9145,"children":-1},"Глибоке дослідження вбудованих метрик у .NET 10 та ASP.NET Core: архітектура System.Diagnostics.Metrics, типи вимірювальних інструментів, кастомна інструментація бізнес-логіки та аналіз у реальному часі через CLI-утиліту dotnet-counters.",1781795445878]