[{"data":1,"prerenderedAt":8681},["ShallowReactive",2],{"navigation_docs":3,"-aws-03a-docker-ecs-doc":3338,"-aws-03a-docker-ecs-doc-surround":8676},[4,1707,1904,2358,2539,2608,2815,2937,2987,3044,3078,3204,3281,3334],{"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,1896,1900],{"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},"Об'єднання (union): один блок пам'яті, кілька інтерпретацій","\u002Fcpp\u002Funion","02.cpp\u002F45.union",{"title":1897,"path":1898,"stem":1899},"Організація коду: файли, препроцесор, простори імен","\u002Fcpp\u002Fmultifile-programs","02.cpp\u002F46.multifile-programs",{"title":1901,"path":1902,"stem":1903},"План навчання: Курс C++ — Продовження (Статті 29–60+)","\u002Fcpp\u002Fcurriculum-plan","02.cpp\u002Fcurriculum-plan",{"title":1905,"icon":1906,"path":1907,"stem":1908,"children":1909,"page":59},"JavaScript","i-devicon-javascript","\u002Fjavascript","03.javascript",[1910,1936,1990,2012,2316,2354],{"title":1911,"icon":1912,"path":1913,"stem":1914,"children":1915,"page":59},"Events","i-lucide-mouse-pointer-click","\u002Fjavascript\u002Fevents","03.javascript\u002F01.events",[1916,1920,1924,1928,1932],{"title":1917,"path":1918,"stem":1919},"Вступ до подій браузера","\u002Fjavascript\u002Fevents\u002Fintro","03.javascript\u002F01.events\u002F01.intro",{"title":1921,"path":1922,"stem":1923},"Бульбашковий механізм (Bubbling) та занурення (Capturing)","\u002Fjavascript\u002Fevents\u002Fbubbling-capturing","03.javascript\u002F01.events\u002F02.bubbling-capturing",{"title":1925,"path":1926,"stem":1927},"Делегування подій (Event Delegation)","\u002Fjavascript\u002Fevents\u002Fdelegate-events","03.javascript\u002F01.events\u002F03.delegate-events",{"title":1929,"path":1930,"stem":1931},"Типові дії браузера та preventDefault()","\u002Fjavascript\u002Fevents\u002Fprevent-default","03.javascript\u002F01.events\u002F04.prevent-default",{"title":1933,"path":1934,"stem":1935},"Запуск користувацьких подій (Custom Events)","\u002Fjavascript\u002Fevents\u002Fcustom-events","03.javascript\u002F01.events\u002F05.custom-events",{"title":1937,"icon":1938,"path":1939,"stem":1940,"children":1941,"page":59},"Network","i-lucide-globe","\u002Fjavascript\u002Fnetwork","03.javascript\u002F02.network",[1942,1946,1950,1954,1958,1962,1966,1970,1974,1978,1982,1986],{"title":1943,"path":1944,"stem":1945},"Fetch API - Сучасний підхід до HTTP-запитів","\u002Fjavascript\u002Fnetwork\u002F01-fetch-api","03.javascript\u002F02.network\u002F01-fetch-api",{"title":1947,"path":1948,"stem":1949},"FormData - Робота з формами та файлами","\u002Fjavascript\u002Fnetwork\u002F02-formdata","03.javascript\u002F02.network\u002F02-formdata",{"title":1951,"path":1952,"stem":1953},"Відстеження прогресу завантаження","\u002Fjavascript\u002Fnetwork\u002F03-download-progress","03.javascript\u002F02.network\u002F03-download-progress",{"title":1955,"path":1956,"stem":1957},"Переривання fetch-запитів","\u002Fjavascript\u002Fnetwork\u002F04-abort-requests","03.javascript\u002F02.network\u002F04-abort-requests",{"title":1959,"path":1960,"stem":1961},"CORS - Запити між різними джерелами","\u002Fjavascript\u002Fnetwork\u002F05-cors","03.javascript\u002F02.network\u002F05-cors",{"title":1963,"path":1964,"stem":1965},"Fetch API - Повний довідник опцій","\u002Fjavascript\u002Fnetwork\u002F06-fetch-options","03.javascript\u002F02.network\u002F06-fetch-options",{"title":1967,"path":1968,"stem":1969},"URL Objects - Робота з посиланнями","\u002Fjavascript\u002Fnetwork\u002F07-url-objects","03.javascript\u002F02.network\u002F07-url-objects",{"title":1971,"path":1972,"stem":1973},"XMLHttpRequest - AJAX та низькорівневі запити","\u002Fjavascript\u002Fnetwork\u002F08-xmlhttprequest","03.javascript\u002F02.network\u002F08-xmlhttprequest",{"title":1975,"path":1976,"stem":1977},"Відновлюване завантаження файлів","\u002Fjavascript\u002Fnetwork\u002F09-resumable-upload","03.javascript\u002F02.network\u002F09-resumable-upload",{"title":1979,"path":1980,"stem":1981},"Cookies, document.cookie та світ після \"Cookiepocalypse\"","\u002Fjavascript\u002Fnetwork\u002F10-cookies","03.javascript\u002F02.network\u002F10-cookies",{"title":1983,"path":1984,"stem":1985},"js-cookie: Керування Cookies без Болю","\u002Fjavascript\u002Fnetwork\u002F11-js-cookie","03.javascript\u002F02.network\u002F11-js-cookie",{"title":1987,"path":1988,"stem":1989},"Axios: Потужний HTTP-клієнт для JavaScript","\u002Fjavascript\u002Fnetwork\u002F12-axios","03.javascript\u002F02.network\u002F12-axios",{"title":1991,"icon":1992,"path":1993,"stem":1994,"children":1995,"page":59},"Bom","i-lucide-monitor","\u002Fjavascript\u002Fbom","03.javascript\u002F03.bom",[1996,2000,2004,2008],{"title":1997,"path":1998,"stem":1999},"LocalStorage, SessionStorage та patterns збереження даних","\u002Fjavascript\u002Fbom\u002F01-localstorage","03.javascript\u002F03.bom\u002F01-localstorage",{"title":2001,"path":2002,"stem":2003},"Location Object - Керування адресою сторінки","\u002Fjavascript\u002Fbom\u002F02-location-object","03.javascript\u002F03.bom\u002F02-location-object",{"title":2005,"path":2006,"stem":2007},"History API - Керування історією браузера","\u002Fjavascript\u002Fbom\u002F03-history-api","03.javascript\u002F03.bom\u002F03-history-api",{"title":2009,"path":2010,"stem":2011},"Navigator Object - Ідентифікація та Можливості Пристрою","\u002Fjavascript\u002Fbom\u002F04-navigator-object","03.javascript\u002F03.bom\u002F04-navigator-object",{"title":2013,"icon":2014,"path":2015,"stem":2016,"children":2017},"React","i-devicon-react","\u002Fjavascript\u002Freact","03.javascript\u002F04.react\u002Findex",[2018,2019,2023,2027,2031,2035,2098,2133,2285],{"title":2013,"path":2015,"stem":2016},{"title":2020,"path":2021,"stem":2022},"Робота з Формами в React","\u002Fjavascript\u002Freact\u002Freact-forms","03.javascript\u002F04.react\u002F01.react-forms",{"title":2024,"path":2025,"stem":2026},"React Hook Form: Професійна Робота з Формами","\u002Fjavascript\u002Freact\u002Freact-hook-form","03.javascript\u002F04.react\u002F02.react-hook-form",{"title":2028,"path":2029,"stem":2030},"React Hook Form: Глибоке Розуміння Архітектури та Оптимізації","\u002Fjavascript\u002Freact\u002Freact-hook-form-new","03.javascript\u002F04.react\u002F02.react-hook-form-new",{"title":2032,"path":2033,"stem":2034},"Axios та React: Професійна Архітектура Запитів","\u002Fjavascript\u002Freact\u002Fdata-fetching-axios","03.javascript\u002F04.react\u002F03.data-fetching-axios",{"title":2036,"icon":132,"path":2037,"stem":2038,"children":2039},"Tanstack Query","\u002Fjavascript\u002Freact\u002Ftanstack-query","03.javascript\u002F04.react\u002F04.tanstack-query\u002Findex",[2040,2042,2046,2050,2054,2058,2062,2066,2070,2074,2078,2082,2086,2090,2094],{"title":2041,"path":2037,"stem":2038},"TanStack Query: Майстерність Керування Станом Сервера",{"title":2043,"path":2044,"stem":2045},"Парадигма Server State: Чому useEffect недостатньо","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-state-paradigm","03.javascript\u002F04.react\u002F04.tanstack-query\u002F01.server-state-paradigm",{"title":2047,"path":2048,"stem":2049},"Встановлення та Налаштування: Фундамент","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Finstallation-and-devtools","03.javascript\u002F04.react\u002F04.tanstack-query\u002F02.installation-and-devtools",{"title":2051,"path":2052,"stem":2053},"Основи Запитів та Магія Ключів","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fquery-basics-and-keys","03.javascript\u002F04.react\u002F04.tanstack-query\u002F03.query-basics-and-keys",{"title":2055,"path":2056,"stem":2057},"Синхронізація Даних: Життєвий Цикл Запиту","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fdata-synchronization","03.javascript\u002F04.react\u002F04.tanstack-query\u002F04.data-synchronization",{"title":2059,"path":2060,"stem":2061},"Мутації та Інвалідація: Зміна Даних","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fmutations-and-invalidation","03.javascript\u002F04.react\u002F04.tanstack-query\u002F05.mutations-and-invalidation",{"title":2063,"path":2064,"stem":2065},"Оптимістичні Оновлення: Швидше за Світло","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Foptimistic-updates","03.javascript\u002F04.react\u002F04.tanstack-query\u002F06.optimistic-updates",{"title":2067,"path":2068,"stem":2069},"Пагінація та Infinite Scroll","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fpagination-and-load-more","03.javascript\u002F04.react\u002F04.tanstack-query\u002F07.pagination-and-load-more",{"title":2071,"path":2072,"stem":2073},"Просунуті Патерни та Оптимізація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F04.tanstack-query\u002F08.advanced-patterns",{"title":2075,"path":2076,"stem":2077},"Архітектура та Best Practices","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Farchitecture-and-best-practices","03.javascript\u002F04.react\u002F04.tanstack-query\u002F09.architecture-and-best-practices",{"title":2079,"path":2080,"stem":2081},"Server-Side Rendering (SSR) та Гідратація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-side-rendering","03.javascript\u002F04.react\u002F04.tanstack-query\u002F10.server-side-rendering",{"title":2083,"path":2084,"stem":2085},"Стратегії Тестування","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Ftesting-strategies","03.javascript\u002F04.react\u002F04.tanstack-query\u002F11.testing-strategies",{"title":2087,"path":2088,"stem":2089},"Аутентифікація та Обробка Помилок","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fauthentication-and-errors","03.javascript\u002F04.react\u002F04.tanstack-query\u002F12.authentication-and-errors",{"title":2091,"path":2092,"stem":2093},"React Suspense та Майбутнє","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Freact-suspense","03.javascript\u002F04.react\u002F04.tanstack-query\u002F13.react-suspense",{"title":2095,"path":2096,"stem":2097},"Глибоке Занурення в Продуктивність","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fperformance-deep-dive","03.javascript\u002F04.react\u002F04.tanstack-query\u002F14.performance-deep-dive",{"title":2099,"icon":2014,"path":2100,"stem":2101,"children":2102},"React Router","\u002Fjavascript\u002Freact\u002Freact-router","03.javascript\u002F04.react\u002F05.react-router\u002Findex",[2103,2105,2109,2113,2117,2121,2125,2129],{"title":2104,"path":2100,"stem":2101},"React Router: Навігаційна система сучасного вебу",{"title":2106,"path":2107,"stem":2108},"Налаштування та Базовий Роутинг","\u002Fjavascript\u002Freact\u002Freact-router\u002Fsetup-and-basic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F01.setup-and-basic-routing",{"title":2110,"path":2111,"stem":2112},"Динамічна Навігація","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnavigation-and-links","03.javascript\u002F04.react\u002F05.react-router\u002F02.navigation-and-links",{"title":2114,"path":2115,"stem":2116},"Вкладені Маршрути та Макети","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnested-routes-and-layouts","03.javascript\u002F04.react\u002F05.react-router\u002F03.nested-routes-and-layouts",{"title":2118,"path":2119,"stem":2120},"Динамічні Маршрути та Параметри","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdynamic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F04.dynamic-routing",{"title":2122,"path":2123,"stem":2124},"Data APIs: Loaders та Actions","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdata-loading","03.javascript\u002F04.react\u002F05.react-router\u002F05.data-loading",{"title":2126,"path":2127,"stem":2128},"Просунуті Патерни","\u002Fjavascript\u002Freact\u002Freact-router\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F05.react-router\u002F06.advanced-patterns",{"title":2130,"path":2131,"stem":2132},"Legacy Routing: Компонентний підхід","\u002Fjavascript\u002Freact\u002Freact-router\u002Flegacy-routing","03.javascript\u002F04.react\u002F05.react-router\u002F07.legacy-routing",{"title":2134,"icon":132,"path":2135,"stem":2136,"children":2137},"Redux","\u002Fjavascript\u002Freact\u002Fredux","03.javascript\u002F04.react\u002F06.redux\u002Findex",[2138,2140,2156,2185,2194,2215,2231,2260],{"title":2139,"path":2135,"stem":2136},"Redux: Еволюція управління станом",{"title":14,"icon":15,"path":2141,"stem":2142,"children":2143,"page":59},"\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals",[2144,2148,2152],{"title":2145,"path":2146,"stem":2147},"Вступ до State Management","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fintro-state-management","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F01.intro-state-management",{"title":2149,"path":2150,"stem":2151},"Філософія Redux та Три Принципи","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fredux-philosophy","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F02.redux-philosophy",{"title":2153,"path":2154,"stem":2155},"Чисті функції та Іммутабельність","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fpure-functions-immutability","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F03.pure-functions-immutability",{"title":2157,"icon":132,"path":2158,"stem":2159,"children":2160,"page":59},"Classic Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux",[2161,2165,2169,2173,2177,2181],{"title":2162,"path":2163,"stem":2164},"Створення Store (Classic Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fstore-setup","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F01.store-setup",{"title":2166,"path":2167,"stem":2168},"Actions, Constants та Action Creators","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Factions-constants","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F02.actions-constants",{"title":2170,"path":2171,"stem":2172},"Логіка Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freducers","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F03.reducers",{"title":2174,"path":2175,"stem":2176},"Комбінування Reducers (Root Reducer)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fdata-flow","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F04.data-flow",{"title":2178,"path":2179,"stem":2180},"Підключення до 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":2182,"path":2183,"stem":2184},"Middleware та Асинхронність (Redux Thunk)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fmiddleware-thunk","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F06.middleware-thunk",{"title":2186,"icon":132,"path":2187,"stem":2188,"children":2189,"page":59},"Transition To Rtk","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk",[2190],{"title":2191,"path":2192,"stem":2193},"Проблеми класичного 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":2195,"icon":132,"path":2196,"stem":2197,"children":2198,"page":59},"Redux Toolkit","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit",[2199,2203,2207,2211],{"title":2200,"path":2201,"stem":2202},"Налаштування Store з configureStore","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fconfigure-store","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F01.configure-store",{"title":2204,"path":2205,"stem":2206},"createSlice: Революція в Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fcreate-slice","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F02.create-slice",{"title":2208,"path":2209,"stem":2210},"Асинхронність з createAsyncThunk","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fasync-thunks","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F03.async-thunks",{"title":2212,"path":2213,"stem":2214},"04. Entity Adapter: Керування нормалізованим станом","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fentity-adapter","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F04.entity-adapter",{"title":2216,"icon":92,"path":2217,"stem":2218,"children":2219,"page":59},"Advanced","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced",[2220,2224,2228],{"title":2221,"path":2222,"stem":2223},"Мемоізація та Селектори: Повний Гайд по Reselect","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Fselectors-reselect","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F01.selectors-reselect",{"title":2225,"path":2226,"stem":2227},"RTK Query: Архітектура Серверного Кешу","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Frtk-query-intro","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F02.rtk-query-intro",{"title":2075,"path":2229,"stem":2230},"\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Farchitecture-best-practices","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F03.architecture-best-practices",{"title":2232,"icon":132,"path":2233,"stem":2234,"children":2235,"page":59},"Project Kanban","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban",[2236,2240,2244,2248,2252,2256],{"title":2237,"path":2238,"stem":2239},"Проєкт: Kanban Board (Trello Clone)","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fproject-overview","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F01.project-overview",{"title":2241,"path":2242,"stem":2243},"Налаштування та Типізація","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fsetup-and-types","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F02.setup-and-types",{"title":2245,"path":2246,"stem":2247},"Board Slice: Серце Дошки","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fboard-slice","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F03.board-slice",{"title":2249,"path":2250,"stem":2251},"Логіка 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":2253,"path":2254,"stem":2255},"Інтеграція з RTK Query","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Frtk-query-integration","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F05.rtk-query-integration",{"title":2257,"path":2258,"stem":2259},"Optimistic Updates","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Foptimistic-updates","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F06.optimistic-updates",{"title":2261,"icon":132,"path":2262,"stem":2263,"children":2264,"page":59},"Testing","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting","03.javascript\u002F04.react\u002F06.redux\u002F07.testing",[2265,2269,2273,2277,2281],{"title":2266,"path":2267,"stem":2268},"Тестування Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Fintro-testing","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F01.intro-testing",{"title":2270,"path":2271,"stem":2272},"Тестування Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-reducers","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F02.testing-reducers",{"title":2274,"path":2275,"stem":2276},"Тестування Селекторів","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-selectors","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F03.testing-selectors",{"title":2278,"path":2279,"stem":2280},"Тестування Компонентів (Integration)","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-components","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F04.testing-components",{"title":2282,"path":2283,"stem":2284},"Тестування Async Thunks","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-thunks","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F05.testing-thunks",{"title":2286,"icon":132,"path":2287,"stem":2288,"children":2289},"Ui Libraries","\u002Fjavascript\u002Freact\u002Fui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002Findex",[2290,2292,2296,2300,2304,2308,2312],{"title":2291,"path":2287,"stem":2288},"UI Бібліотеки в React",{"title":2293,"path":2294,"stem":2295},"Вступ до UI Бібліотек: Навіщо Винаходити Велосипед Двічі?","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fintroduction-to-ui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002F01.introduction-to-ui-libraries",{"title":2297,"path":2298,"stem":2299},"Філософія shadcn\u002Fui: \"Not a Component Library\"","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-philosophy","03.javascript\u002F04.react\u002F07.ui-libraries\u002F02.shadcn-philosophy",{"title":2301,"path":2302,"stem":2303},"Установка та Налаштування shadcn\u002Fui","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-installation","03.javascript\u002F04.react\u002F07.ui-libraries\u002F03.shadcn-installation",{"title":2305,"path":2306,"stem":2307},"Базові Компоненти shadcn\u002Fui: Фундамент Інтерфейсу","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-basics","03.javascript\u002F04.react\u002F07.ui-libraries\u002F04.shadcn-components-basics",{"title":2309,"path":2310,"stem":2311},"Компоненти Форм: Побудова Інтерактивних Form","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-forms","03.javascript\u002F04.react\u002F07.ui-libraries\u002F05.shadcn-components-forms",{"title":2313,"path":2314,"stem":2315},"Складні Компоненти: Dialog, Dropdown, Table та Command","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-advanced","03.javascript\u002F04.react\u002F07.ui-libraries\u002F06.shadcn-components-advanced",{"title":2317,"icon":2318,"path":2319,"stem":2320,"children":2321,"page":59},"TypeScript","i-devicon-typescript","\u002Fjavascript\u002Ftypescript","03.javascript\u002F05.typescript",[2322,2326,2330,2334,2338,2342,2346,2350],{"title":2323,"path":2324,"stem":2325},"TypeScript: Броня для вашого коду","\u002Fjavascript\u002Ftypescript\u002Fintro-and-basic-types","03.javascript\u002F05.typescript\u002F01.intro-and-basic-types",{"title":2327,"path":2328,"stem":2329},"Майстерність Моделювання Даних: Інтерфейси та Просунуті Типи","\u002Fjavascript\u002Ftypescript\u002Finterfaces-and-advanced-types","03.javascript\u002F05.typescript\u002F02.interfaces-and-advanced-types",{"title":2331,"path":2332,"stem":2333},"Алхімія Типів: Generics та Utility Types","\u002Fjavascript\u002Ftypescript\u002Fgenerics-and-utilities","03.javascript\u002F05.typescript\u002F03.generics-and-utilities",{"title":2335,"path":2336,"stem":2337},"Архітектура та Шаблони: Класи в TypeScript","\u002Fjavascript\u002Ftypescript\u002Fclasses-and-oop","03.javascript\u002F05.typescript\u002F04.classes-and-oop",{"title":2339,"path":2340,"stem":2341},"Продакшн та Екосистема: Advanced Config & Workflow","\u002Fjavascript\u002Ftypescript\u002Fadvanced-patterns-and-config","03.javascript\u002F05.typescript\u002F05.advanced-patterns-and-config",{"title":2343,"path":2344,"stem":2345},"TypeScript у світі React","\u002Fjavascript\u002Ftypescript\u002Freact-basics","03.javascript\u002F05.typescript\u002F06.react-basics",{"title":2347,"path":2348,"stem":2349},"React + TypeScript: Продвинуті патерни","\u002Fjavascript\u002Ftypescript\u002Freact-advanced","03.javascript\u002F05.typescript\u002F07.react-advanced",{"title":2351,"path":2352,"stem":2353},"React + TypeScript: Екосистема та бібліотеки","\u002Fjavascript\u002Ftypescript\u002Freact-ecosystem","03.javascript\u002F05.typescript\u002F08.react-ecosystem",{"title":2355,"path":2356,"stem":2357},"Atomic Design","\u002Fjavascript\u002Fatomic-design","03.javascript\u002F2.atomic-design",{"title":2359,"icon":2360,"path":2361,"stem":2362,"children":2363,"page":59},"Java","i-devicon-java","\u002Fjava","04.java",[2364,2367,2370,2374,2378,2382,2386],{"title":162,"path":2365,"stem":2366},"\u002Fjava\u002Fdata-mapper-part1","04.java\u002F01.data-mapper-part1",{"title":166,"path":2368,"stem":2369},"\u002Fjava\u002Fdata-mapper-part2","04.java\u002F02.data-mapper-part2",{"title":2371,"path":2372,"stem":2373},"Service Layer: Організація бізнес-логіки","\u002Fjava\u002Fservice-layer","04.java\u002F03.service-layer",{"title":2375,"path":2376,"stem":2377},"Rich Domain Model та State Pattern","\u002Fjava\u002Frich-domain-model","04.java\u002F04.rich-domain-model",{"title":2379,"path":2380,"stem":2381},"Патерни для складної бізнес-логіки","\u002Fjava\u002Fbusiness-logic-patterns","04.java\u002F05.business-logic-patterns",{"title":2383,"path":2384,"stem":2385},"Обробка помилок та валідація","\u002Fjava\u002Ferror-handling-validation","04.java\u002F06.error-handling-validation",{"title":2387,"path":2388,"stem":2389,"children":2390,"page":59},"Проектування баз даних","\u002Fjava\u002Fpr2","04.java\u002Fpr2",[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,2531,2535],{"title":2392,"path":2393,"stem":2394},"Концептуальне моделювання: Мистецтво розуміння предметної області","\u002Fjava\u002Fpr2\u002Fconceptual-modeling","04.java\u002Fpr2\u002F01.conceptual-modeling",{"title":2396,"path":2397,"stem":2398},"Логічне моделювання: Від бізнес-ідей до структур даних","\u002Fjava\u002Fpr2\u002Flogical-modeling","04.java\u002Fpr2\u002F02.logical-modeling",{"title":2400,"path":2401,"stem":2402},"Нормалізація: Гігієна даних та боротьба з аномаліями","\u002Fjava\u002Fpr2\u002Fnormalization","04.java\u002Fpr2\u002F03.normalization",{"title":2404,"path":2405,"stem":2406},"Фізична схема: Від абстракції до DDL","\u002Fjava\u002Fpr2\u002Fphysical-schema","04.java\u002Fpr2\u002F04.physical-schema",{"title":2408,"path":2409,"stem":2410},"Архітектурна класифікація таблиць","\u002Fjava\u002Fpr2\u002Ftable-classification","04.java\u002Fpr2\u002F05.table-classification",{"title":2412,"path":2413,"stem":2414},"Database Migrations: Версіонування схеми з Flyway","\u002Fjava\u002Fpr2\u002Fdatabase-migrations","04.java\u002Fpr2\u002F06.database-migrations",{"title":2416,"path":2417,"stem":2418},"А що, якби це була не реляційна БД?","\u002Fjava\u002Fpr2\u002Fbeyond-relational","04.java\u002Fpr2\u002F07.beyond-relational",{"title":2420,"path":2421,"stem":2422},"Object-Relational Impedance Mismatch: Два світи, що не хочуть дружити","\u002Fjava\u002Fpr2\u002Fimpedance-mismatch","04.java\u002Fpr2\u002F09.impedance-mismatch",{"title":2424,"path":2425,"stem":2426},"JDBC: Перший контакт із базою даних","\u002Fjava\u002Fpr2\u002Fjdbc-fundamentals","04.java\u002Fpr2\u002F10.jdbc-fundamentals",{"title":2428,"path":2429,"stem":2430},"Якість коду: Spotless, SpotBugs та SonarQube","\u002Fjava\u002Fpr2\u002F10a.code-quality","04.java\u002Fpr2\u002F10a.code-quality",{"title":2432,"path":2433,"stem":2434},"Connection Pool: Патерн Object Pool для JDBC-з'єднань","\u002Fjava\u002Fpr2\u002Fconnection-pool","04.java\u002Fpr2\u002F11.connection-pool",{"title":2436,"path":2437,"stem":2438},"Row Data Gateway: Об'єкт як обгортка рядка таблиці","\u002Fjava\u002Fpr2\u002Frow-data-gateway","04.java\u002Fpr2\u002F12.row-data-gateway",{"title":2440,"path":2441,"stem":2442},"Table Data Gateway: Фасад таблиці як архітектурний відступ","\u002Fjava\u002Fpr2\u002Ftable-data-gateway","04.java\u002Fpr2\u002F13.table-data-gateway",{"title":2444,"path":2445,"stem":2446},"Repository + Data Mapper: Правильна шарова архітектура з JDBC","\u002Fjava\u002Fpr2\u002Frepository-data-mapper","04.java\u002Fpr2\u002F14.repository-data-mapper",{"title":2448,"path":2449,"stem":2450},"Identity Map: Кешування сутностей у рамках сесії","\u002Fjava\u002Fpr2\u002Fidentity-map","04.java\u002Fpr2\u002F15.identity-map",{"title":2452,"path":2453,"stem":2454},"Unit of Work: Відстеження змін і координація JDBC-транзакцій","\u002Fjava\u002Fpr2\u002Funit-of-work","04.java\u002Fpr2\u002F16.unit-of-work",{"title":2456,"path":2457,"stem":2458},"Strategy: Замінювані SQL-стратегії для підтримки різних СУБД","\u002Fjava\u002Fpr2\u002Fstrategy-sql","04.java\u002Fpr2\u002F17.strategy-sql",{"title":2460,"path":2461,"stem":2462},"Proxy: Lazy Loading для One-To-Many колекцій","\u002Fjava\u002Fpr2\u002Fproxy-lazy-loading","04.java\u002Fpr2\u002F18.proxy-lazy-loading",{"title":2464,"path":2465,"stem":2466},"Generic Repository через Java Reflection: анотації та динамічний SQL","\u002Fjava\u002Fpr2\u002Fgeneric-repository-reflection","04.java\u002Fpr2\u002F19.generic-repository-reflection",{"title":2468,"path":2469,"stem":2470},"Specification Pattern: Композиція бізнес-правил для складних запитів","\u002Fjava\u002Fpr2\u002Fspecification-pattern","04.java\u002Fpr2\u002F20.specification-pattern",{"title":2472,"path":2473,"stem":2474},"Розширені можливості Specification Pattern: підзапити, агрегації та гібридний підхід","\u002Fjava\u002Fpr2\u002F20a.advanced-specifications","04.java\u002Fpr2\u002F20a.advanced-specifications",{"title":2476,"path":2477,"stem":2478},"Асинхронність у JDBC: Від блокуючих викликів до CompletableFuture","\u002Fjava\u002Fpr2\u002Fasynchronous-jdbc","04.java\u002Fpr2\u002F21.asynchronous-jdbc",{"title":2480,"path":2481,"stem":2482},"Інтеграційне тестування JDBC-репозиторіїв: Embedded H2 та патерн AAA","\u002Fjava\u002Fpr2\u002Fintegration-testing-h2","04.java\u002Fpr2\u002F22.integration-testing-h2",{"title":2484,"path":2485,"stem":2486},"Testcontainers: Тестування з реальною PostgreSQL у Docker-контейнерах","\u002Fjava\u002Fpr2\u002Fintegration-testing-testcontainers","04.java\u002Fpr2\u002F23.integration-testing-testcontainers",{"title":2488,"path":2489,"stem":2490},"Google Guice: Впровадження залежностей у JavaFX-проєкті","\u002Fjava\u002Fpr2\u002Fdependency-injection-guice","04.java\u002Fpr2\u002F24.dependency-injection-guice",{"title":2492,"path":2493,"stem":2494},"JavaFX: Основи побудови графічних інтерфейсів","\u002Fjava\u002Fpr2\u002Fjavafx-fundamentals","04.java\u002Fpr2\u002F25.javafx-fundamentals",{"title":2496,"path":2497,"stem":2498},"Properties та Bindings: Реактивність у JavaFX","\u002Fjava\u002Fpr2\u002Fjavafx-properties-bindings","04.java\u002Fpr2\u002F26.javafx-properties-bindings",{"title":2500,"path":2501,"stem":2502},"MVC vs MVP vs MVVM: Еволюція архітектурних патернів UI","\u002Fjava\u002Fpr2\u002Fui-architecture-patterns","04.java\u002Fpr2\u002F27.ui-architecture-patterns",{"title":2504,"path":2505,"stem":2506},"MVVM на практиці: Побудова ViewModel","\u002Fjava\u002Fpr2\u002Fmvvm-viewmodel-implementation","04.java\u002Fpr2\u002F28.mvvm-viewmodel-implementation",{"title":2508,"path":2509,"stem":2510},"View та Controller: Зв'язування з ViewModel через FXML","\u002Fjava\u002Fpr2\u002Fmvvm-view-controller","04.java\u002Fpr2\u002F29.mvvm-view-controller",{"title":2512,"path":2513,"stem":2514},"Інтеграція MVVM з Guice: Автоматична ін'єкція залежностей","\u002Fjava\u002Fpr2\u002Fmvvm-guice-integration","04.java\u002Fpr2\u002F30.mvvm-guice-integration",{"title":2516,"path":2517,"stem":2518},"Валідація та обробка помилок у MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-validation-error-handling","04.java\u002Fpr2\u002F31.mvvm-validation-error-handling",{"title":2520,"path":2521,"stem":2522},"Навігація та управління екранами у JavaFX MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-navigation-screen-management","04.java\u002Fpr2\u002F32.mvvm-navigation-screen-management",{"title":2524,"path":2525,"stem":2526},"Тестування JavaFX MVVM-додатків","\u002Fjava\u002Fpr2\u002Fmvvm-testing","04.java\u002Fpr2\u002F33.mvvm-testing",{"title":2528,"path":2529,"stem":2530},"Стилізація та теми у JavaFX: CSS та User Experience","\u002Fjava\u002Fpr2\u002Fjavafx-styling-themes","04.java\u002Fpr2\u002F34.javafx-styling-themes",{"title":2532,"path":2533,"stem":2534},"AtlantaFX: Сучасні теми для JavaFX додатків","\u002Fjava\u002Fpr2\u002Fatlantafx-modern-themes","04.java\u002Fpr2\u002F35.atlantafx-modern-themes",{"title":2536,"path":2537,"stem":2538},"Пакування та розповсюдження JavaFX-додатків","\u002Fjava\u002Fpr2\u002Fjar-packaging-distribution","04.java\u002Fpr2\u002F36.jar-packaging-distribution",{"title":2540,"icon":2541,"path":2542,"stem":2543,"children":2544,"page":59},"Python","i-devicon-python","\u002Fpython","05.python",[2545,2549,2552,2556,2560,2564,2568,2572,2576,2580,2584,2588,2592,2596,2600,2604],{"title":2546,"path":2547,"stem":2548},"Модулі, Пакети та Віртуальні Середовища","\u002Fpython\u002Fmodules-packages-venv","05.python\u002F00.modules-packages-venv",{"title":71,"path":2550,"stem":2551},"\u002Fpython\u002Fclasses-objects","05.python\u002F01.classes-objects",{"title":2553,"path":2554,"stem":2555},"Інкапсуляція, Керування Доступом та Властивості","\u002Fpython\u002Fencapsulation","05.python\u002F02.encapsulation",{"title":2557,"path":2558,"stem":2559},"Наслідування, MRO та суперсила super()","\u002Fpython\u002Finheritance-mro","05.python\u002F03.inheritance-mro",{"title":2561,"path":2562,"stem":2563},"Абстракція — ABC проти Статичних Протоколів (PEP 544)","\u002Fpython\u002Fabstraction-protocols","05.python\u002F04.abstraction-protocols",{"title":2565,"path":2566,"stem":2567},"Магічні методи (Dunder) та Емуляція протоколів","\u002Fpython\u002Fdunder-methods","05.python\u002F05.dunder-methods",{"title":2569,"path":2570,"stem":2571},"Декоратори та Керування життєвим циклом методів","\u002Fpython\u002Fdecorators-static-class","05.python\u002F06.decorators-static-class",{"title":2573,"path":2574,"stem":2575},"Дескриптори — Магія доступу до атрибутів","\u002Fpython\u002Fdescriptors","05.python\u002F07.descriptors",{"title":2577,"path":2578,"stem":2579},"Метакласи — Динамічне створення класів під капотом CPython","\u002Fpython\u002Fmetaclasses","05.python\u002F08.metaclasses",{"title":2581,"path":2582,"stem":2583},"Dataclasses, NamedTuple та сучасні контейнери Python","\u002Fpython\u002Fmodern-containers","05.python\u002F09.modern-containers",{"title":2585,"path":2586,"stem":2587},"GIL та модель конкурентності CPython — фундамент перед потоками і процесами","\u002Fpython\u002Fgil-concurrency-intro","05.python\u002F11.gil-concurrency-intro",{"title":2589,"path":2590,"stem":2591},"Threading — конкурентність для I\u002FO-bound задач","\u002Fpython\u002Fthreading","05.python\u002F12.threading",{"title":2593,"path":2594,"stem":2595},"Multiprocessing — справжній паралелізм для CPU-bound задач","\u002Fpython\u002Fmultiprocessing","05.python\u002F13.multiprocessing",{"title":2597,"path":2598,"stem":2599},"asyncio — кооперативна конкурентність та event loop","\u002Fpython\u002Fasyncio","05.python\u002F14.asyncio",{"title":2601,"path":2602,"stem":2603},"📦 Повний посібник з модулів, пакетів та віртуальних середовищ у Python","\u002Fpython\u002Flesson_9","05.python\u002Flesson_9",{"title":2605,"path":2606,"stem":2607},"[object Object]","\u002Fpython\u002Foop-plan","05.python\u002Foop-plan",{"title":2609,"icon":2610,"path":2611,"stem":2612,"children":2613,"page":59},"Бази даних","i-lucide-database","\u002Fdatabases","06.databases",[2614,2644,2667,2704,2733,2751,2785,2797,2806],{"title":2615,"icon":2616,"path":2617,"stem":2618,"children":2619,"page":59},"Intro","i-lucide-play","\u002Fdatabases\u002Fintro","06.databases\u002F01.intro",[2620,2624,2628,2632,2636,2640],{"title":2621,"path":2622,"stem":2623},"Введення в теорію баз даних","\u002Fdatabases\u002Fintro\u002Fintroduction-to-databases","06.databases\u002F01.intro\u002F01.introduction-to-databases",{"title":2625,"path":2626,"stem":2627},"Реляційна модель даних","\u002Fdatabases\u002Fintro\u002Frelational-model-theory","06.databases\u002F01.intro\u002F02.relational-model-theory",{"title":2629,"path":2630,"stem":2631},"ER-моделювання","\u002Fdatabases\u002Fintro\u002Fer-modeling","06.databases\u002F01.intro\u002F03.er-modeling",{"title":2633,"path":2634,"stem":2635},"Логічне проектування БД","\u002Fdatabases\u002Fintro\u002Flogical-schema","06.databases\u002F01.intro\u002F04.logical-schema",{"title":2637,"path":2638,"stem":2639},"Класифікація таблиць","\u002Fdatabases\u002Fintro\u002Ftable-classification","06.databases\u002F01.intro\u002F05.table-classification",{"title":2641,"path":2642,"stem":2643},"PlantUML для баз даних","\u002Fdatabases\u002Fintro\u002Fplantuml-diagrams","06.databases\u002F01.intro\u002F06.plantuml-diagrams",{"title":2645,"icon":2610,"path":2646,"stem":2647,"children":2648,"page":59},"MS SQL Server Start","\u002Fdatabases\u002Fms-sql-server-start","06.databases\u002F02.ms-sql-server-start",[2649,2653,2659,2663],{"title":2650,"path":2651,"stem":2652},"Типи даних у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fdata-types","06.databases\u002F02.ms-sql-server-start\u002F01.data-types",{"title":2654,"path":2655,"stem":2656,"children":2657},"Індекси у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-indexes","06.databases\u002F02.ms-sql-server-start\u002F02.sql-indexes",[2658],{"title":2654,"path":2655,"stem":2656},{"title":2660,"path":2661,"stem":2662},"Системні бази даних MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsystem-databases","06.databases\u002F02.ms-sql-server-start\u002F03.system-databases",{"title":2664,"path":2665,"stem":2666},"Огляд мови SQL та запитів","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-queries-overview","06.databases\u002F02.ms-sql-server-start\u002F04.sql-queries-overview",{"title":2668,"icon":2610,"path":2669,"stem":2670,"children":2671,"page":59},"SQL","\u002Fdatabases\u002Fsql","06.databases\u002F03.sql",[2672,2676,2680,2684,2688,2692,2696,2700],{"title":2673,"path":2674,"stem":2675},"Налаштування демонстраційної бази даних","\u002Fdatabases\u002Fsql\u002Fsample-database-setup","06.databases\u002F03.sql\u002F00.sample-database-setup",{"title":2677,"path":2678,"stem":2679},"DDL - Створення таблиць (CREATE TABLE)","\u002Fdatabases\u002Fsql\u002Fddl-create-table","06.databases\u002F03.sql\u002F01.ddl-create-table",{"title":2681,"path":2682,"stem":2683},"DDL - Зміна та видалення таблиць (ALTER, DROP)","\u002Fdatabases\u002Fsql\u002Fddl-alter-drop-table","06.databases\u002F03.sql\u002F02.ddl-alter-drop-table",{"title":2685,"path":2686,"stem":2687},"SELECT запити - Основи","\u002Fdatabases\u002Fsql\u002Fselect-queries-fundamentals","06.databases\u002F03.sql\u002F03.select-queries-fundamentals",{"title":2689,"path":2690,"stem":2691},"SELECT запити - Розширені можливості","\u002Fdatabases\u002Fsql\u002Fselect-queries-advanced","06.databases\u002F03.sql\u002F04.select-queries-advanced",{"title":2693,"path":2694,"stem":2695},"INSERT запити - Додавання даних","\u002Fdatabases\u002Fsql\u002Finsert-queries","06.databases\u002F03.sql\u002F05.insert-queries",{"title":2697,"path":2698,"stem":2699},"UPDATE та DELETE запити","\u002Fdatabases\u002Fsql\u002Fupdate-delete-queries","06.databases\u002F03.sql\u002F06.update-delete-queries",{"title":2701,"path":2702,"stem":2703},"Транзакції в SQL","\u002Fdatabases\u002Fsql\u002Ftransactions","06.databases\u002F03.sql\u002F07.transactions",{"title":2705,"icon":2610,"path":2706,"stem":2707,"children":2708,"page":59},"Multi Table Databases","\u002Fdatabases\u002Fmulti-table-databases","06.databases\u002F04.multi-table-databases",[2709,2713,2717,2721,2725,2729],{"title":2710,"path":2711,"stem":2712},"Зв'язки та нормалізація БД","\u002Fdatabases\u002Fmulti-table-databases\u002Frelationships-and-normalization","06.databases\u002F04.multi-table-databases\u002F00.relationships-and-normalization",{"title":2714,"path":2715,"stem":2716},"INNER JOIN - З'єднання таблиць","\u002Fdatabases\u002Fmulti-table-databases\u002Finner-join","06.databases\u002F04.multi-table-databases\u002F01.inner-join",{"title":2718,"path":2719,"stem":2720},"OUTER JOINs - LEFT, RIGHT, FULL","\u002Fdatabases\u002Fmulti-table-databases\u002Fouter-joins","06.databases\u002F04.multi-table-databases\u002F02.outer-joins",{"title":2722,"path":2723,"stem":2724},"CROSS та SELF JOINs","\u002Fdatabases\u002Fmulti-table-databases\u002Fcross-self-joins","06.databases\u002F04.multi-table-databases\u002F03.cross-self-joins",{"title":2726,"path":2727,"stem":2728},"Підзапити (Subqueries)","\u002Fdatabases\u002Fmulti-table-databases\u002Fsubqueries","06.databases\u002F04.multi-table-databases\u002F04.subqueries",{"title":2730,"path":2731,"stem":2732},"Агрегації з JOIN","\u002Fdatabases\u002Fmulti-table-databases\u002Faggregations-with-joins","06.databases\u002F04.multi-table-databases\u002F05.aggregations-with-joins",{"title":2734,"icon":2735,"path":2736,"stem":2737,"children":2738,"page":59},"Aggregate Functions","i-lucide-calculator","\u002Fdatabases\u002Faggregate-functions","06.databases\u002F05.aggregate-functions",[2739,2743,2747],{"title":2740,"path":2741,"stem":2742},"Функції агрегування в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fintroduction-aggregate-functions","06.databases\u002F05.aggregate-functions\u002F01.introduction-aggregate-functions",{"title":2744,"path":2745,"stem":2746},"Групування даних в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fgrouping-data","06.databases\u002F05.aggregate-functions\u002F02.grouping-data",{"title":2748,"path":2749,"stem":2750},"Підзапити з агрегатними функціями","\u002Fdatabases\u002Faggregate-functions\u002Fsubqueries-aggregates","06.databases\u002F05.aggregate-functions\u002F03.subqueries-aggregates",{"title":2752,"icon":2753,"path":2754,"stem":2755,"children":2756,"page":59},"Тригери та зберігаємі процедури","i-lucide-database-zap","\u002Fdatabases\u002Ftriggers-stored-procedures","06.databases\u002F07.triggers-stored-procedures",[2757,2761,2765,2769,2773,2777,2781],{"title":2758,"path":2759,"stem":2760},"DML-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fdml-triggers","06.databases\u002F07.triggers-stored-procedures\u002F01.dml-triggers",{"title":2762,"path":2763,"stem":2764},"DDL-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fddl-triggers","06.databases\u002F07.triggers-stored-procedures\u002F02.ddl-triggers",{"title":2766,"path":2767,"stem":2768},"Transact-SQL розширення","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransact-sql-extensions","06.databases\u002F07.triggers-stored-procedures\u002F03.transact-sql-extensions",{"title":2770,"path":2771,"stem":2772},"Транзакції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransactions","06.databases\u002F07.triggers-stored-procedures\u002F04.transactions",{"title":2774,"path":2775,"stem":2776},"Зберігаємі процедури","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fstored-procedures","06.databases\u002F07.triggers-stored-procedures\u002F05.stored-procedures",{"title":2778,"path":2779,"stem":2780},"Користувацькі функції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fuser-defined-functions","06.databases\u002F07.triggers-stored-procedures\u002F06.user-defined-functions",{"title":2782,"path":2783,"stem":2784},"Безпека баз даних","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fsecurity","06.databases\u002F07.triggers-stored-procedures\u002F08.security",{"title":2782,"icon":793,"path":2786,"stem":2787,"children":2788,"page":59},"\u002Fdatabases\u002Fsecurity","06.databases\u002F08.security",[2789,2793],{"title":2790,"path":2791,"stem":2792},"Вступ до безпеки баз даних","\u002Fdatabases\u002Fsecurity\u002Fintroduction","06.databases\u002F08.security\u002F01.introduction",{"title":2794,"path":2795,"stem":2796},"Системні представлення та метадані","\u002Fdatabases\u002Fsecurity\u002Fsystem-views","06.databases\u002F08.security\u002F02.system-views",{"title":2798,"icon":2799,"path":2800,"stem":2801,"children":2802,"page":59},"Резервне копіювання та відновлення","i-lucide-database-backup","\u002Fdatabases\u002Fbackup-recovery","06.databases\u002F09.backup-recovery",[2803],{"title":2798,"path":2804,"stem":2805},"\u002Fdatabases\u002Fbackup-recovery\u002Fbackup-restore","06.databases\u002F09.backup-recovery\u002F01.backup-restore",{"title":2807,"icon":2808,"path":2809,"stem":2810,"children":2811,"page":59},"Повнотекстовий пошук","i-lucide-search","\u002Fdatabases\u002Ffull-text-search","06.databases\u002F10.full-text-search",[2812],{"title":2807,"path":2813,"stem":2814},"\u002Fdatabases\u002Ffull-text-search\u002Ffull-text-search","06.databases\u002F10.full-text-search\u002F01.full-text-search",{"title":2816,"icon":2817,"path":2818,"stem":2819,"children":2820,"page":59},"Tools","i-lucide-wrench","\u002Ftools","07.tools",[2821,2897],{"title":2822,"icon":2823,"path":2824,"stem":2825,"children":2826},"Docker","i-simple-icons-docker","\u002Ftools\u002Fdocker","07.tools\u002F01.docker\u002Findex",[2827,2829,2833,2837,2841,2845,2849,2853,2857,2861,2865,2869,2873,2877,2881,2885,2889,2893],{"title":2828,"path":2824,"stem":2825},"Docker: від нуля до production",{"title":2830,"path":2831,"stem":2832},"Контейнеризація — від проблеми до рішення","\u002Ftools\u002Fdocker\u002Fcontainerization-concept","07.tools\u002F01.docker\u002F01.containerization-concept",{"title":2834,"path":2835,"stem":2836},"Docker — що це і навіщо?","\u002Ftools\u002Fdocker\u002Fdocker-what-and-why","07.tools\u002F01.docker\u002F02.docker-what-and-why",{"title":2838,"path":2839,"stem":2840},"Архітектура Docker Engine","\u002Ftools\u002Fdocker\u002Fdocker-architecture","07.tools\u002F01.docker\u002F03.docker-architecture",{"title":2842,"path":2843,"stem":2844},"Встановлення Docker","\u002Ftools\u002Fdocker\u002Finstallation","07.tools\u002F01.docker\u002F04.installation",{"title":2846,"path":2847,"stem":2848},"Перший контейнер — docker run","\u002Ftools\u002Fdocker\u002Ffirst-container","07.tools\u002F01.docker\u002F05.first-container",{"title":2850,"path":2851,"stem":2852},"Життєвий цикл контейнера","\u002Ftools\u002Fdocker\u002Fcontainer-lifecycle","07.tools\u002F01.docker\u002F06.container-lifecycle",{"title":2854,"path":2855,"stem":2856},"Docker Images — фундаментальні концепції","\u002Ftools\u002Fdocker\u002Fdocker-images-fundamentals","07.tools\u002F01.docker\u002F07.docker-images-fundamentals",{"title":2858,"path":2859,"stem":2860},"Dockerfile — основи","\u002Ftools\u002Fdocker\u002Fdockerfile-basics","07.tools\u002F01.docker\u002F08.dockerfile-basics",{"title":2862,"path":2863,"stem":2864},"Dockerfile — просунуті техніки","\u002Ftools\u002Fdocker\u002Fdockerfile-advanced","07.tools\u002F01.docker\u002F09.dockerfile-advanced",{"title":2866,"path":2867,"stem":2868},"Build Context та кешування шарів","\u002Ftools\u002Fdocker\u002Fbuild-context-and-cache","07.tools\u002F01.docker\u002F10.build-context-and-cache",{"title":2870,"path":2871,"stem":2872},"Реєстри Docker-образів","\u002Ftools\u002Fdocker\u002Fimage-registries","07.tools\u002F01.docker\u002F11.image-registries",{"title":2874,"path":2875,"stem":2876},"Контейнеризація .NET додатків","\u002Ftools\u002Fdocker\u002Fdotnet-containerization","07.tools\u002F01.docker\u002F12.dotnet-containerization",{"title":2878,"path":2879,"stem":2880},"Томи та збереження даних","\u002Ftools\u002Fdocker\u002Fvolumes-and-data","07.tools\u002F01.docker\u002F13.volumes-and-data",{"title":2882,"path":2883,"stem":2884},"Основи мережі в Docker","\u002Ftools\u002Fdocker\u002Fnetworking-basics","07.tools\u002F01.docker\u002F14.networking-basics",{"title":2886,"path":2887,"stem":2888},"Змінні оточення та конфігурація","\u002Ftools\u002Fdocker\u002Fenvironment-and-configuration","07.tools\u002F01.docker\u002F15.environment-and-configuration",{"title":2890,"path":2891,"stem":2892},"Docker Compose — оркестрація контейнерів","\u002Ftools\u002Fdocker\u002Fdocker-compose-basics","07.tools\u002F01.docker\u002F16.docker-compose-basics",{"title":2894,"path":2895,"stem":2896},"Docker Compose — Multi-Service застосунки","\u002Ftools\u002Fdocker\u002Fcompose-multi-service","07.tools\u002F01.docker\u002F17.compose-multi-service",{"title":2898,"icon":2899,"path":2900,"stem":2901,"children":2902},"Kubernetes","simple-icons:kubernetes","\u002Ftools\u002Fkubernetes","07.tools\u002F02.kubernetes\u002Findex",[2903,2905,2909,2913,2917,2921,2925,2929,2933],{"title":2904,"path":2900,"stem":2901},"Kubernetes: від розробки до production",{"title":2906,"path":2907,"stem":2908},"Kubernetes — коли Docker Compose більше не вистачає","\u002Ftools\u002Fkubernetes\u002Fwhy-kubernetes","07.tools\u002F02.kubernetes\u002F01.why-kubernetes",{"title":2910,"path":2911,"stem":2912},"Архітектура Kubernetes — анатомія кластера","\u002Ftools\u002Fkubernetes\u002Fkubernetes-architecture","07.tools\u002F02.kubernetes\u002F02.kubernetes-architecture",{"title":2914,"path":2915,"stem":2916},"Локальне середовище — minikube, kind та k3s","\u002Ftools\u002Fkubernetes\u002Flocal-environment","07.tools\u002F02.kubernetes\u002F03.local-environment",{"title":2918,"path":2919,"stem":2920},"Pod — атомарна одиниця Kubernetes","\u002Ftools\u002Fkubernetes\u002Fpods-and-containers","07.tools\u002F02.kubernetes\u002F04.pods-and-containers",{"title":2922,"path":2923,"stem":2924},"Патерни використання Pod","\u002Ftools\u002Fkubernetes\u002Fpod-patterns","07.tools\u002F02.kubernetes\u002F05.pod-patterns",{"title":2926,"path":2927,"stem":2928},"Deployment — декларативне управління Pod","\u002Ftools\u002Fkubernetes\u002Fdeployment-basics","07.tools\u002F02.kubernetes\u002F06.deployment-basics",{"title":2930,"path":2931,"stem":2932},"Rolling Updates та управління життєвим циклом Deployment","\u002Ftools\u002Fkubernetes\u002Fdeployment-rolling-updates","07.tools\u002F02.kubernetes\u002F07.deployment-rolling-updates",{"title":2934,"path":2935,"stem":2936},"Service — мережева абстракція для Pod","\u002Ftools\u002Fkubernetes\u002Fservices-networking","07.tools\u002F02.kubernetes\u002F08.services-networking",{"title":2938,"icon":2939,"path":2940,"stem":2941,"children":2942,"page":59},"Software Engineering","i-lucide-code-2","\u002Fsoftware-engineering","09.software-engineering",[2943,2947,2951,2955,2959,2963,2967,2971,2975,2979,2983],{"title":2944,"path":2945,"stem":2946},"1. Аналіз предметної області. Експертні знання та складність","\u002Fsoftware-engineering\u002Fintro-subdomains","09.software-engineering\u002F01.intro-subdomains",{"title":2948,"path":2949,"stem":2950},"2. Обмежені контексти. Інтеграція обмежених контекстів","\u002Fsoftware-engineering\u002Fintegrating-limited-contexts","09.software-engineering\u002F02.integrating-limited-contexts",{"title":2952,"path":2953,"stem":2954},"3. Реалізація простої бізнес-логіки","\u002Fsoftware-engineering\u002Fsimple","09.software-engineering\u002F03.simple",{"title":2956,"path":2957,"stem":2958},"4. Опрацювання складної бізнес-логіки","\u002Fsoftware-engineering\u002Fcomplex-business-logic","09.software-engineering\u002F04.complex-business-logic",{"title":2960,"path":2961,"stem":2962},"5. Моделювання фактора часу. Подієво-орієнтована архітектура.","\u002Fsoftware-engineering\u002Fmodelling-the-time-factor","09.software-engineering\u002F05.modelling-the-time-factor",{"title":2964,"path":2965,"stem":2966},"6. Архітектурні патерни","\u002Fsoftware-engineering\u002Farchitectural-patterns","09.software-engineering\u002F06.architectural-patterns",{"title":2968,"path":2969,"stem":2970},"Паттерни взаємодії","\u002Fsoftware-engineering\u002Fpatterns-of-interaction","09.software-engineering\u002F07.patterns-of-interaction",{"title":2972,"path":2973,"stem":2974},"Евристика проєктування","\u002Fsoftware-engineering\u002Fdesign-heuristics","09.software-engineering\u002F08.design-heuristics",{"title":2976,"path":2977,"stem":2978},"Еволюція проєктних рішень","\u002Fsoftware-engineering\u002Fevolution-of-design-solutions","09.software-engineering\u002F09.evolution-of-design-solutions",{"title":2980,"path":2981,"stem":2982},"EventStorming","\u002Fsoftware-engineering\u002Feventstorming","09.software-engineering\u002F10.eventstorming",{"title":2984,"path":2985,"stem":2986},"DDD на практиці","\u002Fsoftware-engineering\u002Fddd-in-practice","09.software-engineering\u002F11.ddd-in-practice",{"title":2988,"icon":943,"path":2989,"stem":2990,"children":2991,"page":59},"DDD","\u002Fddd","10.ddd",[2992,2996,3000,3004,3008,3012,3016,3020,3024,3028,3032,3036,3040],{"title":2993,"path":2994,"stem":2995},"Аналіз предметної області","\u002Fddd\u002Fdomain-analysis","10.ddd\u002F01.domain-analysis",{"title":2997,"path":2998,"stem":2999},"Експертні знання про предметну область","\u002Fddd\u002Fdomain-expert-knowledge","10.ddd\u002F02.domain-expert-knowledge",{"title":3001,"path":3002,"stem":3003},"Як осмислити складність предметної області","\u002Fddd\u002Fmanaging-domain-complexity","10.ddd\u002F03.managing-domain-complexity",{"title":3005,"path":3006,"stem":3007},"Інтеграція обмежених контекстів","\u002Fddd\u002Fbounded-context-integration","10.ddd\u002F04.bounded-context-integration",{"title":3009,"path":3010,"stem":3011},"Реалізація простої бізнес-логіки","\u002Fddd\u002Fsimple-business-logic","10.ddd\u002F05.simple-business-logic",{"title":3013,"path":3014,"stem":3015},"Обробка складної бізнес-логіки","\u002Fddd\u002Fcomplex-business-logic","10.ddd\u002F06.complex-business-logic",{"title":3017,"path":3018,"stem":3019},"Моделювання фактора часу","\u002Fddd\u002Ftime-modeling","10.ddd\u002F07.time-modeling",{"title":3021,"path":3022,"stem":3023},"Глава 8. Архітектурні Патерни","\u002Fddd\u002Farchitectural-patterns","10.ddd\u002F08.architectural-patterns",{"title":3025,"path":3026,"stem":3027},"Глава 9. Патерни Взаємодії","\u002Fddd\u002Finteraction-patterns","10.ddd\u002F09.interaction-patterns",{"title":3029,"path":3030,"stem":3031},"Глава 10. Проектні Евристики","\u002Fddd\u002Fdesign-heuristics","10.ddd\u002F10.design-heuristics",{"title":3033,"path":3034,"stem":3035},"Глава 11. Еволюція Проектних Рішень","\u002Fddd\u002Fevolution-of-design-decisions","10.ddd\u002F11.evolution-of-design-decisions",{"title":3037,"path":3038,"stem":3039},"Глава 12. EventStorming","\u002Fddd\u002Fevent-storming","10.ddd\u002F12.event-storming",{"title":3041,"path":3042,"stem":3043},"Глава 13. DDD на Практиці","\u002Fddd\u002Fddd-in-practice","10.ddd\u002F13.ddd-in-practice",{"title":3045,"icon":3046,"path":3047,"stem":3048,"children":3049,"page":59},"Media Streaming","i-lucide-video","\u002Fmedia-streaming","11.media-streaming",[3050,3054,3058,3062,3066,3070,3074],{"title":3051,"path":3052,"stem":3053},"01. Магія Стрімінгу: Що відбувається, коли ви натискаєте \"Play\"","\u002Fmedia-streaming\u002Fintroduction","11.media-streaming\u002F01.introduction",{"title":3055,"path":3056,"stem":3057},"02. Анатомія Медіа: Кодеки, Контейнери та Стиснення","\u002Fmedia-streaming\u002Faudio-video-anatomy","11.media-streaming\u002F02.audio-video-anatomy",{"title":3059,"path":3060,"stem":3061},"03. The Gym: FFmpeg Deep Dive","\u002Fmedia-streaming\u002Fffmpeg-gym","11.media-streaming\u002F03.ffmpeg-gym",{"title":3063,"path":3064,"stem":3065},"04. HLS Protocol: HTTP Live Streaming у Деталях","\u002Fmedia-streaming\u002Fhls-protocol","11.media-streaming\u002F04.hls-protocol",{"title":3067,"path":3068,"stem":3069},"05. DASH Protocol: Відкритий Стандарт","\u002Fmedia-streaming\u002Fdash-protocol","11.media-streaming\u002F05.dash-protocol",{"title":3071,"path":3072,"stem":3073},"06. Масштабування: CDN та Adaptive Bitrate","\u002Fmedia-streaming\u002Fcdn-and-adaptive-bitrate","11.media-streaming\u002F06.cdn-and-adaptive-bitrate",{"title":3075,"path":3076,"stem":3077},"07. Війна із Затримкою (Latency)","\u002Fmedia-streaming\u002Frealtime-latency","11.media-streaming\u002F07.realtime-latency",{"title":3079,"icon":3080,"path":3081,"stem":3082,"children":3083,"page":59},"HTML & CSS","i-devicon-html5","\u002Fhtml-css","12.html-css",[3084,3088,3092,3096,3100,3104,3108,3112,3116,3120,3124,3128,3132,3136,3140,3144,3148,3152,3156,3160,3164,3168,3172,3176,3180,3184,3188,3192,3196,3200],{"title":3085,"path":3086,"stem":3087},"Вступ до HTML. Структура документа","\u002Fhtml-css\u002Fintro-html-structure","12.html-css\u002F01.intro-html-structure",{"title":3089,"path":3090,"stem":3091},"Форматування тексту в HTML","\u002Fhtml-css\u002Fhtml-text-formatting","12.html-css\u002F02.html-text-formatting",{"title":3093,"path":3094,"stem":3095},"Посилання та зображення в HTML","\u002Fhtml-css\u002Fhtml-links-images","12.html-css\u002F03.html-links-images",{"title":3097,"path":3098,"stem":3099},"Списки та таблиці в HTML","\u002Fhtml-css\u002Fhtml-lists-tables","12.html-css\u002F04.html-lists-tables",{"title":3101,"path":3102,"stem":3103},"Форми в HTML","\u002Fhtml-css\u002Fhtml-forms","12.html-css\u002F05.html-forms",{"title":3105,"path":3106,"stem":3107},"Семантичні елементи HTML5","\u002Fhtml-css\u002Fhtml-semantic-elements","12.html-css\u002F06.html-semantic-elements",{"title":3109,"path":3110,"stem":3111},"Мультимедіа та розширені елементи HTML","\u002Fhtml-css\u002Fhtml-multimedia-advanced","12.html-css\u002F07.html-multimedia-advanced",{"title":3113,"path":3114,"stem":3115},"Мікророзмітка та SEO в HTML","\u002Fhtml-css\u002Fhtml-microdata-seo","12.html-css\u002F08.html-microdata-seo",{"title":3117,"path":3118,"stem":3119},"Вступ до CSS. Селектори та специфічність","\u002Fhtml-css\u002Fcss-intro-selectors","12.html-css\u002F09.css-intro-selectors",{"title":3121,"path":3122,"stem":3123},"Блокова модель CSS. Відступи. Box Sizing","\u002Fhtml-css\u002Fcss-box-model","12.html-css\u002F10.css-box-model",{"title":3125,"path":3126,"stem":3127},"Розміри у CSS: повний довідник одиниць і ключових слів","\u002Fhtml-css\u002F10a.css-sizing","12.html-css\u002F10a.css-sizing",{"title":3129,"path":3130,"stem":3131},"Типографіка в CSS. Шрифти та текст","\u002Fhtml-css\u002Fcss-typography","12.html-css\u002F11.css-typography",{"title":3133,"path":3134,"stem":3135},"Кольори та фони в CSS","\u002Fhtml-css\u002Fcss-colors-backgrounds","12.html-css\u002F12.css-colors-backgrounds",{"title":3137,"path":3138,"stem":3139},"Тіні та фільтри в CSS","\u002Fhtml-css\u002F12b.css-shadows-filters","12.html-css\u002F12b.css-shadows-filters",{"title":3141,"path":3142,"stem":3143},"CSS Flexbox: Фундамент гнучких макетів","\u002Fhtml-css\u002Fcss-flexbox-fundamentals","12.html-css\u002F13.css-flexbox-fundamentals",{"title":3145,"path":3146,"stem":3147},"CSS Flexbox: Вирівнювання та Позиціонування","\u002Fhtml-css\u002Fcss-flexbox-alignment-sizing-and-patterns","12.html-css\u002F14.css-flexbox-alignment-sizing-and-patterns",{"title":3149,"path":3150,"stem":3151},"CSS Grid. Двовимірний макет. Частина 1","\u002Fhtml-css\u002Fcss-layout-grid","12.html-css\u002F15.css-layout-grid",{"title":3153,"path":3154,"stem":3155},"CSS Grid. Двовимірний макет. Частина 2","\u002Fhtml-css\u002Fcss-layout-grid-advanced","12.html-css\u002F16.css-layout-grid-advanced",{"title":3157,"path":3158,"stem":3159},"Позиціонування в CSS. Z-index. Stacking Context","\u002Fhtml-css\u002Fcss-positioning","12.html-css\u002F17.css-positioning",{"title":3161,"path":3162,"stem":3163},"CSS Анімації та Переходи","\u002Fhtml-css\u002Fcss-animations-transitions","12.html-css\u002F18.css-animations-transitions",{"title":3165,"path":3166,"stem":3167},"Адаптивний дизайн. Media Queries. Частина 1","\u002Fhtml-css\u002Fcss-responsive-media-queries","12.html-css\u002F19.css-responsive-media-queries",{"title":3169,"path":3170,"stem":3171},"Адаптивний дизайн. Частина 2: clamp(), Container Queries, @layer","\u002Fhtml-css\u002Fcss-responsive-advanced","12.html-css\u002F20.css-responsive-advanced",{"title":3173,"path":3174,"stem":3175},"CSS Custom Properties. Методології. Сучасний CSS","\u002Fhtml-css\u002Fcss-variables-methodologies","12.html-css\u002F21.css-variables-methodologies",{"title":3177,"path":3178,"stem":3179},"Сучасний CSS 2023–2025: Нові можливості","\u002Fhtml-css\u002Fcss-modern-features","12.html-css\u002F22.css-modern-features",{"title":3181,"path":3182,"stem":3183},"CSS Nesting, @layer, @scope та @property: нативний препроцесор","\u002Fhtml-css\u002F22a.css-nesting-modern-syntax","12.html-css\u002F22a.css-nesting-modern-syntax",{"title":3185,"path":3186,"stem":3187},"CSS для форм та інтерактивних станів","\u002Fhtml-css\u002Fcss-forms-interactive-states","12.html-css\u002F23.css-forms-interactive-states",{"title":3189,"path":3190,"stem":3191},"Доступність у CSS (CSS Accessibility)","\u002Fhtml-css\u002Fcss-accessibility","12.html-css\u002F24.css-accessibility",{"title":3193,"path":3194,"stem":3195},"CSS-функції та сучасні sizing primitives","\u002Fhtml-css\u002Fcss-functions-sizing","12.html-css\u002F25.css-functions-sizing",{"title":3197,"path":3198,"stem":3199},"Rendering Pipeline і CSS Performance","\u002Fhtml-css\u002Fcss-rendering-performance","12.html-css\u002F26.css-rendering-performance",{"title":3201,"path":3202,"stem":3203},"CSS Best Practices: типові ситуації та правильні рішення","\u002Fhtml-css\u002Fcss-best-practices","12.html-css\u002F27.css-best-practices",{"title":3205,"path":3206,"stem":3207,"children":3208,"page":59},"AWS","\u002Faws","13.aws",[3209,3213,3217,3221,3225,3229,3233,3237,3241,3245,3249,3253,3257,3261,3265,3269,3273,3277],{"title":3210,"path":3211,"stem":3212},"Реєстрація AWS акаунту та студентські програми","\u002Faws\u002Faccount-registration","13.aws\u002F00.account-registration",{"title":3214,"path":3215,"stem":3216},"Вступ до хмарних обчислень та AWS","\u002Faws\u002Fintroduction-to-cloud","13.aws\u002F01.introduction-to-cloud",{"title":3218,"path":3219,"stem":3220},"AWS IAM — Identity and Access Management","\u002Faws\u002Fiam","13.aws\u002F02.iam",{"title":3222,"path":3223,"stem":3224},"AWS IAM CLI — Довідник команд","\u002Faws\u002F02a.iam-doc","13.aws\u002F02a.iam-doc",{"title":3226,"path":3227,"stem":3228},"Docker та контейнеризація в AWS — ECR, ECS та Fargate","\u002Faws\u002Fdocker-ecs","13.aws\u002F03.docker-ecs",{"title":3230,"path":3231,"stem":3232},"AWS ECR \u002F ECS CLI — Довідник команд","\u002Faws\u002F03a.docker-ecs-doc","13.aws\u002F03a.docker-ecs-doc",{"title":3234,"path":3235,"stem":3236},"Amazon EC2 — Elastic Compute Cloud","\u002Faws\u002Fec2","13.aws\u002F04.ec2",{"title":3238,"path":3239,"stem":3240},"AWS EC2 CLI — Довідник команд","\u002Faws\u002F04a.ec2-doc","13.aws\u002F04a.ec2-doc",{"title":3242,"path":3243,"stem":3244},"Elastic Load Balancing та Auto Scaling","\u002Faws\u002Falb-asg","13.aws\u002F05.alb-asg",{"title":3246,"path":3247,"stem":3248},"Amazon S3 — Simple Storage Service","\u002Faws\u002Fs3","13.aws\u002F06.s3",{"title":3250,"path":3251,"stem":3252},"Amazon CloudFront — Content Delivery Network","\u002Faws\u002Fcloudfront","13.aws\u002F07.cloudfront",{"title":3254,"path":3255,"stem":3256},"Amazon RDS — Relational Database Service","\u002Faws\u002Frds","13.aws\u002F08.rds",{"title":3258,"path":3259,"stem":3260},"Amazon DynamoDB — NoSQL Database","\u002Faws\u002Fdynamodb","13.aws\u002F09.dynamodb",{"title":3262,"path":3263,"stem":3264},"AWS Lambda та Serverless Compute","\u002Faws\u002Flambda","13.aws\u002F10.lambda",{"title":3266,"path":3267,"stem":3268},"Amazon Bedrock - Foundation Models, RAG та Agents","\u002Faws\u002Fbedrock","13.aws\u002F22.bedrock",{"title":3270,"path":3271,"stem":3272},"Amazon Rekognition - Комп'ютерний зір","\u002Faws\u002Frekognition","13.aws\u002F23.rekognition",{"title":3274,"path":3275,"stem":3276},"Amazon Textract - Інтелектуальний аналіз документів","\u002Faws\u002Ftextract","13.aws\u002F24.textract",{"title":3278,"path":3279,"stem":3280},"Amazon Polly, Transcribe, Comprehend та Translate","\u002Faws\u002Faudio-nlp-services","13.aws\u002F25.audio-nlp-services",{"title":3282,"path":3283,"stem":3284,"children":3285,"page":59},"Tailwind","\u002Ftailwind","21.tailwind",[3286,3290,3294,3298,3302,3306,3310,3314,3318,3322,3326,3330],{"title":3287,"path":3288,"stem":3289},"Що таке Tailwind CSS і навіщо він потрібен","\u002Ftailwind\u002Ftailwind-intro-philosophy","21.tailwind\u002F01.tailwind-intro-philosophy",{"title":3291,"path":3292,"stem":3293},"Встановлення та налаштування Tailwind CSS v4","\u002Ftailwind\u002Ftailwind-installation-setup","21.tailwind\u002F02.tailwind-installation-setup",{"title":3295,"path":3296,"stem":3297},"Utility-класи: основи та система Tailwind","\u002Ftailwind\u002Ftailwind-utility-classes-core","21.tailwind\u002F03.tailwind-utility-classes-core",{"title":3299,"path":3300,"stem":3301},"Layout: Flexbox та Grid через Tailwind","\u002Ftailwind\u002Ftailwind-flexbox-grid","21.tailwind\u002F04.tailwind-flexbox-grid",{"title":3303,"path":3304,"stem":3305},"Кастомізація теми через @theme у Tailwind v4","\u002Ftailwind\u002Ftailwind-theme-customization","21.tailwind\u002F05.tailwind-theme-customization",{"title":3307,"path":3308,"stem":3309},"Варіанти: hover, focus, responsive, dark mode та нові v4","\u002Ftailwind\u002Ftailwind-variants-states","21.tailwind\u002F06.tailwind-variants-states",{"title":3311,"path":3312,"stem":3313},"Типографіка та система кольорів у Tailwind v4","\u002Ftailwind\u002Ftailwind-typography-colors","21.tailwind\u002F07.tailwind-typography-colors",{"title":3315,"path":3316,"stem":3317},"Компоненти та повторюваність: @apply, @utility та патерни","\u002Ftailwind\u002Ftailwind-components-patterns","21.tailwind\u002F08.tailwind-components-patterns",{"title":3319,"path":3320,"stem":3321},"Темна тема та система дизайн-токенів у Tailwind v4","\u002Ftailwind\u002Ftailwind-dark-mode-theming","21.tailwind\u002F09.tailwind-dark-mode-theming",{"title":3323,"path":3324,"stem":3325},"Довільні значення та контейнерні запити у Tailwind v4","\u002Ftailwind\u002Ftailwind-arbitrary-container-queries","21.tailwind\u002F10.tailwind-arbitrary-container-queries",{"title":3327,"path":3328,"stem":3329},"Анімації, трансформації та 3D у Tailwind v4","\u002Ftailwind\u002Ftailwind-animations-transforms","21.tailwind\u002F11.tailwind-animations-transforms",{"title":3331,"path":3332,"stem":3333},"Tailwind CLI, PostCSS та інтеграція з фреймворками","\u002Ftailwind\u002Ftailwind-cli-tooling","21.tailwind\u002F12.tailwind-cli-tooling",{"title":3335,"path":3336,"stem":3337},"Тестування компонентів діаграм","\u002Ftest-components","98.test-components",{"id":3339,"title":3230,"body":3340,"description":8670,"extension":8671,"links":8672,"meta":8673,"navigation":8084,"path":3231,"seo":8674,"stem":3232,"__hash__":8675},"docs\u002F13.aws\u002F03a.docker-ecs-doc.md",{"type":3341,"value":3342,"toc":8600},"minimark",[3343,3347,3351,3378,3381,3386,3390,3397,3430,3489,3491,3495,3498,3514,3564,3579,3581,3584,3590,3596,3631,3633,3637,3641,3648,3656,3693,3701,3703,3707,3712,3767,3860,3876,3878,3882,3885,3909,3997,3999,4003,4006,4035,4153,4167,4169,4173,4176,4192,4287,4289,4293,4296,4306,4359,4361,4365,4368,4383,4451,4453,4457,4460,4478,4533,4535,4539,4542,4565,4635,4637,4641,4645,4648,4673,4760,4762,4766,4769,4783,4828,4830,4834,4837,4856,4858,4862,4866,4872,5007,5075,5086,5088,5092,5095,5171,5173,5177,5181,5184,5257,5348,5350,5354,5357,5393,5462,5476,5478,5482,5489,5500,5554,5556,5560,5564,5567,5585,5663,5665,5669,5683,5711,5806,5808,5812,5815,5844,5924,5929,5931,5935,5939,5942,6061,6063,6067,6070,6191,6193,6197,6201,6204,6306,6308,6312,6315,6341,6481,6483,6487,6490,6589,6591,6595,6599,6602,6642,6736,6738,6742,6748,6782,6872,6874,6878,6881,6917,7111,7113,7117,7121,7124,7159,7221,7223,7227,7230,7273,7421,7423,7427,7431,7438,7486,7554,7573,7575,7579,7582,7585,7620,7622,7626,7630,7637,7669,7781,7795,7797,7801,7805,7808,7844,7993,7995,7999,8003,8230,8234,8374,8378,8596],[3344,3345,3230],"h1",{"id":3346},"aws-ecr-ecs-cli-довідник-команд",[3348,3349,3350],"p",{},"Цей довідник охоплює всі важливі команди для роботи з контейнерами в AWS, згруповані за сервісом. Для кожної команди наведено опис параметрів та очікуваний вивід терміналу.",[3352,3353,3354,3355,3359,3360,3363,3364,3363,3367,3370,3371,3363,3374,3377],"note",{},"Перед використанням переконайтеся, що AWS CLI налаштований: ",[3356,3357,3358],"code",{},"aws configure"," або через змінні середовища ",[3356,3361,3362],{},"AWS_ACCESS_KEY_ID",", ",[3356,3365,3366],{},"AWS_SECRET_ACCESS_KEY",[3356,3368,3369],{},"AWS_DEFAULT_REGION",". Також потрібний встановлений Docker для команд ",[3356,3372,3373],{},"docker build",[3356,3375,3376],{},"docker push",".",[3379,3380],"hr",{},[3382,3383,3385],"h2",{"id":3384},"docker-локальна-робота-з-образами","Docker — локальна робота з образами",[3387,3388,3373],"h3",{"id":3389},"docker-build",[3348,3391,3392,3393,3396],{},"Збирає Docker-образ з ",[3356,3394,3395],{},"Dockerfile"," у поточній або вказаній директорії.",[3398,3399,3400,3414,3421,3425],"field-group",{},[3401,3402,3406,3407,3410,3411,3377],"field",{"name":3403,"type":3404,"required":3405},"-t \u002F --tag","string","true","Ім'я та тег образу у форматі ",[3356,3408,3409],{},"name:tag",". Без тегу Docker автоматично використовує ",[3356,3412,3413],{},":latest",[3401,3415,3417,3418,3420],{"name":3377,"type":3416,"required":3405},"path","Шлях до build context — директорії з вихідним кодом та Dockerfile. ",[3356,3419,3377],{}," означає поточну директорію.",[3401,3422,3424],{"name":3423,"type":3404},"--file \u002F -f","Шлях до Dockerfile, якщо він не знаходиться у кореневій директорії build context.",[3401,3426,3429],{"name":3427,"type":3428},"--no-cache","boolean","Збирати образ без використання кешу шарів. Корисно для відлагодження та CI\u002FCD.",[3431,3432,3434,3450,3454,3458,3466,3474,3482],"terminal-preview",{"title":3433},"docker build — збірка .NET API образу",[3435,3436,3439,3445,3446],"div",{"className":3437},[3438],"line",[3440,3441,3444],"span",{"className":3442},[3443],"opacity-40","$"," ",[3447,3448,3449],"strong",{},"docker build -t my-api:v1.0.0 .",[3435,3451,3453],{"className":3452},[3438],"[+] Building 38.5s (12\u002F12) FINISHED",[3435,3455,3457],{"className":3456},[3438]," => [build 1\u002F5] FROM mcr.microsoft.com\u002Fdotnet\u002Fsdk:8.0",[3435,3459,3461,3462],{"className":3460},[3438]," => [build 3\u002F5] RUN dotnet restore \"MyApi.csproj\"          ",[3440,3463,3465],{"className":3464},[3443],"10.2s",[3435,3467,3469,3470],{"className":3468},[3438]," => [build 5\u002F5] RUN dotnet publish \"MyApi.csproj\" -c Release -o \u002Fapp\u002Fpublish  ",[3440,3471,3473],{"className":3472},[3443],"18.1s",[3435,3475,3477],{"className":3476},[3438],[3440,3478,3481],{"className":3479},[3480],"text-green-400"," => => writing image sha256:a1b2c3d4e5f6...  0.1s",[3435,3483,3485],{"className":3484},[3438],[3440,3486,3488],{"className":3487},[3480]," => => naming to docker.io\u002Flibrary\u002Fmy-api:v1.0.0  0.0s",[3379,3490],{},[3387,3492,3494],{"id":3493},"docker-tag","docker tag",[3348,3496,3497],{},"Додає новий тег до вже існуючого локального образу. Не копіює образ — лише додає псевдонім.",[3398,3499,3500,3507],{},[3401,3501,3503,3504,3377],{"name":3502,"type":3404,"required":3405},"SOURCE_IMAGE:TAG","Ім'я та тег локального образу-джерела, наприклад ",[3356,3505,3506],{},"my-api:v1.0.0",[3401,3508,3510,3511,3377],{"name":3509,"type":3404,"required":3405},"TARGET_IMAGE:TAG","Нове ім'я та тег. Для ECR — повна адреса у форматі ",[3356,3512,3513],{},"ACCOUNT_ID.dkr.ecr.REGION.amazonaws.com\u002FREPO:TAG",[3431,3515,3517,3526,3537,3544,3547,3556,3560],{"title":3516},"docker tag — теґування для ECR",[3435,3518,3520,3445,3523],{"className":3519},[3438],[3440,3521,3444],{"className":3522},[3443],[3447,3524,3525],{},"docker tag my-api:v1.0.0 \\",[3435,3527,3529,3533,3534],{"className":3528},[3438],[3440,3530,3532],{"className":3531},[3443],">","     ",[3447,3535,3536],{},"123456789012.dkr.ecr.eu-central-1.amazonaws.com\u002Fmy-api:v1.0.0",[3435,3538,3540],{"className":3539},[3438],[3440,3541,3543],{"className":3542},[3480],"(no output — success)",[3435,3545],{"className":3546},[3438],[3435,3548,3550,3445,3553],{"className":3549},[3438],[3440,3551,3444],{"className":3552},[3443],[3447,3554,3555],{},"docker images | grep my-api",[3435,3557,3559],{"className":3558},[3438],"my-api                                                    v1.0.0    a1b2c3d4e5f6   2 min ago   204MB",[3435,3561,3563],{"className":3562},[3438],"123456789012.dkr.ecr.eu-central-1.amazonaws.com\u002Fmy-api   v1.0.0    a1b2c3d4e5f6   2 min ago   204MB",[3565,3566,3567,3568,3571,3572,3575,3576,3578],"tip",{},"Обидва рядки у виводі ",[3356,3569,3570],{},"docker images"," вказують на той самий образ (однаковий ",[3356,3573,3574],{},"sha256","). ",[3356,3577,3494],{}," лише додає псевдонім — місце на диску не подвоюється.",[3379,3580],{},[3387,3582,3376],{"id":3583},"docker-push",[3348,3585,3586,3587,3377],{},"Завантажує образ у реєстр. Для ECR потрібна попередня аутентифікація через ",[3356,3588,3589],{},"aws ecr get-login-password",[3398,3591,3592],{},[3401,3593,3595],{"name":3594,"type":3404,"required":3405},"IMAGE:TAG","Повна адреса образу включно з реєстром, репозиторієм та тегом.",[3431,3597,3599,3608,3612,3616,3620,3624],{"title":3598},"docker push — завантаження в ECR",[3435,3600,3602,3445,3605],{"className":3601},[3438],[3440,3603,3444],{"className":3604},[3443],[3447,3606,3607],{},"docker push 123456789012.dkr.ecr.eu-central-1.amazonaws.com\u002Fmy-api:v1.0.0",[3435,3609,3611],{"className":3610},[3438],"The push refers to repository [123456789012.dkr.ecr.eu-central-1.amazonaws.com\u002Fmy-api]",[3435,3613,3615],{"className":3614},[3438],"3f4a8b9c1d2e: Pushing  45.23 MB\u002F120.5 MB",[3435,3617,3619],{"className":3618},[3438],"8c2d1e5f9a3b: Pushed",[3435,3621,3623],{"className":3622},[3438],"1a4f7e2c8b6d: Pushed",[3435,3625,3627],{"className":3626},[3438],[3440,3628,3630],{"className":3629},[3480],"v1.0.0: digest: sha256:abc123def456... size: 1847",[3379,3632],{},[3382,3634,3636],{"id":3635},"amazon-ecr-elastic-container-registry","Amazon ECR — Elastic Container Registry",[3387,3638,3640],{"id":3639},"ecr-get-login-password","ecr get-login-password",[3348,3642,3643,3644,3647],{},"Отримує тимчасовий токен аутентифікації (12 годин) та передає його стандартному ",[3356,3645,3646],{},"docker login"," через pipe. Це єдиний спосіб аутентифікуватись у ECR — постійних паролів немає.",[3398,3649,3650],{},[3401,3651,3653,3654,3377],{"name":3652,"type":3404,"required":3405},"--region","Регіон ECR. Повинен збігатися з регіоном, вказаним у URI реєстру у наступній команді ",[3356,3655,3646],{},[3431,3657,3659,3668,3677,3686],{"title":3658},"aws ecr get-login-password — аутентифікація",[3435,3660,3662,3445,3665],{"className":3661},[3438],[3440,3663,3444],{"className":3664},[3443],[3447,3666,3667],{},"aws ecr get-login-password --region eu-central-1 \\",[3435,3669,3671,3533,3674],{"className":3670},[3438],[3440,3672,3532],{"className":3673},[3443],[3447,3675,3676],{},"| docker login --username AWS \\",[3435,3678,3680,3533,3683],{"className":3679},[3438],[3440,3681,3532],{"className":3682},[3443],[3447,3684,3685],{},"--password-stdin 123456789012.dkr.ecr.eu-central-1.amazonaws.com",[3435,3687,3689],{"className":3688},[3438],[3440,3690,3692],{"className":3691},[3480],"Login Succeeded",[3694,3695,3696,3697,3700],"caution",{},"Токен дійсний 12 годин. У CI\u002FCD pipeline виконуйте ",[3356,3698,3699],{},"get-login-password"," на початку кожного job, а не один раз при налаштуванні.",[3379,3702],{},[3387,3704,3706],{"id":3705},"ecr-create-repository","ecr create-repository",[3348,3708,3709,3710,3377],{},"Створює новий репозиторій у ECR. Потрібно виконати один раз перед першим ",[3356,3711,3376],{},[3398,3713,3714,3729,3732,3741,3755],{},[3401,3715,3717,3718,3721,3722,3725,3726,3377],{"name":3716,"type":3404,"required":3405},"--repository-name","Ім'я репозиторію. Повинне відповідати ",[3356,3719,3720],{},"[a-z0-9._\u002F-]+",". Підтримує вкладеність через ",[3356,3723,3724],{},"\u002F",": ",[3356,3727,3728],{},"backend\u002Fmy-api",[3401,3730,3731],{"name":3652,"type":3404,"required":3405},"Регіон AWS, де буде створено репозиторій.",[3401,3733,3736,3737,3740],{"name":3734,"type":3735},"--image-scanning-configuration","object","Конфігурація сканування. ",[3356,3738,3739],{},"scanOnPush=true"," вмикає автоматичне сканування CVE при кожному push через Amazon Inspector.",[3401,3742,3744,3747,3748,3751,3752,3754],{"name":3743,"type":3404},"--image-tag-mutability",[3356,3745,3746],{},"MUTABLE"," (за замовчуванням) — теги можна перезаписати. ",[3356,3749,3750],{},"IMMUTABLE"," — теги захищені від перезапису. Рекомендується ",[3356,3753,3750],{}," для production.",[3401,3756,3758,3759,3762,3763,3766],{"name":3757,"type":3735},"--encryption-configuration","Тип шифрування: ",[3356,3760,3761],{},"AES256"," (за замовчуванням, безкоштовно) або ",[3356,3764,3765],{},"KMS"," (власний ключ AWS KMS, платно).",[3431,3768,3770,3779,3788,3797,3806,3815,3819,3823,3827,3831,3835,3844,3848,3852,3856],{"title":3769},"aws ecr create-repository — відповідь",[3435,3771,3773,3445,3776],{"className":3772},[3438],[3440,3774,3444],{"className":3775},[3443],[3447,3777,3778],{},"aws ecr create-repository \\",[3435,3780,3782,3533,3785],{"className":3781},[3438],[3440,3783,3532],{"className":3784},[3443],[3447,3786,3787],{},"--repository-name my-api \\",[3435,3789,3791,3533,3794],{"className":3790},[3438],[3440,3792,3532],{"className":3793},[3443],[3447,3795,3796],{},"--region eu-central-1 \\",[3435,3798,3800,3533,3803],{"className":3799},[3438],[3440,3801,3532],{"className":3802},[3443],[3447,3804,3805],{},"--image-scanning-configuration scanOnPush=true \\",[3435,3807,3809,3533,3812],{"className":3808},[3438],[3440,3810,3532],{"className":3811},[3443],[3447,3813,3814],{},"--image-tag-mutability IMMUTABLE",[3435,3816,3818],{"className":3817},[3438],"{",[3435,3820,3822],{"className":3821},[3438],"    \"repository\": {",[3435,3824,3826],{"className":3825},[3438],"        \"repositoryArn\": \"arn:aws:ecr:eu-central-1:123456789012:repository\u002Fmy-api\",",[3435,3828,3830],{"className":3829},[3438],"        \"registryId\": \"123456789012\",",[3435,3832,3834],{"className":3833},[3438],"        \"repositoryName\": \"my-api\",",[3435,3836,3838,3839,3843],{"className":3837},[3438],"        ",[3440,3840,3842],{"className":3841},[3480],"\"repositoryUri\": \"123456789012.dkr.ecr.eu-central-1.amazonaws.com\u002Fmy-api\"",",",[3435,3845,3847],{"className":3846},[3438],"        \"imageTagMutability\": \"IMMUTABLE\",",[3435,3849,3851],{"className":3850},[3438],"        \"imageScanningConfiguration\": { \"scanOnPush\": true }",[3435,3853,3855],{"className":3854},[3438],"    }",[3435,3857,3859],{"className":3858},[3438],"}",[3565,3861,3862,3863,3866,3867,3363,3869,3871,3872,3875],{},"Збережіть значення ",[3356,3864,3865],{},"repositoryUri"," — воно використовується у ",[3356,3868,3494],{},[3356,3870,3376],{}," та у полі ",[3356,3873,3874],{},"image"," Task Definition.",[3379,3877],{},[3387,3879,3881],{"id":3880},"ecr-describe-repositories-describe-images","ecr describe-repositories \u002F describe-images",[3348,3883,3884],{},"Перегляд списку репозиторіїв або образів у конкретному репозиторії.",[3398,3886,3887,3896,3902],{},[3401,3888,3891,3892,3895],{"name":3889,"type":3890},"--repository-names","list","Список репозиторіїв для ",[3356,3893,3894],{},"describe-repositories",". Якщо не вказано — повертає всі репозиторії акаунту.",[3401,3897,3898,3899,3377],{"name":3716,"type":3404,"required":3405},"Ім'я репозиторію для ",[3356,3900,3901],{},"describe-images",[3401,3903,3905,3906,3377],{"name":3904,"type":3404},"--query","JMESPath-вираз для фільтрації відповіді. Наприклад, ",[3356,3907,3908],{},"images[*].{Tag:imageTags[0],Digest:imageDigest}",[3431,3910,3911,3920,3929,3933,3937,3941,3944,3947,3956,3965,3974,3978,3982,3986,3990,3994],{"title":3881},[3435,3912,3914,3445,3917],{"className":3913},[3438],[3440,3915,3444],{"className":3916},[3443],[3447,3918,3919],{},"aws ecr describe-repositories --region eu-central-1 \\",[3435,3921,3923,3533,3926],{"className":3922},[3438],[3440,3924,3532],{"className":3925},[3443],[3447,3927,3928],{},"--query \"repositories[*].repositoryName\" --output table",[3435,3930,3932],{"className":3931},[3438],"-----------",[3435,3934,3936],{"className":3935},[3438],"| my-api  |",[3435,3938,3940],{"className":3939},[3438],"| my-auth |",[3435,3942,3932],{"className":3943},[3438],[3435,3945],{"className":3946},[3438],[3435,3948,3950,3445,3953],{"className":3949},[3438],[3440,3951,3444],{"className":3952},[3443],[3447,3954,3955],{},"aws ecr describe-images --repository-name my-api --region eu-central-1 \\",[3435,3957,3959,3533,3962],{"className":3958},[3438],[3440,3960,3532],{"className":3961},[3443],[3447,3963,3964],{},"--query \"imageDetails[*].{Tag:imageTags[0],Pushed:imagePushedAt,Size:imageSizeInBytes}\" \\",[3435,3966,3968,3533,3971],{"className":3967},[3438],[3440,3969,3532],{"className":3970},[3443],[3447,3972,3973],{},"--output table",[3435,3975,3977],{"className":3976},[3438],"------------------------------------------------",[3435,3979,3981],{"className":3980},[3438],"| Tag     | Pushed                   | Size     |",[3435,3983,3985],{"className":3984},[3438],"|---------+--------------------------+----------|",[3435,3987,3989],{"className":3988},[3438],"| v1.1.0  | 2024-01-15T12:30:00+00:00| 211054321|",[3435,3991,3993],{"className":3992},[3438],"| v1.0.0  | 2024-01-10T09:15:00+00:00| 208832100|",[3435,3995,3977],{"className":3996},[3438],[3379,3998],{},[3387,4000,4002],{"id":4001},"ecr-put-lifecycle-policy","ecr put-lifecycle-policy",[3348,4004,4005],{},"Застосовує Lifecycle Policy до репозиторію — правило автоматичного видалення застарілих образів.",[3398,4007,4008,4011],{},[3401,4009,4010],{"name":3716,"type":3404,"required":3405},"Ім'я репозиторію, до якого застосовується policy.",[3401,4012,4015,4016,4019,4020,3363,4023,4026,4027,4030,4031,4034],{"name":4013,"type":4014,"required":3405},"--lifecycle-policy-text","json-string","JSON-рядок або посилання ",[3356,4017,4018],{},"file:\u002F\u002Fpath.json"," з правилами lifecycle policy. Кожне правило має ",[3356,4021,4022],{},"rulePriority",[3356,4024,4025],{},"selection"," (фільтр образів) та ",[3356,4028,4029],{},"action"," (",[3356,4032,4033],{},"expire",").",[3431,4036,4038,4047,4050,4054,4058,4062,4066,4070,4074,4078,4082,4086,4090,4093,4096,4105,4113,4122,4131,4134,4138,4142,4150],{"title":4037},"aws ecr put-lifecycle-policy",[3435,4039,4041,3445,4044],{"className":4040},[3438],[3440,4042,3444],{"className":4043},[3443],[3447,4045,4046],{},"cat lifecycle.json",[3435,4048,3818],{"className":4049},[3438],[3435,4051,4053],{"className":4052},[3438],"  \"rules\": [",[3435,4055,4057],{"className":4056},[3438],"    { \"rulePriority\": 1, \"description\": \"Видалити untagged після 1 дня\",",[3435,4059,4061],{"className":4060},[3438],"      \"selection\": { \"tagStatus\": \"untagged\", \"countType\": \"sinceImagePushed\",",[3435,4063,4065],{"className":4064},[3438],"                     \"countUnit\": \"days\", \"countNumber\": 1 },",[3435,4067,4069],{"className":4068},[3438],"      \"action\": { \"type\": \"expire\" } },",[3435,4071,4073],{"className":4072},[3438],"    { \"rulePriority\": 2, \"description\": \"Зберігати лише 10 tagged\",",[3435,4075,4077],{"className":4076},[3438],"      \"selection\": { \"tagStatus\": \"tagged\", \"tagPrefixList\": [\"v\"],",[3435,4079,4081],{"className":4080},[3438],"                     \"countType\": \"imageCountMoreThan\", \"countNumber\": 10 },",[3435,4083,4085],{"className":4084},[3438],"      \"action\": { \"type\": \"expire\" } }",[3435,4087,4089],{"className":4088},[3438],"  ]",[3435,4091,3859],{"className":4092},[3438],[3435,4094],{"className":4095},[3438],[3435,4097,4099,3445,4102],{"className":4098},[3438],[3440,4100,3444],{"className":4101},[3443],[3447,4103,4104],{},"aws ecr put-lifecycle-policy \\",[3435,4106,4108,3533,4111],{"className":4107},[3438],[3440,4109,3532],{"className":4110},[3443],[3447,4112,3787],{},[3435,4114,4116,3533,4119],{"className":4115},[3438],[3440,4117,3532],{"className":4118},[3443],[3447,4120,4121],{},"--lifecycle-policy-text file:\u002F\u002Flifecycle.json \\",[3435,4123,4125,3533,4128],{"className":4124},[3438],[3440,4126,3532],{"className":4127},[3443],[3447,4129,4130],{},"--region eu-central-1",[3435,4132,3818],{"className":4133},[3438],[3435,4135,4137],{"className":4136},[3438],"    \"registryId\": \"123456789012\",",[3435,4139,4141],{"className":4140},[3438],"    \"repositoryName\": \"my-api\",",[3435,4143,4145,4146],{"className":4144},[3438],"    ",[3440,4147,4149],{"className":4148},[3480],"\"lifecyclePolicyText\": \"{\\\"rules\\\":[...]}\"",[3435,4151,3859],{"className":4152},[3438],[3565,4154,4155,4156,4159,4160,4159,4163,4166],{},"Перед застосуванням policy перевірте, які образи підпадуть під видалення: ECR Console → ",[3356,4157,4158],{},"my-api"," → ",[3447,4161,4162],{},"Lifecycle policy",[3447,4164,4165],{},"Test rules"," — покаже список без реального видалення.",[3379,4168],{},[3387,4170,4172],{"id":4171},"ecr-start-image-scan-describe-image-scan-findings","ecr start-image-scan \u002F describe-image-scan-findings",[3348,4174,4175],{},"Запускає сканування образу на вразливості CVE або переглядає результати попереднього сканування.",[3398,4177,4178,4181],{},[3401,4179,4180],{"name":3716,"type":3404,"required":3405},"Ім'я репозиторію з образом.",[3401,4182,4184,4185,4188,4189,3377],{"name":4183,"type":3735,"required":3405},"--image-id","Ідентифікатор образу: ",[3356,4186,4187],{},"imageTag=v1.0.0"," або ",[3356,4190,4191],{},"imageDigest=sha256:abc123...",[3431,4193,4194,4203,4212,4220,4224,4227,4236,4244,4252,4261,4264,4268,4272,4276,4280,4284],{"title":4172},[3435,4195,4197,3445,4200],{"className":4196},[3438],[3440,4198,3444],{"className":4199},[3443],[3447,4201,4202],{},"aws ecr start-image-scan \\",[3435,4204,4206,3533,4209],{"className":4205},[3438],[3440,4207,3532],{"className":4208},[3443],[3447,4210,4211],{},"--repository-name my-api --image-id imageTag=v1.0.0 \\",[3435,4213,4215,3533,4218],{"className":4214},[3438],[3440,4216,3532],{"className":4217},[3443],[3447,4219,4130],{},[3435,4221,4223],{"className":4222},[3438],"{ \"imageScanStatus\": { \"status\": \"IN_PROGRESS\" } }",[3435,4225],{"className":4226},[3438],[3435,4228,4230,3445,4233],{"className":4229},[3438],[3440,4231,3444],{"className":4232},[3443],[3447,4234,4235],{},"aws ecr describe-image-scan-findings \\",[3435,4237,4239,3533,4242],{"className":4238},[3438],[3440,4240,3532],{"className":4241},[3443],[3447,4243,4211],{},[3435,4245,4247,3533,4250],{"className":4246},[3438],[3440,4248,3532],{"className":4249},[3443],[3447,4251,3796],{},[3435,4253,4255,3533,4258],{"className":4254},[3438],[3440,4256,3532],{"className":4257},[3443],[3447,4259,4260],{},"--query \"imageScanFindings.findingSeverityCounts\"",[3435,4262,3818],{"className":4263},[3438],[3435,4265,4267],{"className":4266},[3438],"    \"CRITICAL\": 0,",[3435,4269,4271],{"className":4270},[3438],"    \"HIGH\": 1,",[3435,4273,4275],{"className":4274},[3438],"    \"MEDIUM\": 3,",[3435,4277,4279],{"className":4278},[3438],"    \"LOW\": 12,",[3435,4281,4283],{"className":4282},[3438],"    \"INFORMATIONAL\": 5",[3435,4285,3859],{"className":4286},[3438],[3379,4288],{},[3387,4290,4292],{"id":4291},"ecr-put-image-tag-mutability","ecr put-image-tag-mutability",[3348,4294,4295],{},"Змінює режим захисту тегів для існуючого репозиторію.",[3398,4297,4298],{},[3401,4299,4300,4302,4303,4305],{"name":3743,"type":3404,"required":3405},[3356,4301,3746],{}," — теги можна перезаписати (за замовчуванням). ",[3356,4304,3750],{}," — теги незмінні після першого push; гарантує відтворюваність образів у production.",[3431,4307,4309,4318,4326,4335,4343,4346,4349,4356],{"title":4308},"aws ecr put-image-tag-mutability",[3435,4310,4312,3445,4315],{"className":4311},[3438],[3440,4313,3444],{"className":4314},[3443],[3447,4316,4317],{},"aws ecr put-image-tag-mutability \\",[3435,4319,4321,3533,4324],{"className":4320},[3438],[3440,4322,3532],{"className":4323},[3443],[3447,4325,3787],{},[3435,4327,4329,3533,4332],{"className":4328},[3438],[3440,4330,3532],{"className":4331},[3443],[3447,4333,4334],{},"--image-tag-mutability IMMUTABLE \\",[3435,4336,4338,3533,4341],{"className":4337},[3438],[3440,4339,3532],{"className":4340},[3443],[3447,4342,4130],{},[3435,4344,3818],{"className":4345},[3438],[3435,4347,4141],{"className":4348},[3438],[3435,4350,4145,4352],{"className":4351},[3438],[3440,4353,4355],{"className":4354},[3480],"\"imageTagMutability\": \"IMMUTABLE\"",[3435,4357,3859],{"className":4358},[3438],[3379,4360],{},[3387,4362,4364],{"id":4363},"ecr-set-repository-policy","ecr set-repository-policy",[3348,4366,4367],{},"Застосовує Resource-based Policy до репозиторію — дозволяє завантажувати образи з інших AWS акаунтів (multi-account архітектура).",[3398,4369,4370],{},[3401,4371,4373,4374,3363,4377,3363,4380,3377],{"name":4372,"type":4014,"required":3405},"--policy-text","JSON з IAM-policy. Principal — ARN акаунту або ролі, що має отримати доступ. Action — мінімально: ",[3356,4375,4376],{},"ecr:GetDownloadUrlForLayer",[3356,4378,4379],{},"ecr:BatchGetImage",[3356,4381,4382],{},"ecr:BatchCheckLayerAvailability",[3431,4384,4386,4395,4403,4412,4421,4430,4438,4442],{"title":4385},"aws ecr set-repository-policy — cross-account access",[3435,4387,4389,3445,4392],{"className":4388},[3438],[3440,4390,3444],{"className":4391},[3443],[3447,4393,4394],{},"aws ecr set-repository-policy \\",[3435,4396,4398,3533,4401],{"className":4397},[3438],[3440,4399,3532],{"className":4400},[3443],[3447,4402,3787],{},[3435,4404,4406,3533,4409],{"className":4405},[3438],[3440,4407,3532],{"className":4408},[3443],[3447,4410,4411],{},"--policy-text '{\"Version\":\"2012-10-17\",\"Statement\":[{\"Effect\":\"Allow\",",[3435,4413,4415,3533,4418],{"className":4414},[3438],[3440,4416,3532],{"className":4417},[3443],[3447,4419,4420],{},"\"Principal\":{\"AWS\":\"arn:aws:iam::PROD_ACCOUNT:root\"},",[3435,4422,4424,3533,4427],{"className":4423},[3438],[3440,4425,3532],{"className":4426},[3443],[3447,4428,4429],{},"\"Action\":[\"ecr:GetDownloadUrlForLayer\",\"ecr:BatchGetImage\"]}]}' \\",[3435,4431,4433,3533,4436],{"className":4432},[3438],[3440,4434,3532],{"className":4435},[3443],[3447,4437,4130],{},[3435,4439,4441],{"className":4440},[3438],"{ \"registryId\": \"123456789012\", \"repositoryName\": \"my-api\",",[3435,4443,4445,4446,4450],{"className":4444},[3438],"  ",[3440,4447,4449],{"className":4448},[3480],"\"policyText\": \"{\\\"Version\\\":\\\"2012-10-17\\\",...}\""," }",[3379,4452],{},[3387,4454,4456],{"id":4455},"ecr-put-replication-configuration","ecr put-replication-configuration",[3348,4458,4459],{},"Налаштовує автоматичну реплікацію образів між регіонами або між акаунтами.",[3398,4461,4462],{},[3401,4463,4465,4466,4469,4470,4473,4474,4477],{"name":4464,"type":3735,"required":3405},"--replication-configuration","Об'єкт з ",[3356,4467,4468],{},"rules"," — масивом правил реплікації. Кожне правило містить ",[3356,4471,4472],{},"destinations"," (регіон та registryId) та ",[3356,4475,4476],{},"repositoryFilters"," (фільтр за префіксом імені).",[3431,4479,4481,4490,4499,4508,4517,4525],{"title":4480},"aws ecr put-replication-configuration",[3435,4482,4484,3445,4487],{"className":4483},[3438],[3440,4485,3444],{"className":4486},[3443],[3447,4488,4489],{},"aws ecr put-replication-configuration \\",[3435,4491,4493,3533,4496],{"className":4492},[3438],[3440,4494,3532],{"className":4495},[3443],[3447,4497,4498],{},"--replication-configuration '{\"rules\":[{\"destinations\":[",[3435,4500,4502,3533,4505],{"className":4501},[3438],[3440,4503,3532],{"className":4504},[3443],[3447,4506,4507],{},"{\"region\":\"us-east-1\",\"registryId\":\"123456789012\"}],",[3435,4509,4511,3533,4514],{"className":4510},[3438],[3440,4512,3532],{"className":4513},[3443],[3447,4515,4516],{},"\"repositoryFilters\":[{\"filter\":\"my-api\",\"filterType\":\"PREFIX_MATCH\"}]}]}' \\",[3435,4518,4520,3533,4523],{"className":4519},[3438],[3440,4521,3532],{"className":4522},[3443],[3447,4524,4130],{},[3435,4526,4528,4529,4450],{"className":4527},[3438],"{ ",[3440,4530,4532],{"className":4531},[3480],"\"replicationConfiguration\": { \"rules\": [...] }",[3379,4534],{},[3387,4536,4538],{"id":4537},"ecr-batch-delete-image-delete-repository","ecr batch-delete-image \u002F delete-repository",[3348,4540,4541],{},"Видалення образів або цілого репозиторію.",[3398,4543,4544,4557],{},[3401,4545,4547,4548,4551,4552,4188,4554,3377],{"name":4546,"type":3890,"required":3405},"--image-ids","Список образів для ",[3356,4549,4550],{},"batch-delete-image",". Кожен елемент: ",[3356,4553,4187],{},[3356,4555,4556],{},"imageDigest=sha256:...",[3401,4558,4560,4561,4564],{"name":4559,"type":3428},"--force","Для ",[3356,4562,4563],{},"delete-repository"," — видаляє репозиторій навіть якщо він містить образи.",[3431,4566,4567,4576,4584,4593,4601,4605,4608,4617,4626],{"title":4538},[3435,4568,4570,3445,4573],{"className":4569},[3438],[3440,4571,3444],{"className":4572},[3443],[3447,4574,4575],{},"aws ecr batch-delete-image \\",[3435,4577,4579,3533,4582],{"className":4578},[3438],[3440,4580,3532],{"className":4581},[3443],[3447,4583,3787],{},[3435,4585,4587,3533,4590],{"className":4586},[3438],[3440,4588,3532],{"className":4589},[3443],[3447,4591,4592],{},"--image-ids imageTag=v1.0.0 imageTag=v1.1.0 \\",[3435,4594,4596,3533,4599],{"className":4595},[3438],[3440,4597,3532],{"className":4598},[3443],[3447,4600,4130],{},[3435,4602,4604],{"className":4603},[3438],"{ \"imageIds\": [{ \"imageTag\": \"v1.0.0\" }, { \"imageTag\": \"v1.1.0\" }], \"failures\": [] }",[3435,4606],{"className":4607},[3438],[3435,4609,4611,3445,4614],{"className":4610},[3438],[3440,4612,3444],{"className":4613},[3443],[3447,4615,4616],{},"aws ecr delete-repository \\",[3435,4618,4620,3533,4623],{"className":4619},[3438],[3440,4621,3532],{"className":4622},[3443],[3447,4624,4625],{},"--repository-name my-api --force --region eu-central-1",[3435,4627,4629,4630,4634],{"className":4628},[3438],"{ \"repository\": { \"repositoryName\": \"my-api\", ",[3440,4631,4633],{"className":4632},[3480],"\"repositoryUri\": \"...\""," } }",[3379,4636],{},[3382,4638,4640],{"id":4639},"amazon-ecs-cluster","Amazon ECS — Cluster",[3387,4642,4644],{"id":4643},"ecs-create-cluster","ecs create-cluster",[3348,4646,4647],{},"Створює логічну групу для запуску ECS Tasks та Services.",[3398,4649,4650,4654,4665],{},[3401,4651,4653],{"name":4652,"type":3404,"required":3405},"--cluster-name","Ім'я кластера. Унікальне в межах акаунту та регіону.",[3401,4655,4657,4658,3363,4661,4664],{"name":4656,"type":3890},"--capacity-providers","Capacity Providers: ",[3356,4659,4660],{},"FARGATE",[3356,4662,4663],{},"FARGATE_SPOT"," або власні EC2-провайдери. Якщо не вказано — кластер підтримує всі типи.",[3401,4666,4668,4669,4672],{"name":4667,"type":3890},"--settings","Налаштування кластера. ",[3356,4670,4671],{},"name=containerInsights,value=enabled"," вмикає CloudWatch Container Insights — деталізовані метрики CPU, Memory, Network по кожному Task та Service.",[3431,4674,4676,4685,4694,4703,4712,4720,4723,4727,4731,4738,4742,4746,4750,4754,4757],{"title":4675},"aws ecs create-cluster — відповідь",[3435,4677,4679,3445,4682],{"className":4678},[3438],[3440,4680,3444],{"className":4681},[3443],[3447,4683,4684],{},"aws ecs create-cluster \\",[3435,4686,4688,3533,4691],{"className":4687},[3438],[3440,4689,3532],{"className":4690},[3443],[3447,4692,4693],{},"--cluster-name ecs-lab-cluster \\",[3435,4695,4697,3533,4700],{"className":4696},[3438],[3440,4698,3532],{"className":4699},[3443],[3447,4701,4702],{},"--capacity-providers FARGATE \\",[3435,4704,4706,3533,4709],{"className":4705},[3438],[3440,4707,3532],{"className":4708},[3443],[3447,4710,4711],{},"--settings name=containerInsights,value=enabled \\",[3435,4713,4715,3533,4718],{"className":4714},[3438],[3440,4716,3532],{"className":4717},[3443],[3447,4719,4130],{},[3435,4721,3818],{"className":4722},[3438],[3435,4724,4726],{"className":4725},[3438],"    \"cluster\": {",[3435,4728,4730],{"className":4729},[3438],"        \"clusterArn\": \"arn:aws:ecs:eu-central-1:123456789012:cluster\u002Fecs-lab-cluster\",",[3435,4732,3838,4734,3843],{"className":4733},[3438],[3440,4735,4737],{"className":4736},[3480],"\"clusterName\": \"ecs-lab-cluster\"",[3435,4739,4741],{"className":4740},[3438],"        \"status\": \"ACTIVE\",",[3435,4743,4745],{"className":4744},[3438],"        \"registeredContainerInstancesCount\": 0,",[3435,4747,4749],{"className":4748},[3438],"        \"settings\": [{ \"name\": \"containerInsights\", \"value\": \"enabled\" }],",[3435,4751,4753],{"className":4752},[3438],"        \"capacityProviders\": [\"FARGATE\"]",[3435,4755,3855],{"className":4756},[3438],[3435,4758,3859],{"className":4759},[3438],[3379,4761],{},[3387,4763,4765],{"id":4764},"ecs-update-cluster-settings","ecs update-cluster-settings",[3348,4767,4768],{},"Вмикає або вимикає Container Insights для існуючого кластера.",[3398,4770,4771,4775],{},[3401,4772,4774],{"name":4773,"type":3404,"required":3405},"--cluster","Ім'я або ARN кластера.",[3401,4776,4777,4778,4188,4780,3377],{"name":4667,"type":3890,"required":3405},"Масив налаштувань. Для Container Insights: ",[3356,4779,4671],{},[3356,4781,4782],{},"value=disabled",[3431,4784,4786,4795,4804,4812,4820],{"title":4785},"aws ecs update-cluster-settings",[3435,4787,4789,3445,4792],{"className":4788},[3438],[3440,4790,3444],{"className":4791},[3443],[3447,4793,4794],{},"aws ecs update-cluster-settings \\",[3435,4796,4798,3533,4801],{"className":4797},[3438],[3440,4799,3532],{"className":4800},[3443],[3447,4802,4803],{},"--cluster ecs-lab-cluster \\",[3435,4805,4807,3533,4810],{"className":4806},[3438],[3440,4808,3532],{"className":4809},[3443],[3447,4811,4711],{},[3435,4813,4815,3533,4818],{"className":4814},[3438],[3440,4816,3532],{"className":4817},[3443],[3447,4819,4130],{},[3435,4821,4823,4824,4634],{"className":4822},[3438],"{ \"cluster\": { \"clusterName\": \"ecs-lab-cluster\", ",[3440,4825,4827],{"className":4826},[3480],"\"settings\": [{ \"name\": \"containerInsights\", \"value\": \"enabled\" }]",[3379,4829],{},[3387,4831,4833],{"id":4832},"ecs-delete-cluster","ecs delete-cluster",[3348,4835,4836],{},"Видаляє кластер. Перед видаленням усі Services та Tasks повинні бути зупинені.",[3431,4838,4840,4849],{"title":4839},"aws ecs delete-cluster",[3435,4841,4843,3445,4846],{"className":4842},[3438],[3440,4844,3444],{"className":4845},[3443],[3447,4847,4848],{},"aws ecs delete-cluster --cluster ecs-lab-cluster --region eu-central-1",[3435,4850,4823,4852,4634],{"className":4851},[3438],[3440,4853,4855],{"className":4854},[3480],"\"status\": \"INACTIVE\"",[3379,4857],{},[3382,4859,4861],{"id":4860},"amazon-ecs-task-definition","Amazon ECS — Task Definition",[3387,4863,4865],{"id":4864},"ecs-register-task-definition","ecs register-task-definition",[3348,4867,4868,4869,3377],{},"Реєструє нову Task Definition або нову revision існуючої сімейства. Приймає параметри напряму або через ",[3356,4870,4871],{},"--cli-input-json file:\u002F\u002Ftask-def.json",[3398,4873,4874,4893,4914,4923,4950,4964,4975,4982],{},[3401,4875,4877,4878,4881,4882,4885,4886,3363,4889,4892],{"name":4876,"type":3404,"required":3405},"--family","Ім'я сімейства Task Definition. Кожен виклик ",[3356,4879,4880],{},"register-task-definition"," з тим самим ",[3356,4883,4884],{},"family"," створює нову revision (",[3356,4887,4888],{},"my-api:1",[3356,4890,4891],{},"my-api:2",", ...).",[3401,4894,4896,4897,4900,4901,3363,4904,3363,4907,4910,4911,4913],{"name":4895,"type":3404},"--network-mode","Мережевий режим: ",[3356,4898,4899],{},"awsvpc"," (обов'язково для Fargate), ",[3356,4902,4903],{},"bridge",[3356,4905,4906],{},"host",[3356,4908,4909],{},"none",". При ",[3356,4912,4899],{}," кожен Task отримує власний ENI та IP.",[3401,4915,4917,4188,4919,4922],{"name":4916,"type":3890},"--requires-compatibilities",[3356,4918,4660],{},[3356,4920,4921],{},"EC2",". Для Fargate — обов'язково.",[3401,4924,4926,4927,4930,4931,3363,4934,3363,4937,3363,4940,3363,4943,3363,4946,4949],{"name":4925,"type":3404,"required":3405},"--cpu","Кількість CPU units у вигляді рядка: ",[3356,4928,4929],{},"\"256\""," (0.25 vCPU), ",[3356,4932,4933],{},"\"512\"",[3356,4935,4936],{},"\"1024\"",[3356,4938,4939],{},"\"2048\"",[3356,4941,4942],{},"\"4096\"",[3356,4944,4945],{},"\"8192\"",[3356,4947,4948],{},"\"16384\"",". Не довільне число — лише значення з таблиці допустимих комбінацій.",[3401,4951,4953,4954,4957,4958,4960,4961,4963],{"name":4952,"type":3404,"required":3405},"--memory","Пам'ять у MB. Значення обмежені залежно від ",[3356,4955,4956],{},"cpu",": для ",[3356,4959,4929],{}," — 512, 1024 або 2048; для ",[3356,4962,4933],{}," — 1024–4096 тощо.",[3401,4965,4967,4968,4971,4972,3377],{"name":4966,"type":3404,"required":3405},"--execution-role-arn","ARN IAM Role, яку Fargate використовує для завантаження образу з ECR та запису логів у CloudWatch. Зазвичай ",[3356,4969,4970],{},"ecsTaskExecutionRole"," з ",[3356,4973,4974],{},"AmazonECSTaskExecutionRolePolicy",[3401,4976,4978,4979,3377],{"name":4977,"type":3404},"--task-role-arn","ARN IAM Role для самого контейнера — надає права викликати інші AWS API (S3, SQS, DynamoDB тощо). Відокремлений від ",[3356,4980,4981],{},"execution-role-arn",[3401,4983,4986,4987,3363,4990,3363,4992,3363,4995,3363,4998,3363,5001,3363,5004,3377],{"name":4984,"type":4985,"required":3405},"--container-definitions","json-list","Масив конфігурацій контейнерів. Кожен об'єкт містить: ",[3356,4988,4989],{},"name",[3356,4991,3874],{},[3356,4993,4994],{},"portMappings",[3356,4996,4997],{},"environment",[3356,4999,5000],{},"secrets",[3356,5002,5003],{},"healthCheck",[3356,5005,5006],{},"logConfiguration",[3431,5008,5010,5019,5028,5036,5039,5043,5047,5054,5058,5061,5065,5069,5072],{"title":5009},"aws ecs register-task-definition",[3435,5011,5013,3445,5016],{"className":5012},[3438],[3440,5014,3444],{"className":5015},[3443],[3447,5017,5018],{},"aws ecs register-task-definition \\",[3435,5020,5022,3533,5025],{"className":5021},[3438],[3440,5023,3532],{"className":5024},[3443],[3447,5026,5027],{},"--cli-input-json file:\u002F\u002F\u002Ftmp\u002Ftask-def.json \\",[3435,5029,5031,3533,5034],{"className":5030},[3438],[3440,5032,3532],{"className":5033},[3443],[3447,5035,4130],{},[3435,5037,3818],{"className":5038},[3438],[3435,5040,5042],{"className":5041},[3438],"    \"taskDefinition\": {",[3435,5044,5046],{"className":5045},[3438],"        \"family\": \"my-api\",",[3435,5048,3838,5050,3843],{"className":5049},[3438],[3440,5051,5053],{"className":5052},[3480],"\"taskDefinitionArn\": \"arn:aws:ecs:eu-central-1:123456789012:task-definition\u002Fmy-api:1\"",[3435,5055,5057],{"className":5056},[3438],"        \"revision\": 1,",[3435,5059,4741],{"className":5060},[3438],[3435,5062,5064],{"className":5063},[3438],"        \"cpu\": \"256\",",[3435,5066,5068],{"className":5067},[3438],"        \"memory\": \"512\"",[3435,5070,3855],{"className":5071},[3438],[3435,5073,3859],{"className":5074},[3438],[3565,5076,5077,5078,3363,5080,3363,5082,5085],{},"Після кожної зміни Task Definition (навіть однієї змінної середовища) AWS створює нову revision. Попередні revisions зберігаються назавжди — ви можете відкотитись на будь-яку з них. ",[3356,5079,4888],{},[3356,5081,4891],{},[3356,5083,5084],{},"my-api:LATEST"," — всі посилаються на ту саму сімейство.",[3379,5087],{},[3387,5089,5091],{"id":5090},"ecs-list-task-definitions-describe-task-definition","ecs list-task-definitions \u002F describe-task-definition",[3348,5093,5094],{},"Перегляд зареєстрованих Task Definitions.",[3431,5096,5098,5107,5110,5114,5118,5122,5126,5129,5132,5141,5150,5153,5157,5161,5168],{"title":5097},"list-task-definitions \u002F describe-task-definition",[3435,5099,5101,3445,5104],{"className":5100},[3438],[3440,5102,3444],{"className":5103},[3443],[3447,5105,5106],{},"aws ecs list-task-definitions --family-prefix my-api --region eu-central-1",[3435,5108,3818],{"className":5109},[3438],[3435,5111,5113],{"className":5112},[3438],"    \"taskDefinitionArns\": [",[3435,5115,5117],{"className":5116},[3438],"        \"arn:aws:ecs:eu-central-1:123456789012:task-definition\u002Fmy-api:1\",",[3435,5119,5121],{"className":5120},[3438],"        \"arn:aws:ecs:eu-central-1:123456789012:task-definition\u002Fmy-api:2\"",[3435,5123,5125],{"className":5124},[3438],"    ]",[3435,5127,3859],{"className":5128},[3438],[3435,5130],{"className":5131},[3438],[3435,5133,5135,3445,5138],{"className":5134},[3438],[3440,5136,3444],{"className":5137},[3443],[3447,5139,5140],{},"aws ecs describe-task-definition --task-definition my-api:2 --region eu-central-1 \\",[3435,5142,5144,3533,5147],{"className":5143},[3438],[3440,5145,3532],{"className":5146},[3443],[3447,5148,5149],{},"--query \"taskDefinition.{cpu:cpu,memory:memory,image:containerDefinitions[0].image}\"",[3435,5151,3818],{"className":5152},[3438],[3435,5154,5156],{"className":5155},[3438],"    \"cpu\": \"256\",",[3435,5158,5160],{"className":5159},[3438],"    \"memory\": \"512\",",[3435,5162,4145,5164],{"className":5163},[3438],[3440,5165,5167],{"className":5166},[3480],"\"image\": \"123456789012.dkr.ecr.eu-central-1.amazonaws.com\u002Fmy-api:v1.1.0\"",[3435,5169,3859],{"className":5170},[3438],[3379,5172],{},[3382,5174,5176],{"id":5175},"amazon-ecs-service","Amazon ECS — Service",[3387,5178,5180],{"id":5179},"ecs-create-service","ecs create-service",[3348,5182,5183],{},"Створює ECS Service — оркестратор, що підтримує задану кількість Tasks, виконує rolling updates та інтегрується з ALB.",[3398,5185,5186,5189,5193,5204,5209,5217,5231,5245],{},[3401,5187,5188],{"name":4773,"type":3404,"required":3405},"Ім'я кластера, де буде запущено Service.",[3401,5190,5192],{"name":5191,"type":3404,"required":3405},"--service-name","Ім'я Service. Унікальне в межах кластера.",[3401,5194,5196,5197,5199,5200,5203],{"name":5195,"type":3404,"required":3405},"--task-definition","Ім'я Task Definition або конкретна revision: ",[3356,5198,4158],{}," (остання) або ",[3356,5201,5202],{},"my-api:3"," (конкретна).",[3401,5205,5208],{"name":5206,"type":5207,"required":3405},"--desired-count","integer","Бажана кількість паралельно запущених Tasks. Service підтримуватиме саме цю кількість.",[3401,5210,5212,4188,5214,5216],{"name":5211,"type":3404},"--launch-type",[3356,5213,4660],{},[3356,5215,4921],{},". При використанні Capacity Providers не вказується.",[3401,5218,5220,5221,4030,5224,4188,5227,5230],{"name":5219,"type":3735},"--network-configuration","Конфігурація awsvpc: підмережі, Security Groups, ",[3356,5222,5223],{},"assignPublicIp",[3356,5225,5226],{},"ENABLED",[3356,5228,5229],{},"DISABLED","). Обов'язкова для Fargate.",[3401,5232,5234,5235,3363,5238,3363,5241,5244],{"name":5233,"type":3890},"--load-balancers","Прив'язка до Target Group ALB: ",[3356,5236,5237],{},"targetGroupArn",[3356,5239,5240],{},"containerName",[3356,5242,5243],{},"containerPort",". Без цього параметра Service не реєструє Tasks в ALB.",[3401,5246,5248,5249,5252,5253,5256],{"name":5247,"type":3735},"--deployment-configuration","Параметри rolling update: ",[3356,5250,5251],{},"minimumHealthyPercent"," (мінімум здорових Tasks, %) та ",[3356,5254,5255],{},"maximumPercent"," (максимум Tasks під час деплою, %).",[3431,5258,5260,5269,5278,5287,5296,5305,5313,5316,5320,5327,5330,5334,5338,5342,5345],{"title":5259},"aws ecs create-service",[3435,5261,5263,3445,5266],{"className":5262},[3438],[3440,5264,3444],{"className":5265},[3443],[3447,5267,5268],{},"aws ecs create-service \\",[3435,5270,5272,3533,5275],{"className":5271},[3438],[3440,5273,3532],{"className":5274},[3443],[3447,5276,5277],{},"--cluster ecs-lab-cluster --service-name ecs-lab-service \\",[3435,5279,5281,3533,5284],{"className":5280},[3438],[3440,5282,3532],{"className":5283},[3443],[3447,5285,5286],{},"--task-definition ecs-lab-api --desired-count 2 \\",[3435,5288,5290,3533,5293],{"className":5289},[3438],[3440,5291,3532],{"className":5292},[3443],[3447,5294,5295],{},"--launch-type FARGATE \\",[3435,5297,5299,3533,5302],{"className":5298},[3438],[3440,5300,3532],{"className":5301},[3443],[3447,5303,5304],{},"--network-configuration \"awsvpcConfiguration={subnets=[subnet-aaa,subnet-bbb],securityGroups=[sg-zzz],assignPublicIp=ENABLED}\" \\",[3435,5306,5308,3533,5311],{"className":5307},[3438],[3440,5309,3532],{"className":5310},[3443],[3447,5312,4130],{},[3435,5314,3818],{"className":5315},[3438],[3435,5317,5319],{"className":5318},[3438],"    \"service\": {",[3435,5321,3838,5323,3843],{"className":5322},[3438],[3440,5324,5326],{"className":5325},[3480],"\"serviceArn\": \"arn:aws:ecs:eu-central-1:123456789012:service\u002Fecs-lab-cluster\u002Fecs-lab-service\"",[3435,5328,4741],{"className":5329},[3438],[3435,5331,5333],{"className":5332},[3438],"        \"desiredCount\": 2,",[3435,5335,5337],{"className":5336},[3438],"        \"runningCount\": 0,",[3435,5339,5341],{"className":5340},[3438],"        \"pendingCount\": 2",[3435,5343,3855],{"className":5344},[3438],[3435,5346,3859],{"className":5347},[3438],[3379,5349],{},[3387,5351,5353],{"id":5352},"ecs-update-service","ecs update-service",[3348,5355,5356],{},"Оновлює конфігурацію існуючого Service. Найчастіше використовується для запуску нової Task Definition (rolling update) або вмикання\u002Fвимикання функцій.",[3398,5358,5359,5362,5369,5376,5387],{},[3401,5360,5361],{"name":5195,"type":3404},"Нова Task Definition. Після оновлення ECS починає rolling update: запускає нові Tasks з новою конфігурацією і поступово зупиняє старі.",[3401,5363,5364,5365,5368],{"name":5206,"type":5207},"Нова бажана кількість Tasks. ",[3356,5366,5367],{},"0"," — зупиняє всі Tasks (Service залишається, але нічого не запущено).",[3401,5370,5372,5373,3377],{"name":5371,"type":3428},"--enable-execute-command","Вмикає ECS Exec — можливість підключатись до контейнера через ",[3356,5374,5375],{},"aws ecs execute-command",[3401,5377,5378,5379,5382,5383,3363,5385,3377],{"name":5247,"type":3735},"Оновлює параметри деплою: ",[3356,5380,5381],{},"deploymentCircuitBreaker"," (автовідкат при збоях), ",[3356,5384,5255],{},[3356,5386,5251],{},[3401,5388,5390,5391,3377],{"name":5389,"type":3428},"--force-new-deployment","Примусово перезапустити всі Tasks навіть якщо Task Definition не змінилась. Корисно для підхоплення нового образу з тегом ",[3356,5392,3413],{},[3431,5394,5396,5405,5413,5422,5431,5439,5442,5445,5449,5456,5459],{"title":5395},"aws ecs update-service — rolling update та circuit breaker",[3435,5397,5399,3445,5402],{"className":5398},[3438],[3440,5400,3444],{"className":5401},[3443],[3447,5403,5404],{},"aws ecs update-service \\",[3435,5406,5408,3533,5411],{"className":5407},[3438],[3440,5409,3532],{"className":5410},[3443],[3447,5412,5277],{},[3435,5414,5416,3533,5419],{"className":5415},[3438],[3440,5417,3532],{"className":5418},[3443],[3447,5420,5421],{},"--task-definition ecs-lab-api:2 \\",[3435,5423,5425,3533,5428],{"className":5424},[3438],[3440,5426,3532],{"className":5427},[3443],[3447,5429,5430],{},"--deployment-configuration '{\"deploymentCircuitBreaker\":{\"enable\":true,\"rollback\":true},\"maximumPercent\":200,\"minimumHealthyPercent\":50}' \\",[3435,5432,5434,3533,5437],{"className":5433},[3438],[3440,5435,3532],{"className":5436},[3443],[3447,5438,4130],{},[3435,5440,3818],{"className":5441},[3438],[3435,5443,5319],{"className":5444},[3438],[3435,5446,5448],{"className":5447},[3438],"        \"taskDefinition\": \"arn:aws:ecs:...:task-definition\u002Fecs-lab-api:2\",",[3435,5450,3838,5452],{"className":5451},[3438],[3440,5453,5455],{"className":5454},[3480],"\"deployments\": [{ \"status\": \"PRIMARY\", \"taskDefinition\": \"...ecs-lab-api:2\", \"runningCount\": 0, \"desiredCount\": 2 }]",[3435,5457,3855],{"className":5458},[3438],[3435,5460,3859],{"className":5461},[3438],[3565,5463,5464,5467,5468,5471,5472,5475],{},[3356,5465,5466],{},"maximumPercent=200"," при ",[3356,5469,5470],{},"desiredCount=2"," означає: ECS може запустити до 4 Tasks одночасно під час rolling update (2 старих + 2 нових). ",[3356,5473,5474],{},"minimumHealthyPercent=50"," гарантує, що принаймні 1 Task залишається здоровим весь час.",[3379,5477],{},[3387,5479,5481],{"id":5480},"ecs-delete-service","ecs delete-service",[3348,5483,5484,5485,5488],{},"Видаляє Service. Рекомендується спочатку встановити ",[3356,5486,5487],{},"--desired-count 0",", щоб ECS зупинив Tasks, а потім видалити.",[3398,5490,5491],{},[3401,5492,5493,5494,5496,5497,3377],{"name":4559,"type":3428},"Видалити Service навіть якщо він має запущені Tasks. Без ",[3356,5495,4559],{}," вимагає ",[3356,5498,5499],{},"desiredCount=0",[3431,5501,5503,5510,5519,5526,5529,5536,5545],{"title":5502},"aws ecs delete-service — правильна послідовність",[3435,5504,5506],{"className":5505},[3438],[3440,5507,5509],{"className":5508},[3443],"# 1. Зупинити всі Tasks (встановити desiredCount=0)",[3435,5511,5513,3445,5516],{"className":5512},[3438],[3440,5514,3444],{"className":5515},[3443],[3447,5517,5518],{},"aws ecs update-service --cluster ecs-lab-cluster --service ecs-lab-service --desired-count 0 --region eu-central-1",[3435,5520,5522],{"className":5521},[3438],[3440,5523,5525],{"className":5524},[3480],"(сервіс переходить у runningCount: 0)",[3435,5527],{"className":5528},[3438],[3435,5530,5532],{"className":5531},[3438],[3440,5533,5535],{"className":5534},[3443],"# 2. Видалити Service",[3435,5537,5539,3445,5542],{"className":5538},[3438],[3440,5540,3444],{"className":5541},[3443],[3447,5543,5544],{},"aws ecs delete-service --cluster ecs-lab-cluster --service ecs-lab-service --force --region eu-central-1",[3435,5546,5548,5549,5553],{"className":5547},[3438],"{ \"service\": { \"status\": ",[3440,5550,5552],{"className":5551},[3480],"\"DRAINING\"",", ... } }",[3379,5555],{},[3382,5557,5559],{"id":5558},"amazon-ecs-tasks","Amazon ECS — Tasks",[3387,5561,5563],{"id":5562},"ecs-list-tasks-describe-tasks","ecs list-tasks \u002F describe-tasks",[3348,5565,5566],{},"Перегляд запущених Tasks у кластері.",[3398,5568,5569,5571,5578],{},[3401,5570,4774],{"name":4773,"type":3404,"required":3405},[3401,5572,5573,5574,5577],{"name":5191,"type":3404},"Фільтр для ",[3356,5575,5576],{},"list-tasks"," — повертає лише Tasks конкретного Service.",[3401,5579,5581,5582,3377],{"name":5580,"type":3890,"required":3405},"--tasks","Список ARN Tasks для ",[3356,5583,5584],{},"describe-tasks",[3431,5586,5587,5596,5599,5603,5607,5611,5614,5617,5620,5629,5638,5646,5655],{"title":5563},[3435,5588,5590,3445,5593],{"className":5589},[3438],[3440,5591,3444],{"className":5592},[3443],[3447,5594,5595],{},"aws ecs list-tasks --cluster ecs-lab-cluster --region eu-central-1",[3435,5597,3818],{"className":5598},[3438],[3435,5600,5602],{"className":5601},[3438],"    \"taskArns\": [",[3435,5604,5606],{"className":5605},[3438],"        \"arn:aws:ecs:eu-central-1:123456789012:task\u002Fecs-lab-cluster\u002Fabc123\",",[3435,5608,5610],{"className":5609},[3438],"        \"arn:aws:ecs:eu-central-1:123456789012:task\u002Fecs-lab-cluster\u002Fdef456\"",[3435,5612,5125],{"className":5613},[3438],[3435,5615,3859],{"className":5616},[3438],[3435,5618],{"className":5619},[3438],[3435,5621,5623,3445,5626],{"className":5622},[3438],[3440,5624,3444],{"className":5625},[3443],[3447,5627,5628],{},"aws ecs describe-tasks --cluster ecs-lab-cluster \\",[3435,5630,5632,3533,5635],{"className":5631},[3438],[3440,5633,3532],{"className":5634},[3443],[3447,5636,5637],{},"--tasks arn:aws:ecs:eu-central-1:123456789012:task\u002Fecs-lab-cluster\u002Fabc123 \\",[3435,5639,5641,3533,5644],{"className":5640},[3438],[3440,5642,3532],{"className":5643},[3443],[3447,5645,3796],{},[3435,5647,5649,3533,5652],{"className":5648},[3438],[3440,5650,3532],{"className":5651},[3443],[3447,5653,5654],{},"--query \"tasks[0].{status:lastStatus,ip:attachments[0].details[?name=='privateIPv4Address'].value|[0]}\"",[3435,5656,4528,5658,5662],{"className":5657},[3438],[3440,5659,5661],{"className":5660},[3480],"\"status\": \"RUNNING\"",", \"ip\": \"10.0.1.47\" }",[3379,5664],{},[3387,5666,5668],{"id":5667},"ecs-execute-command","ecs execute-command",[3348,5670,5671,5672,5675,5676,5679,5680,3377],{},"Відкриває інтерактивну сесію всередині запущеного контейнера (аналог ",[3356,5673,5674],{},"docker exec","). Потребує: ",[3356,5677,5678],{},"enableExecuteCommand=true"," у Service, SSM права у Task Role, встановленого ",[3356,5681,5682],{},"session-manager-plugin",[3398,5684,5685,5688,5692,5696,5700],{},[3401,5686,5687],{"name":4773,"type":3404,"required":3405},"Ім'я кластера.",[3401,5689,5691],{"name":5690,"type":3404,"required":3405},"--task","ARN Task, до якого підключаємось.",[3401,5693,5695],{"name":5694,"type":3404},"--container","Ім'я контейнера. Якщо Task має лише один контейнер — можна не вказувати.",[3401,5697,5699],{"name":5698,"type":3428,"required":3405},"--interactive","Вмикає інтерактивний режим (TTY). Без нього команда виконається та завершиться без prompt.",[3401,5701,5703,5704,3363,5707,5710],{"name":5702,"type":3404,"required":3405},"--command","Команда, яку запустити: ",[3356,5705,5706],{},"\u002Fbin\u002Fbash",[3356,5708,5709],{},"\u002Fbin\u002Fsh",", або будь-яка утиліта всередині образу.",[3431,5712,5714,5723,5731,5740,5749,5758,5767,5775,5779,5787,5791,5795,5802],{"title":5713},"aws ecs execute-command — інтерактивна сесія",[3435,5715,5717,3445,5720],{"className":5716},[3438],[3440,5718,3444],{"className":5719},[3443],[3447,5721,5722],{},"aws ecs execute-command \\",[3435,5724,5726,3533,5729],{"className":5725},[3438],[3440,5727,3532],{"className":5728},[3443],[3447,5730,4803],{},[3435,5732,5734,3533,5737],{"className":5733},[3438],[3440,5735,3532],{"className":5736},[3443],[3447,5738,5739],{},"--task arn:aws:ecs:eu-central-1:123456789012:task\u002Fecs-lab-cluster\u002Fabc123 \\",[3435,5741,5743,3533,5746],{"className":5742},[3438],[3440,5744,3532],{"className":5745},[3443],[3447,5747,5748],{},"--container ecs-lab-api \\",[3435,5750,5752,3533,5755],{"className":5751},[3438],[3440,5753,3532],{"className":5754},[3443],[3447,5756,5757],{},"--interactive \\",[3435,5759,5761,3533,5764],{"className":5760},[3438],[3440,5762,3532],{"className":5763},[3443],[3447,5765,5766],{},"--command \"\u002Fbin\u002Fbash\" \\",[3435,5768,5770,3533,5773],{"className":5769},[3438],[3440,5771,3532],{"className":5772},[3443],[3447,5774,4130],{},[3435,5776,5778],{"className":5777},[3438],"Starting session with SessionId: ecs-execute-command-0abc123def456",[3435,5780,5782,5786],{"className":5781},[3438],[3440,5783,5785],{"className":5784},[3480],"app@3f4a8b9c1d2e:\u002Fapp$"," env | grep ASPNETCORE",[3435,5788,5790],{"className":5789},[3438],"ASPNETCORE_ENVIRONMENT=Production",[3435,5792,5794],{"className":5793},[3438],"ASPNETCORE_URLS=http:\u002F\u002F[::]:8080",[3435,5796,5798,5801],{"className":5797},[3438],[3440,5799,5785],{"className":5800},[3480]," curl localhost:8080\u002Fhealth",[3435,5803,5805],{"className":5804},[3438],"Healthy",[3379,5807],{},[3387,5809,5811],{"id":5810},"ecs-put-cluster-capacity-providers","ecs put-cluster-capacity-providers",[3348,5813,5814],{},"Налаштовує Capacity Provider Strategy — розподіл Tasks між FARGATE та FARGATE_SPOT для економії коштів.",[3398,5816,5817,5824],{},[3401,5818,5819,5820,5823],{"name":4656,"type":3890,"required":3405},"Список провайдерів: ",[3356,5821,5822],{},"FARGATE FARGATE_SPOT",". Обидва вказуються через пробіл.",[3401,5825,5827,5828,5831,5832,5835,5836,5839,5840,5843],{"name":5826,"type":3890,"required":3405},"--default-capacity-provider-strategy","Стратегія розподілу. ",[3356,5829,5830],{},"base"," — мінімальна кількість Tasks на провайдері. ",[3356,5833,5834],{},"weight"," — відносна вага. При ",[3356,5837,5838],{},"base=1,weight=1"," для FARGATE та ",[3356,5841,5842],{},"weight=3"," для FARGATE_SPOT: перший Task завжди на FARGATE, далі 75% на FARGATE_SPOT.",[3431,5845,5847,5856,5864,5873,5882,5892,5901,5909,5913,5920],{"title":5846},"aws ecs put-cluster-capacity-providers",[3435,5848,5850,3445,5853],{"className":5849},[3438],[3440,5851,3444],{"className":5852},[3443],[3447,5854,5855],{},"aws ecs put-cluster-capacity-providers \\",[3435,5857,5859,3533,5862],{"className":5858},[3438],[3440,5860,3532],{"className":5861},[3443],[3447,5863,4803],{},[3435,5865,5867,3533,5870],{"className":5866},[3438],[3440,5868,3532],{"className":5869},[3443],[3447,5871,5872],{},"--capacity-providers FARGATE FARGATE_SPOT \\",[3435,5874,5876,3533,5879],{"className":5875},[3438],[3440,5877,3532],{"className":5878},[3443],[3447,5880,5881],{},"--default-capacity-provider-strategy \\",[3435,5883,5885,5888,5889],{"className":5884},[3438],[3440,5886,3532],{"className":5887},[3443],"         ",[3447,5890,5891],{},"\"capacityProvider=FARGATE_SPOT,weight=3,base=0\" \\",[3435,5893,5895,5888,5898],{"className":5894},[3438],[3440,5896,3532],{"className":5897},[3443],[3447,5899,5900],{},"\"capacityProvider=FARGATE,weight=1,base=1\" \\",[3435,5902,5904,3533,5907],{"className":5903},[3438],[3440,5905,3532],{"className":5906},[3443],[3447,5908,4130],{},[3435,5910,5912],{"className":5911},[3438],"{ \"cluster\": { \"clusterName\": \"ecs-lab-cluster\",",[3435,5914,4145,5916,3843],{"className":5915},[3438],[3440,5917,5919],{"className":5918},[3480],"\"capacityProviders\": [\"FARGATE\", \"FARGATE_SPOT\"]",[3435,5921,5923],{"className":5922},[3438],"    \"defaultCapacityProviderStrategy\": [...] } }",[3694,5925,5926,5928],{},[3356,5927,4663],{}," Tasks можуть бути примусово зупинені AWS з 2-хвилинним попередженням. Використовуйте FARGATE_SPOT лише для stateless, batch або job-сервісів. Production API-сервіси зі станом слід тримати на FARGATE.",[3379,5930],{},[3382,5932,5934],{"id":5933},"iam-roles-для-ecs","IAM Roles для ECS",[3387,5936,5938],{"id":5937},"iam-create-role-attach-role-policy-task-execution-role","iam create-role + attach-role-policy — Task Execution Role",[3348,5940,5941],{},"Стандартна роль, яку Fargate використовує для завантаження образу з ECR та запису логів у CloudWatch. Потрібна для кожного кластера.",[3431,5943,5945,5952,5961,5965,5969,5973,5976,5983,5992,6001,6010,6019,6022,6029,6038,6046,6055],{"title":5944},"створення ecsTaskExecutionRole",[3435,5946,5948],{"className":5947},[3438],[3440,5949,5951],{"className":5950},[3443],"# 1. Trust Policy — дозволяє ECS Tasks приймати роль",[3435,5953,5955,3445,5958],{"className":5954},[3438],[3440,5956,3444],{"className":5957},[3443],[3447,5959,5960],{},"cat > \u002Ftmp\u002Fecs-trust.json \u003C\u003C 'EOF'",[3435,5962,5964],{"className":5963},[3438],"{ \"Version\":\"2012-10-17\", \"Statement\":[{ \"Effect\":\"Allow\",",[3435,5966,5968],{"className":5967},[3438],"  \"Principal\":{\"Service\":\"ecs-tasks.amazonaws.com\"}, \"Action\":\"sts:AssumeRole\" }] }",[3435,5970,5972],{"className":5971},[3438],"EOF",[3435,5974],{"className":5975},[3438],[3435,5977,5979],{"className":5978},[3438],[3440,5980,5982],{"className":5981},[3443],"# 2. Створити роль",[3435,5984,5986,3445,5989],{"className":5985},[3438],[3440,5987,3444],{"className":5988},[3443],[3447,5990,5991],{},"aws iam create-role \\",[3435,5993,5995,3533,5998],{"className":5994},[3438],[3440,5996,3532],{"className":5997},[3443],[3447,5999,6000],{},"--role-name ecsTaskExecutionRole \\",[3435,6002,6004,3533,6007],{"className":6003},[3438],[3440,6005,3532],{"className":6006},[3443],[3447,6008,6009],{},"--assume-role-policy-document file:\u002F\u002F\u002Ftmp\u002Fecs-trust.json",[3435,6011,6013,6014,6018],{"className":6012},[3438],"{ \"Role\": { ",[3440,6015,6017],{"className":6016},[3480],"\"RoleName\": \"ecsTaskExecutionRole\"",", \"Arn\": \"arn:aws:iam::123456789012:role\u002FecsTaskExecutionRole\" } }",[3435,6020],{"className":6021},[3438],[3435,6023,6025],{"className":6024},[3438],[3440,6026,6028],{"className":6027},[3443],"# 3. Прикріпити managed policy",[3435,6030,6032,3445,6035],{"className":6031},[3438],[3440,6033,3444],{"className":6034},[3443],[3447,6036,6037],{},"aws iam attach-role-policy \\",[3435,6039,6041,3533,6044],{"className":6040},[3438],[3440,6042,3532],{"className":6043},[3443],[3447,6045,6000],{},[3435,6047,6049,3533,6052],{"className":6048},[3438],[3440,6050,3532],{"className":6051},[3443],[3447,6053,6054],{},"--policy-arn arn:aws:iam::aws:policy\u002Fservice-role\u002FAmazonECSTaskExecutionRolePolicy",[3435,6056,6058],{"className":6057},[3438],[3440,6059,3543],{"className":6060},[3480],[3379,6062],{},[3387,6064,6066],{"id":6065},"iam-create-role-put-role-policy-eventbridge-scheduler-role","iam create-role + put-role-policy — EventBridge Scheduler Role",[3348,6068,6069],{},"IAM Role для EventBridge Scheduler, що дозволяє запускати ECS Tasks за розкладом.",[3431,6071,6073,6082,6085,6089,6092,6095,6103,6112,6121,6129,6132,6141,6149,6158,6167,6176,6185],{"title":6072},"створення EventBridgeECSRole для Scheduled Tasks",[3435,6074,6076,3445,6079],{"className":6075},[3438],[3440,6077,3444],{"className":6078},[3443],[3447,6080,6081],{},"cat > \u002Ftmp\u002Feb-trust.json \u003C\u003C 'EOF'",[3435,6083,5964],{"className":6084},[3438],[3435,6086,6088],{"className":6087},[3438],"  \"Principal\":{\"Service\":\"scheduler.amazonaws.com\"}, \"Action\":\"sts:AssumeRole\" }] }",[3435,6090,5972],{"className":6091},[3438],[3435,6093],{"className":6094},[3438],[3435,6096,6098,3445,6101],{"className":6097},[3438],[3440,6099,3444],{"className":6100},[3443],[3447,6102,5991],{},[3435,6104,6106,3533,6109],{"className":6105},[3438],[3440,6107,3532],{"className":6108},[3443],[3447,6110,6111],{},"--role-name EventBridgeECSRole \\",[3435,6113,6115,3533,6118],{"className":6114},[3438],[3440,6116,3532],{"className":6117},[3443],[3447,6119,6120],{},"--assume-role-policy-document file:\u002F\u002F\u002Ftmp\u002Feb-trust.json",[3435,6122,6013,6124,6128],{"className":6123},[3438],[3440,6125,6127],{"className":6126},[3480],"\"RoleName\": \"EventBridgeECSRole\"",", \"Arn\": \"arn:aws:iam::123456789012:role\u002FEventBridgeECSRole\" } }",[3435,6130],{"className":6131},[3438],[3435,6133,6135,3445,6138],{"className":6134},[3438],[3440,6136,3444],{"className":6137},[3443],[3447,6139,6140],{},"aws iam put-role-policy \\",[3435,6142,6144,3533,6147],{"className":6143},[3438],[3440,6145,3532],{"className":6146},[3443],[3447,6148,6111],{},[3435,6150,6152,3533,6155],{"className":6151},[3438],[3440,6153,3532],{"className":6154},[3443],[3447,6156,6157],{},"--policy-name ECSRunTaskPolicy \\",[3435,6159,6161,3533,6164],{"className":6160},[3438],[3440,6162,3532],{"className":6163},[3443],[3447,6165,6166],{},"--policy-document '{\"Version\":\"2012-10-17\",\"Statement\":[",[3435,6168,6170,5888,6173],{"className":6169},[3438],[3440,6171,3532],{"className":6172},[3443],[3447,6174,6175],{},"{\"Effect\":\"Allow\",\"Action\":\"ecs:RunTask\",\"Resource\":\"arn:aws:ecs:...:task-definition\u002Fcleanup-task:*\"},",[3435,6177,6179,5888,6182],{"className":6178},[3438],[3440,6180,3532],{"className":6181},[3443],[3447,6183,6184],{},"{\"Effect\":\"Allow\",\"Action\":\"iam:PassRole\",\"Resource\":\"arn:aws:iam::...:role\u002FecsTaskExecutionRole\"}]}'",[3435,6186,6188],{"className":6187},[3438],[3440,6189,3543],{"className":6190},[3480],[3379,6192],{},[3382,6194,6196],{"id":6195},"ec2-vpc-та-security-groups-для-ecs","EC2 — VPC та Security Groups для ECS",[3387,6198,6200],{"id":6199},"ec2-describe-vpcs-describe-subnets","ec2 describe-vpcs \u002F describe-subnets",[3348,6202,6203],{},"Знайти ID Default VPC та підмереж перед запуском ECS Service.",[3431,6205,6206,6215,6224,6233,6240,6243,6252,6261,6270,6279,6283,6287,6291,6295,6299,6303],{"title":6200},[3435,6207,6209,3445,6212],{"className":6208},[3438],[3440,6210,3444],{"className":6211},[3443],[3447,6213,6214],{},"aws ec2 describe-vpcs \\",[3435,6216,6218,3533,6221],{"className":6217},[3438],[3440,6219,3532],{"className":6220},[3443],[3447,6222,6223],{},"--filters \"Name=isDefault,Values=true\" \\",[3435,6225,6227,3533,6230],{"className":6226},[3438],[3440,6228,3532],{"className":6229},[3443],[3447,6231,6232],{},"--query \"Vpcs[0].VpcId\" --output text --region eu-central-1",[3435,6234,6236],{"className":6235},[3438],[3440,6237,6239],{"className":6238},[3480],"vpc-0a1b2c3d4e5f67890",[3435,6241],{"className":6242},[3438],[3435,6244,6246,3445,6249],{"className":6245},[3438],[3440,6247,3444],{"className":6248},[3443],[3447,6250,6251],{},"aws ec2 describe-subnets \\",[3435,6253,6255,3533,6258],{"className":6254},[3438],[3440,6256,3532],{"className":6257},[3443],[3447,6259,6260],{},"--filters \"Name=defaultForAz,Values=true\" \\",[3435,6262,6264,3533,6267],{"className":6263},[3438],[3440,6265,3532],{"className":6266},[3443],[3447,6268,6269],{},"--query \"Subnets[*].{ID:SubnetId,AZ:AvailabilityZone}\" \\",[3435,6271,6273,3533,6276],{"className":6272},[3438],[3440,6274,3532],{"className":6275},[3443],[3447,6277,6278],{},"--output table --region eu-central-1",[3435,6280,6282],{"className":6281},[3438],"----------------------------------------------",[3435,6284,6286],{"className":6285},[3438],"| AZ              | ID                      |",[3435,6288,6290],{"className":6289},[3438],"|-----------------+-------------------------|",[3435,6292,6294],{"className":6293},[3438],"| eu-central-1a   | subnet-0a1b2c3d          |",[3435,6296,6298],{"className":6297},[3438],"| eu-central-1b   | subnet-1b2c3d4e          |",[3435,6300,6302],{"className":6301},[3438],"| eu-central-1c   | subnet-2c3d4e5f          |",[3435,6304,6282],{"className":6305},[3438],[3379,6307],{},[3387,6309,6311],{"id":6310},"ec2-create-security-group-authorize-security-group-ingress","ec2 create-security-group \u002F authorize-security-group-ingress",[3348,6313,6314],{},"Створює Security Group та додає правила вхідного трафіку.",[3398,6316,6317,6321,6325,6329,6337],{},[3401,6318,6320],{"name":6319,"type":3404,"required":3405},"--group-name","Ім'я Security Group. Унікальне в межах VPC.",[3401,6322,6324],{"name":6323,"type":3404,"required":3405},"--description","Текстовий опис. Обов'язковий параметр.",[3401,6326,6328],{"name":6327,"type":3404,"required":3405},"--vpc-id","ID VPC, в якому створюється Security Group.",[3401,6330,6332,6333,6336],{"name":6331,"type":3404},"--cidr","CIDR блок для правила ingress. ",[3356,6334,6335],{},"0.0.0.0\u002F0"," — весь Інтернет (лише для lab).",[3401,6338,6340],{"name":6339,"type":3404},"--source-group","ID іншого Security Group як джерело трафіку. Рекомендований підхід для production: ALB SG → Tasks SG.",[3431,6342,6344,6353,6362,6371,6380,6389,6396,6399,6406,6415,6424,6433,6439,6442,6449,6457,6466,6475],{"title":6343},"ec2 create-security-group + authorize-ingress",[3435,6345,6347,3445,6350],{"className":6346},[3438],[3440,6348,3444],{"className":6349},[3443],[3447,6351,6352],{},"SG_ID=$(aws ec2 create-security-group \\",[3435,6354,6356,3533,6359],{"className":6355},[3438],[3440,6357,3532],{"className":6358},[3443],[3447,6360,6361],{},"--group-name \"ecs-lab-sg\" \\",[3435,6363,6365,3533,6368],{"className":6364},[3438],[3440,6366,3532],{"className":6367},[3443],[3447,6369,6370],{},"--description \"ECS Tasks security group\" \\",[3435,6372,6374,3533,6377],{"className":6373},[3438],[3440,6375,3532],{"className":6376},[3443],[3447,6378,6379],{},"--vpc-id vpc-0a1b2c3d4e5f67890 \\",[3435,6381,6383,3533,6386],{"className":6382},[3438],[3440,6384,3532],{"className":6385},[3443],[3447,6387,6388],{},"--query GroupId --output text --region eu-central-1)",[3435,6390,6392],{"className":6391},[3438],[3440,6393,6395],{"className":6394},[3480],"sg-0a1b2c3d4e5f67890",[3435,6397],{"className":6398},[3438],[3435,6400,6402],{"className":6401},[3438],[3440,6403,6405],{"className":6404},[3443],"# Lab: дозволити 0.0.0.0\u002F0 (лише для тестування без ALB)",[3435,6407,6409,3445,6412],{"className":6408},[3438],[3440,6410,3444],{"className":6411},[3443],[3447,6413,6414],{},"aws ec2 authorize-security-group-ingress \\",[3435,6416,6418,3533,6421],{"className":6417},[3438],[3440,6419,3532],{"className":6420},[3443],[3447,6422,6423],{},"--group-id $SG_ID --protocol tcp --port 8080 \\",[3435,6425,6427,3533,6430],{"className":6426},[3438],[3440,6428,3532],{"className":6429},[3443],[3447,6431,6432],{},"--cidr 0.0.0.0\u002F0 --region eu-central-1",[3435,6434,6436],{"className":6435},[3438],[3440,6437,3543],{"className":6438},[3480],[3435,6440],{"className":6441},[3438],[3435,6443,6445],{"className":6444},[3438],[3440,6446,6448],{"className":6447},[3443],"# Production: дозволити лише з ALB Security Group",[3435,6450,6452,3445,6455],{"className":6451},[3438],[3440,6453,3444],{"className":6454},[3443],[3447,6456,6414],{},[3435,6458,6460,3533,6463],{"className":6459},[3438],[3440,6461,3532],{"className":6462},[3443],[3447,6464,6465],{},"--group-id $TASKS_SG_ID --protocol tcp --port 8080 \\",[3435,6467,6469,3533,6472],{"className":6468},[3438],[3440,6470,3532],{"className":6471},[3443],[3447,6473,6474],{},"--source-group $ALB_SG_ID --region eu-central-1",[3435,6476,6478],{"className":6477},[3438],[3440,6479,3543],{"className":6480},[3480],[3379,6482],{},[3387,6484,6486],{"id":6485},"ec2-describe-network-interfaces","ec2 describe-network-interfaces",[3348,6488,6489],{},"Знаходить публічний IP Task через ENI (Elastic Network Interface), прикріплений до Task.",[3431,6491,6493,6500,6509,6518,6527,6536,6539,6546,6555,6564,6573,6582],{"title":6492},"отримання публічного IP Fargate Task",[3435,6494,6496],{"className":6495},[3438],[3440,6497,6499],{"className":6498},[3443],"# 1. Знайти ENI, прикріплений до Task",[3435,6501,6503,3445,6506],{"className":6502},[3438],[3440,6504,3444],{"className":6505},[3443],[3447,6507,6508],{},"ENI_ID=$(aws ecs describe-tasks \\",[3435,6510,6512,3533,6515],{"className":6511},[3438],[3440,6513,3532],{"className":6514},[3443],[3447,6516,6517],{},"--cluster ecs-lab-cluster --tasks $TASK_ARN \\",[3435,6519,6521,3533,6524],{"className":6520},[3438],[3440,6522,3532],{"className":6523},[3443],[3447,6525,6526],{},"--query \"tasks[0].attachments[0].details[?name=='networkInterfaceId'].value\" \\",[3435,6528,6530,3533,6533],{"className":6529},[3438],[3440,6531,3532],{"className":6532},[3443],[3447,6534,6535],{},"--output text --region eu-central-1)",[3435,6537],{"className":6538},[3438],[3435,6540,6542],{"className":6541},[3438],[3440,6543,6545],{"className":6544},[3443],"# 2. Отримати публічний IP ENI",[3435,6547,6549,3445,6552],{"className":6548},[3438],[3440,6550,3444],{"className":6551},[3443],[3447,6553,6554],{},"aws ec2 describe-network-interfaces \\",[3435,6556,6558,3533,6561],{"className":6557},[3438],[3440,6559,3532],{"className":6560},[3443],[3447,6562,6563],{},"--network-interface-ids $ENI_ID \\",[3435,6565,6567,3533,6570],{"className":6566},[3438],[3440,6568,3532],{"className":6569},[3443],[3447,6571,6572],{},"--query \"NetworkInterfaces[0].Association.PublicIp\" \\",[3435,6574,6576,3533,6579],{"className":6575},[3438],[3440,6577,3532],{"className":6578},[3443],[3447,6580,6581],{},"--output text --region eu-central-1",[3435,6583,6585],{"className":6584},[3438],[3440,6586,6588],{"className":6587},[3480],"3.64.185.42",[3379,6590],{},[3382,6592,6594],{"id":6593},"elbv2-application-load-balancer","ELBv2 — Application Load Balancer",[3387,6596,6598],{"id":6597},"elbv2-create-load-balancer","elbv2 create-load-balancer",[3348,6600,6601],{},"Створює Application Load Balancer (Layer 7). Розміщується у публічних підмережах — він отримує зовнішній трафік і перенаправляє на Tasks.",[3398,6603,6604,6608,6612,6618,6631],{},[3401,6605,6607],{"name":6606,"type":3404,"required":3405},"--name","Ім'я ALB. Унікальне в межах акаунту та регіону. Максимум 32 символи.",[3401,6609,6611],{"name":6610,"type":3890,"required":3405},"--subnets","ID мінімум двох публічних підмереж у різних Availability Zones. ALB вимагає мінімум 2 AZ для відмовостійкості.",[3401,6613,6615,6616,3377],{"name":6614,"type":3890,"required":3405},"--security-groups","Security Group для ALB. Має дозволяти вхідний трафік 80\u002F443 з ",[3356,6617,6335],{},[3401,6619,6621,6624,6625,6628,6629,3377],{"name":6620,"type":3404},"--scheme",[3356,6622,6623],{},"internet-facing"," (публічний, є публічний DNS\u002FIP) або ",[3356,6626,6627],{},"internal"," (лише з VPC). Для зовнішнього API — ",[3356,6630,6623],{},[3401,6632,6634,6637,6638,6641],{"name":6633,"type":3404},"--type",[3356,6635,6636],{},"application"," (ALB, Layer 7, HTTP\u002FHTTPS) або ",[3356,6639,6640],{},"network"," (NLB, Layer 4, TCP\u002FUDP).",[3431,6643,6645,6654,6663,6672,6681,6690,6699,6706,6709,6718,6727],{"title":6644},"aws elbv2 create-load-balancer",[3435,6646,6648,3445,6651],{"className":6647},[3438],[3440,6649,3444],{"className":6650},[3443],[3447,6652,6653],{},"ALB_ARN=$(aws elbv2 create-load-balancer \\",[3435,6655,6657,3533,6660],{"className":6656},[3438],[3440,6658,3532],{"className":6659},[3443],[3447,6661,6662],{},"--name my-api-alb --subnets subnet-aaa subnet-bbb \\",[3435,6664,6666,3533,6669],{"className":6665},[3438],[3440,6667,3532],{"className":6668},[3443],[3447,6670,6671],{},"--security-groups sg-alb-id \\",[3435,6673,6675,3533,6678],{"className":6674},[3438],[3440,6676,3532],{"className":6677},[3443],[3447,6679,6680],{},"--scheme internet-facing --type application \\",[3435,6682,6684,3533,6687],{"className":6683},[3438],[3440,6685,3532],{"className":6686},[3443],[3447,6688,6689],{},"--query \"LoadBalancers[0].LoadBalancerArn\" --output text \\",[3435,6691,6693,3533,6696],{"className":6692},[3438],[3440,6694,3532],{"className":6695},[3443],[3447,6697,6698],{},"--region eu-central-1)",[3435,6700,6702],{"className":6701},[3438],[3440,6703,6705],{"className":6704},[3480],"arn:aws:elasticloadbalancing:eu-central-1:123456789012:loadbalancer\u002Fapp\u002Fmy-api-alb\u002F1a2b3c4d",[3435,6707],{"className":6708},[3438],[3435,6710,6712,3445,6715],{"className":6711},[3438],[3440,6713,3444],{"className":6714},[3443],[3447,6716,6717],{},"aws elbv2 describe-load-balancers --names my-api-alb --region eu-central-1 \\",[3435,6719,6721,3533,6724],{"className":6720},[3438],[3440,6722,3532],{"className":6723},[3443],[3447,6725,6726],{},"--query \"LoadBalancers[0].{State:State.Code,DNS:DNSName}\"",[3435,6728,6730,6731,6735],{"className":6729},[3438],"{ \"State\": ",[3440,6732,6734],{"className":6733},[3480],"\"active\"",", \"DNS\": \"my-api-alb-123456789.eu-central-1.elb.amazonaws.com\" }",[3379,6737],{},[3387,6739,6741],{"id":6740},"elbv2-create-target-group","elbv2 create-target-group",[3348,6743,6744,6745,3377],{},"Створює Target Group — набір IP-адрес (Tasks), на які ALB направляє трафік. Для Fargate завжди ",[3356,6746,6747],{},"--target-type ip",[3398,6749,6750,6753,6764,6767,6774],{},[3401,6751,6752],{"name":6606,"type":3404,"required":3405},"Ім'я Target Group.",[3401,6754,6756,6757,6760,6761,3377],{"name":6755,"type":3404},"--protocol \u002F --port","Протокол та порт для внутрішнього трафіку від ALB до Tasks. Для .NET: ",[3356,6758,6759],{},"HTTP"," та ",[3356,6762,6763],{},"8080",[3401,6765,6766],{"name":6327,"type":3404,"required":3405},"VPC, в якому знаходяться Tasks.",[3401,6768,6770,6773],{"name":6769,"type":3404,"required":3405},"--target-type",[3356,6771,6772],{},"ip"," — обов'язково для Fargate (awsvpc режим). Tasks реєструються за IP, а не за EC2 інстанс ID.",[3401,6775,6777,6778,6781],{"name":6776,"type":3404},"--health-check-path","URL шлях для health check. Для .NET — зазвичай ",[3356,6779,6780],{},"\u002Fhealth",". ALB перевіряє кожен Task перед реєстрацією та регулярно після.",[3431,6783,6785,6794,6803,6812,6821,6830,6839,6848,6857,6865],{"title":6784},"aws elbv2 create-target-group",[3435,6786,6788,3445,6791],{"className":6787},[3438],[3440,6789,3444],{"className":6790},[3443],[3447,6792,6793],{},"TG_ARN=$(aws elbv2 create-target-group \\",[3435,6795,6797,3533,6800],{"className":6796},[3438],[3440,6798,3532],{"className":6799},[3443],[3447,6801,6802],{},"--name my-api-tg --protocol HTTP --port 8080 \\",[3435,6804,6806,3533,6809],{"className":6805},[3438],[3440,6807,3532],{"className":6808},[3443],[3447,6810,6811],{},"--vpc-id vpc-0a1b2c3d4e5f --target-type ip \\",[3435,6813,6815,3533,6818],{"className":6814},[3438],[3440,6816,3532],{"className":6817},[3443],[3447,6819,6820],{},"--health-check-path \u002Fhealth \\",[3435,6822,6824,3533,6827],{"className":6823},[3438],[3440,6825,3532],{"className":6826},[3443],[3447,6828,6829],{},"--health-check-interval-seconds 30 \\",[3435,6831,6833,3533,6836],{"className":6832},[3438],[3440,6834,3532],{"className":6835},[3443],[3447,6837,6838],{},"--healthy-threshold-count 2 \\",[3435,6840,6842,3533,6845],{"className":6841},[3438],[3440,6843,3532],{"className":6844},[3443],[3447,6846,6847],{},"--unhealthy-threshold-count 3 \\",[3435,6849,6851,3533,6854],{"className":6850},[3438],[3440,6852,3532],{"className":6853},[3443],[3447,6855,6856],{},"--query \"TargetGroups[0].TargetGroupArn\" --output text \\",[3435,6858,6860,3533,6863],{"className":6859},[3438],[3440,6861,3532],{"className":6862},[3443],[3447,6864,6698],{},[3435,6866,6868],{"className":6867},[3438],[3440,6869,6871],{"className":6870},[3480],"arn:aws:elasticloadbalancing:eu-central-1:123456789012:targetgroup\u002Fmy-api-tg\u002Fabc123",[3379,6873],{},[3387,6875,6877],{"id":6876},"elbv2-create-listener-modify-listener","elbv2 create-listener \u002F modify-listener",[3348,6879,6880],{},"Створює Listener — правило, за яким ALB приймає трафік на певному порті і перенаправляє на Target Group.",[3398,6882,6883,6898,6905],{},[3401,6884,6885,6887,6888,4188,6891,6887,6894,6897],{"name":6755,"type":3404,"required":3405},[3356,6886,6759],{}," \u002F ",[3356,6889,6890],{},"80",[3356,6892,6893],{},"HTTPS",[3356,6895,6896],{},"443",". Для HTTPS потрібен ACM сертифікат.",[3401,6899,6901,6902,3377],{"name":6900,"type":3890},"--certificates","ARN ACM сертифікату для HTTPS Listener: ",[3356,6903,6904],{},"CertificateArn=arn:aws:acm:...",[3401,6906,6908,6909,6912,6913,6916],{"name":6907,"type":3890,"required":3405},"--default-actions","Дія за замовчуванням: ",[3356,6910,6911],{},"Type=forward,TargetGroupArn=..."," (направити на TG) або ",[3356,6914,6915],{},"Type=redirect,RedirectConfig={...}"," (редирект).",[3431,6918,6920,6927,6936,6945,6954,6962,6971,6974,6981,6989,6998,7007,7015,7023,7031,7034,7041,7050,7059,7068,7077,7086,7095,7103],{"title":6919},"create HTTP listener + HTTPS listener + HTTP→HTTPS redirect",[3435,6921,6923],{"className":6922},[3438],[3440,6924,6926],{"className":6925},[3443],"# HTTP Listener (порт 80 → Target Group)",[3435,6928,6930,3445,6933],{"className":6929},[3438],[3440,6931,3444],{"className":6932},[3443],[3447,6934,6935],{},"aws elbv2 create-listener \\",[3435,6937,6939,3533,6942],{"className":6938},[3438],[3440,6940,3532],{"className":6941},[3443],[3447,6943,6944],{},"--load-balancer-arn $ALB_ARN --protocol HTTP --port 80 \\",[3435,6946,6948,3533,6951],{"className":6947},[3438],[3440,6949,3532],{"className":6950},[3443],[3447,6952,6953],{},"--default-actions Type=forward,TargetGroupArn=$TG_ARN \\",[3435,6955,6957,3533,6960],{"className":6956},[3438],[3440,6958,3532],{"className":6959},[3443],[3447,6961,4130],{},[3435,6963,6965,6966,6970],{"className":6964},[3438],"{ \"Listeners\": [{ \"ListenerArn\": \"arn:...\", ",[3440,6967,6969],{"className":6968},[3480],"\"Port\": 80, \"Protocol\": \"HTTP\""," }] }",[3435,6972],{"className":6973},[3438],[3435,6975,6977],{"className":6976},[3438],[3440,6978,6980],{"className":6979},[3443],"# HTTPS Listener (порт 443 → Target Group через ACM)",[3435,6982,6984,3445,6987],{"className":6983},[3438],[3440,6985,3444],{"className":6986},[3443],[3447,6988,6935],{},[3435,6990,6992,3533,6995],{"className":6991},[3438],[3440,6993,3532],{"className":6994},[3443],[3447,6996,6997],{},"--load-balancer-arn $ALB_ARN --protocol HTTPS --port 443 \\",[3435,6999,7001,3533,7004],{"className":7000},[3438],[3440,7002,3532],{"className":7003},[3443],[3447,7005,7006],{},"--certificates CertificateArn=$CERT_ARN \\",[3435,7008,7010,3533,7013],{"className":7009},[3438],[3440,7011,3532],{"className":7012},[3443],[3447,7014,6953],{},[3435,7016,7018,3533,7021],{"className":7017},[3438],[3440,7019,3532],{"className":7020},[3443],[3447,7022,4130],{},[3435,7024,7026,7027,6970],{"className":7025},[3438],"{ \"Listeners\": [{ ",[3440,7028,7030],{"className":7029},[3480],"\"Port\": 443, \"Protocol\": \"HTTPS\"",[3435,7032],{"className":7033},[3438],[3435,7035,7037],{"className":7036},[3438],[3440,7038,7040],{"className":7039},[3443],"# Змінити HTTP Listener на redirect → HTTPS",[3435,7042,7044,3445,7047],{"className":7043},[3438],[3440,7045,3444],{"className":7046},[3443],[3447,7048,7049],{},"HTTP_LISTENER=$(aws elbv2 describe-listeners \\",[3435,7051,7053,3533,7056],{"className":7052},[3438],[3440,7054,3532],{"className":7055},[3443],[3447,7057,7058],{},"--load-balancer-arn $ALB_ARN \\",[3435,7060,7062,3533,7065],{"className":7061},[3438],[3440,7063,3532],{"className":7064},[3443],[3447,7066,7067],{},"--query \"Listeners[?Port==\\`80\\`].ListenerArn\" --output text --region eu-central-1)",[3435,7069,7071,3445,7074],{"className":7070},[3438],[3440,7072,3444],{"className":7073},[3443],[3447,7075,7076],{},"aws elbv2 modify-listener \\",[3435,7078,7080,3533,7083],{"className":7079},[3438],[3440,7081,3532],{"className":7082},[3443],[3447,7084,7085],{},"--listener-arn $HTTP_LISTENER \\",[3435,7087,7089,3533,7092],{"className":7088},[3438],[3440,7090,3532],{"className":7091},[3443],[3447,7093,7094],{},"--default-actions 'Type=redirect,RedirectConfig={Protocol=HTTPS,Port=443,StatusCode=HTTP_301}' \\",[3435,7096,7098,3533,7101],{"className":7097},[3438],[3440,7099,3532],{"className":7100},[3443],[3447,7102,4130],{},[3435,7104,7026,7106,7110],{"className":7105},[3438],[3440,7107,7109],{"className":7108},[3480],"\"Protocol\": \"HTTP\", \"Port\": 80",", \"DefaultActions\": [{\"Type\": \"redirect\"}] }] }",[3379,7112],{},[3382,7114,7116],{"id":7115},"application-auto-scaling-ecs","Application Auto Scaling — ECS",[3387,7118,7120],{"id":7119},"application-autoscaling-register-scalable-target","application-autoscaling register-scalable-target",[3348,7122,7123],{},"Реєструє ECS Service як масштабований ресурс. Цей крок — передумова перед додаванням Scaling Policy.",[3398,7125,7126,7133,7140,7147,7155],{},[3401,7127,7129,7130,3377],{"name":7128,"type":3404,"required":3405},"--service-namespace","Простір імен сервісу. Для ECS завжди ",[3356,7131,7132],{},"ecs",[3401,7134,7136,7137,3377],{"name":7135,"type":3404,"required":3405},"--scalable-dimension","Розмір, що масштабується. Для ECS Service: ",[3356,7138,7139],{},"ecs:service:DesiredCount",[3401,7141,7143,7144,3377],{"name":7142,"type":3404,"required":3405},"--resource-id","Ідентифікатор ресурсу у форматі ",[3356,7145,7146],{},"service\u002F\u003Ccluster-name>\u002F\u003Cservice-name>",[3401,7148,7150,7151,7154],{"name":7149,"type":5207,"required":3405},"--min-capacity","Мінімальна кількість Tasks. Рекомендується ",[3356,7152,7153],{},"2"," для production: захищає від повного простою.",[3401,7156,7158],{"name":7157,"type":5207,"required":3405},"--max-capacity","Максимальна кількість Tasks. Захищає від неконтрольованих витрат.",[3431,7160,7162,7171,7180,7189,7198,7207,7215],{"title":7161},"aws application-autoscaling register-scalable-target",[3435,7163,7165,3445,7168],{"className":7164},[3438],[3440,7166,3444],{"className":7167},[3443],[3447,7169,7170],{},"aws application-autoscaling register-scalable-target \\",[3435,7172,7174,3533,7177],{"className":7173},[3438],[3440,7175,3532],{"className":7176},[3443],[3447,7178,7179],{},"--service-namespace ecs \\",[3435,7181,7183,3533,7186],{"className":7182},[3438],[3440,7184,3532],{"className":7185},[3443],[3447,7187,7188],{},"--scalable-dimension ecs:service:DesiredCount \\",[3435,7190,7192,3533,7195],{"className":7191},[3438],[3440,7193,3532],{"className":7194},[3443],[3447,7196,7197],{},"--resource-id service\u002Fproduction\u002Fmy-api \\",[3435,7199,7201,3533,7204],{"className":7200},[3438],[3440,7202,3532],{"className":7203},[3443],[3447,7205,7206],{},"--min-capacity 2 --max-capacity 20 \\",[3435,7208,7210,3533,7213],{"className":7209},[3438],[3440,7211,3532],{"className":7212},[3443],[3447,7214,4130],{},[3435,7216,7218],{"className":7217},[3438],[3440,7219,3543],{"className":7220},[3480],[3379,7222],{},[3387,7224,7226],{"id":7225},"application-autoscaling-put-scaling-policy","application-autoscaling put-scaling-policy",[3348,7228,7229],{},"Застосовує Scaling Policy до зареєстрованого ресурсу.",[3398,7231,7232,7236,7250],{},[3401,7233,7235],{"name":7234,"type":3404,"required":3405},"--policy-name","Ім'я Policy, унікальне для ресурсу.",[3401,7237,7239,7242,7243,7246,7247,3377],{"name":7238,"type":3404,"required":3405},"--policy-type",[3356,7240,7241],{},"TargetTrackingScaling"," (підтримує ціль метрики), ",[3356,7244,7245],{},"StepScaling"," (кроки при перевищенні порогу) або ",[3356,7248,7249],{},"SimpleScaling",[3401,7251,7254,7255,3725,7257,7260,7261,4188,7264,3363,7267,3363,7270,3377],{"name":7252,"type":7253},"--target-tracking-scaling-policy-configuration","json-object","Конфігурація для ",[3356,7256,7241],{},[3356,7258,7259],{},"TargetValue"," (ціль), ",[3356,7262,7263],{},"PredefinedMetricSpecification",[3356,7265,7266],{},"CustomizedMetricSpecification",[3356,7268,7269],{},"ScaleInCooldown",[3356,7271,7272],{},"ScaleOutCooldown",[3431,7274,7276,7285,7293,7301,7309,7318,7327,7336,7345,7354,7364,7373,7382,7391,7400,7408,7411,7418],{"title":7275},"aws application-autoscaling put-scaling-policy — CPU Target Tracking",[3435,7277,7279,3445,7282],{"className":7278},[3438],[3440,7280,3444],{"className":7281},[3443],[3447,7283,7284],{},"aws application-autoscaling put-scaling-policy \\",[3435,7286,7288,3533,7291],{"className":7287},[3438],[3440,7289,3532],{"className":7290},[3443],[3447,7292,7179],{},[3435,7294,7296,3533,7299],{"className":7295},[3438],[3440,7297,3532],{"className":7298},[3443],[3447,7300,7188],{},[3435,7302,7304,3533,7307],{"className":7303},[3438],[3440,7305,3532],{"className":7306},[3443],[3447,7308,7197],{},[3435,7310,7312,3533,7315],{"className":7311},[3438],[3440,7313,3532],{"className":7314},[3443],[3447,7316,7317],{},"--policy-name cpu-target-70 \\",[3435,7319,7321,3533,7324],{"className":7320},[3438],[3440,7322,3532],{"className":7323},[3443],[3447,7325,7326],{},"--policy-type TargetTrackingScaling \\",[3435,7328,7330,3533,7333],{"className":7329},[3438],[3440,7331,3532],{"className":7332},[3443],[3447,7334,7335],{},"--target-tracking-scaling-policy-configuration '{",[3435,7337,7339,5888,7342],{"className":7338},[3438],[3440,7340,3532],{"className":7341},[3443],[3447,7343,7344],{},"\"TargetValue\": 70.0,",[3435,7346,7348,5888,7351],{"className":7347},[3438],[3440,7349,3532],{"className":7350},[3443],[3447,7352,7353],{},"\"PredefinedMetricSpecification\": {",[3435,7355,7357,7360,7361],{"className":7356},[3438],[3440,7358,3532],{"className":7359},[3443],"             ",[3447,7362,7363],{},"\"PredefinedMetricType\": \"ECSServiceAverageCPUUtilization\"",[3435,7365,7367,5888,7370],{"className":7366},[3438],[3440,7368,3532],{"className":7369},[3443],[3447,7371,7372],{},"},",[3435,7374,7376,5888,7379],{"className":7375},[3438],[3440,7377,3532],{"className":7378},[3443],[3447,7380,7381],{},"\"ScaleInCooldown\": 300,",[3435,7383,7385,5888,7388],{"className":7384},[3438],[3440,7386,3532],{"className":7387},[3443],[3447,7389,7390],{},"\"ScaleOutCooldown\": 60",[3435,7392,7394,3533,7397],{"className":7393},[3438],[3440,7395,3532],{"className":7396},[3443],[3447,7398,7399],{},"}' \\",[3435,7401,7403,3533,7406],{"className":7402},[3438],[3440,7404,3532],{"className":7405},[3443],[3447,7407,4130],{},[3435,7409,3818],{"className":7410},[3438],[3435,7412,4145,7414],{"className":7413},[3438],[3440,7415,7417],{"className":7416},[3480],"\"PolicyARN\": \"arn:aws:autoscaling:eu-central-1:123456789012:scalingPolicy:abc:resource\u002Fecs\u002Fservice\u002Fproduction\u002Fmy-api:policyName\u002Fcpu-target-70\"",[3435,7419,3859],{"className":7420},[3438],[3379,7422],{},[3382,7424,7426],{"id":7425},"cloudwatch-logs","CloudWatch Logs",[3387,7428,7430],{"id":7429},"logs-tail","logs tail",[3348,7432,7433,7434,7437],{},"Виводить та в режимі ",[3356,7435,7436],{},"--follow"," потокує нові записи з CloudWatch Log Group. Основний спосіб переглядати логи ECS контейнерів у реальному часі.",[3398,7439,7440,7447,7453,7472],{},[3401,7441,7443,7444,3377],{"name":7442,"type":3404,"required":3405},"LOG_GROUP_NAME","Ім'я Log Group. Для ECS — стандартно ",[3356,7445,7446],{},"\u002Fecs\u002F\u003Ctask-definition-family>",[3401,7448,7449,7450,3377],{"name":7436,"type":3428},"Продовжувати виводити нові записи (live tail). Аналог ",[3356,7451,7452],{},"tail -f",[3401,7454,7456,7457,7460,7461,7464,7465,7468,7469,7471],{"name":7455,"type":3404},"--format","Формат виводу: ",[3356,7458,7459],{},"short"," (мітка часу + повідомлення), ",[3356,7462,7463],{},"detailed"," (всі метадані), ",[3356,7466,7467],{},"json",". ",[3356,7470,7459],{}," — найзручніший для читання.",[3401,7473,7475,7476,3363,7479,3363,7482,7485],{"name":7474,"type":3404},"--since","Почати з певного моменту: ",[3356,7477,7478],{},"1h",[3356,7480,7481],{},"30m",[3356,7483,7484],{},"2024-01-15T10:00:00",". Без цього параметра — виводить останні записи.",[3431,7487,7489,7498,7506,7513,7525,7533,7540,7547],{"title":7488},"aws logs tail — логи .NET API з ECS",[3435,7490,7492,3445,7495],{"className":7491},[3438],[3440,7493,3444],{"className":7494},[3443],[3447,7496,7497],{},"aws logs tail \u002Fecs\u002Fecs-lab-api --follow --format short --region eu-central-1",[3435,7499,7501,7505],{"className":7500},[3438],[3440,7502,7504],{"className":7503},[3443],"2024-01-15T10:23:45"," ecs\u002Fecs-lab-api\u002Fabc123  info: Microsoft.Hosting.Lifetime[14]",[3435,7507,7509,7512],{"className":7508},[3438],[3440,7510,7504],{"className":7511},[3443]," ecs\u002Fecs-lab-api\u002Fabc123      Now listening on: http:\u002F\u002F[::]:8080",[3435,7514,7516,7520,7521],{"className":7515},[3438],[3440,7517,7519],{"className":7518},[3443],"2024-01-15T10:23:46"," ecs\u002Fecs-lab-api\u002Fabc123  ",[3440,7522,7524],{"className":7523},[3480],"info: Microsoft.Hosting.Lifetime[0] Application started.",[3435,7526,7528,7532],{"className":7527},[3438],[3440,7529,7531],{"className":7530},[3443],"2024-01-15T10:24:01"," ecs\u002Fecs-lab-api\u002Fabc123  info: Microsoft.AspNetCore.Hosting.Diagnostics[1]",[3435,7534,7536,7539],{"className":7535},[3438],[3440,7537,7531],{"className":7538},[3443]," ecs\u002Fecs-lab-api\u002Fabc123      Request starting HTTP\u002F1.1 GET http:\u002F\u002F10.0.1.47:8080\u002Fhealth - -",[3435,7541,7543,7546],{"className":7542},[3438],[3440,7544,7531],{"className":7545},[3443]," ecs\u002Fecs-lab-api\u002Fabc123  info: Microsoft.AspNetCore.Hosting.Diagnostics[2]",[3435,7548,7550,7553],{"className":7549},[3438],[3440,7551,7531],{"className":7552},[3443]," ecs\u002Fecs-lab-api\u002Fabc123      Request finished HTTP\u002F1.1 GET \u002Fhealth - 200 - text\u002Fplain 1.2ms",[3565,7555,7556,7557,7560,7561,7564,7565,7568,7569,7572],{},"Кожен Task пише логи в окремий ",[3447,7558,7559],{},"Log Stream"," з іменем ",[3356,7562,7563],{},"ecs\u002F\u003Cfamily>\u002F\u003Ctask-id>",". При рестарті Task — новий стрім. Лог Group (",[3356,7566,7567],{},"\u002Fecs\u002Fecs-lab-api",") залишається; ",[3356,7570,7571],{},"aws logs tail"," агрегує всі стріми.",[3379,7574],{},[3387,7576,7578],{"id":7577},"logs-delete-log-group","logs delete-log-group",[3348,7580,7581],{},"Видаляє Log Group та всі її Log Streams.",[3694,7583,7584],{},"Видалення Log Group є незворотним. Усі збережені логи будуть втрачені. Виконуйте цю команду лише після завершення роботи з лабораторним середовищем.",[3431,7586,7588,7597,7606,7614],{"title":7587},"aws logs delete-log-group",[3435,7589,7591,3445,7594],{"className":7590},[3438],[3440,7592,3444],{"className":7593},[3443],[3447,7595,7596],{},"aws logs delete-log-group \\",[3435,7598,7600,3533,7603],{"className":7599},[3438],[3440,7601,3532],{"className":7602},[3443],[3447,7604,7605],{},"--log-group-name \u002Fecs\u002Fecs-lab-api \\",[3435,7607,7609,3533,7612],{"className":7608},[3438],[3440,7610,3532],{"className":7611},[3443],[3447,7613,4130],{},[3435,7615,7617],{"className":7616},[3438],[3440,7618,3543],{"className":7619},[3480],[3379,7621],{},[3382,7623,7625],{"id":7624},"acm-aws-certificate-manager","ACM — AWS Certificate Manager",[3387,7627,7629],{"id":7628},"acm-request-certificate","acm request-certificate",[3348,7631,7632,7633,7636],{},"Запитує безкоштовний SSL\u002FTLS сертифікат. Для ALB у регіоні ",[3356,7634,7635],{},"eu-central-1"," — сертифікат має бути в тому самому регіоні.",[3398,7638,7639,7647,7658],{},[3401,7640,7642,7643,7646],{"name":7641,"type":3404,"required":3405},"--domain-name","Основний домен сертифікату: ",[3356,7644,7645],{},"myapp.pp.ua",". Сертифікат буде видано саме для цього домену.",[3401,7648,7650,7653,7654,7657],{"name":7649,"type":3404,"required":3405},"--validation-method",[3356,7651,7652],{},"DNS"," (рекомендовано) — потрібно додати CNAME у DNS; автоматично оновлюється при продовженні. ",[3356,7655,7656],{},"EMAIL"," — лист на адміністративний email домену.",[3401,7659,7661,7662,3363,7665,7668],{"name":7660,"type":3890},"--subject-alternative-names","Додаткові домени в одному сертифікаті: ",[3356,7663,7664],{},"*.myapp.pp.ua",[3356,7666,7667],{},"api.myapp.pp.ua"," тощо.",[3431,7670,7672,7681,7690,7699,7707,7716,7723,7726,7733,7742,7751,7760,7763,7767,7771,7778],{"title":7671},"acm request-certificate + describe DNS validation record",[3435,7673,7675,3445,7678],{"className":7674},[3438],[3440,7676,3444],{"className":7677},[3443],[3447,7679,7680],{},"CERT_ARN=$(aws acm request-certificate \\",[3435,7682,7684,3533,7687],{"className":7683},[3438],[3440,7685,3532],{"className":7686},[3443],[3447,7688,7689],{},"--domain-name \"myecs.pp.ua\" \\",[3435,7691,7693,3533,7696],{"className":7692},[3438],[3440,7694,3532],{"className":7695},[3443],[3447,7697,7698],{},"--validation-method DNS \\",[3435,7700,7702,3533,7705],{"className":7701},[3438],[3440,7703,3532],{"className":7704},[3443],[3447,7706,3796],{},[3435,7708,7710,3533,7713],{"className":7709},[3438],[3440,7711,3532],{"className":7712},[3443],[3447,7714,7715],{},"--query CertificateArn --output text)",[3435,7717,7719],{"className":7718},[3438],[3440,7720,7722],{"className":7721},[3480],"arn:aws:acm:eu-central-1:123456789012:certificate\u002Fabc123-def456",[3435,7724],{"className":7725},[3438],[3435,7727,7729],{"className":7728},[3438],[3440,7730,7732],{"className":7731},[3443],"# Отримати CNAME запис для DNS валідації",[3435,7734,7736,3445,7739],{"className":7735},[3438],[3440,7737,3444],{"className":7738},[3443],[3447,7740,7741],{},"aws acm describe-certificate \\",[3435,7743,7745,3533,7748],{"className":7744},[3438],[3440,7746,3532],{"className":7747},[3443],[3447,7749,7750],{},"--certificate-arn $CERT_ARN --region eu-central-1 \\",[3435,7752,7754,3533,7757],{"className":7753},[3438],[3440,7755,3532],{"className":7756},[3443],[3447,7758,7759],{},"--query \"Certificate.DomainValidationOptions[0].ResourceRecord\"",[3435,7761,3818],{"className":7762},[3438],[3435,7764,7766],{"className":7765},[3438],"    \"Name\": \"_abc123.myecs.pp.ua.\",",[3435,7768,7770],{"className":7769},[3438],"    \"Type\": \"CNAME\",",[3435,7772,4145,7774],{"className":7773},[3438],[3440,7775,7777],{"className":7776},[3480],"\"Value\": \"_def456.acm-validations.aws.\"",[3435,7779,3859],{"className":7780},[3438],[3565,7782,7783,7784,7787,7788,7791,7792,3377],{},"Додайте цей CNAME запис у DNS-панель вашого домену (pp.ua → DNS Management). Після підтвердження сертифікат перейде у статус ",[3356,7785,7786],{},"ISSUED"," (~5–10 хвилин). Далі використовуйте ",[3356,7789,7790],{},"$CERT_ARN"," при створенні HTTPS Listener у ",[3356,7793,7794],{},"elbv2 create-listener",[3379,7796],{},[3382,7798,7800],{"id":7799},"eventbridge-scheduler","EventBridge Scheduler",[3387,7802,7804],{"id":7803},"scheduler-create-schedule","scheduler create-schedule",[3348,7806,7807],{},"Створює розклад для запуску ECS Task за cron-виразом через Amazon EventBridge Scheduler.",[3398,7809,7810,7813,7825,7836],{},[3401,7811,7812],{"name":6606,"type":3404,"required":3405},"Ім'я розкладу. Унікальне в межах групи розкладів.",[3401,7814,7816,7817,7820,7821,7824],{"name":7815,"type":3404,"required":3405},"--schedule-expression","Cron або rate вираз: ",[3356,7818,7819],{},"cron(0 2 * * ? *)"," (щодня о 02:00 UTC) або ",[3356,7822,7823],{},"rate(1 hour)",". Зверніть увагу: AWS cron має 6 полів (є поле рік).",[3401,7826,7828,7831,7832,7835],{"name":7827,"type":3735,"required":3405},"--flexible-time-window",[3356,7829,7830],{},"{\"Mode\": \"OFF\"}"," — точний запуск у вказаний час. ",[3356,7833,7834],{},"{\"Mode\": \"FLEXIBLE\", \"MaximumWindowInMinutes\": 15}"," — запуск у вікні до 15 хв після вказаного часу.",[3401,7837,7839,7840,7843],{"name":7838,"type":7253,"required":3405},"--target","Опис цілі: ARN ECS кластера, IAM Role для запуску, ",[3356,7841,7842],{},"EcsParameters"," з Task Definition ARN, мережевою конфігурацією.",[3431,7845,7847,7856,7865,7874,7883,7892,7901,7910,7919,7928,7937,7946,7956,7964,7972,7980,7983,7990],{"title":7846},"aws scheduler create-schedule — щоденна задача о 02:00 UTC",[3435,7848,7850,3445,7853],{"className":7849},[3438],[3440,7851,3444],{"className":7852},[3443],[3447,7854,7855],{},"aws scheduler create-schedule \\",[3435,7857,7859,3533,7862],{"className":7858},[3438],[3440,7860,3532],{"className":7861},[3443],[3447,7863,7864],{},"--name \"daily-cleanup\" \\",[3435,7866,7868,3533,7871],{"className":7867},[3438],[3440,7869,3532],{"className":7870},[3443],[3447,7872,7873],{},"--schedule-expression \"cron(0 2 * * ? *)\" \\",[3435,7875,7877,3533,7880],{"className":7876},[3438],[3440,7878,3532],{"className":7879},[3443],[3447,7881,7882],{},"--flexible-time-window '{\"Mode\": \"OFF\"}' \\",[3435,7884,7886,3533,7889],{"className":7885},[3438],[3440,7887,3532],{"className":7888},[3443],[3447,7890,7891],{},"--target '{",[3435,7893,7895,5888,7898],{"className":7894},[3438],[3440,7896,3532],{"className":7897},[3443],[3447,7899,7900],{},"\"Arn\": \"arn:aws:ecs:eu-central-1:123456789012:cluster\u002Fmy-cluster\",",[3435,7902,7904,5888,7907],{"className":7903},[3438],[3440,7905,3532],{"className":7906},[3443],[3447,7908,7909],{},"\"RoleArn\": \"arn:aws:iam::123456789012:role\u002FEventBridgeECSRole\",",[3435,7911,7913,5888,7916],{"className":7912},[3438],[3440,7914,3532],{"className":7915},[3443],[3447,7917,7918],{},"\"EcsParameters\": {",[3435,7920,7922,7360,7925],{"className":7921},[3438],[3440,7923,3532],{"className":7924},[3443],[3447,7926,7927],{},"\"TaskDefinitionArn\": \"arn:aws:ecs:...:task-definition\u002Fcleanup-task:1\",",[3435,7929,7931,7360,7934],{"className":7930},[3438],[3440,7932,3532],{"className":7933},[3443],[3447,7935,7936],{},"\"LaunchType\": \"FARGATE\",",[3435,7938,7940,7360,7943],{"className":7939},[3438],[3440,7941,3532],{"className":7942},[3443],[3447,7944,7945],{},"\"NetworkConfiguration\": {\"AwsvpcConfiguration\":",[3435,7947,7949,7952,7953],{"className":7948},[3438],[3440,7950,3532],{"className":7951},[3443],"                 ",[3447,7954,7955],{},"{\"Subnets\":[\"subnet-xxx\"],\"SecurityGroups\":[\"sg-xxx\"],\"AssignPublicIp\":\"DISABLED\"}}",[3435,7957,7959,5888,7962],{"className":7958},[3438],[3440,7960,3532],{"className":7961},[3443],[3447,7963,3859],{},[3435,7965,7967,3533,7970],{"className":7966},[3438],[3440,7968,3532],{"className":7969},[3443],[3447,7971,7399],{},[3435,7973,7975,3533,7978],{"className":7974},[3438],[3440,7976,3532],{"className":7977},[3443],[3447,7979,4130],{},[3435,7981,3818],{"className":7982},[3438],[3435,7984,4145,7986],{"className":7985},[3438],[3440,7987,7989],{"className":7988},[3480],"\"ScheduleArn\": \"arn:aws:scheduler:eu-central-1:123456789012:schedule\u002Fdefault\u002Fdaily-cleanup\"",[3435,7991,3859],{"className":7992},[3438],[3379,7994],{},[3382,7996,7998],{"id":7997},"швидкий-довідник-типові-сценарії","Швидкий довідник: типові сценарії",[3387,8000,8002],{"id":8001},"повний-цикл-деплою-нової-версії","Повний цикл деплою нової версії",[8004,8005,8010],"pre",{"className":8006,"code":8007,"language":8008,"meta":8009,"style":8009},"language-bash shiki shiki-themes light-plus dark-plus dark-plus","# 1. Аутентифікація в ECR\naws ecr get-login-password --region eu-central-1 | \\\n    docker login --username AWS --password-stdin \\\n    $ACCOUNT_ID.dkr.ecr.eu-central-1.amazonaws.com\n\n# 2. Збірка та push\ndocker build -t my-api:v1.1.0 .\ndocker tag my-api:v1.1.0 $REPO_URI:v1.1.0\ndocker push $REPO_URI:v1.1.0\n\n# 3. Нова revision Task Definition (з новим образом)\naws ecs register-task-definition --cli-input-json file:\u002F\u002F\u002Ftmp\u002Ftask-def-v1.1.0.json --region eu-central-1\n\n# 4. Rolling update Service\naws ecs update-service \\\n    --cluster production --service my-api-service \\\n    --task-definition my-api \\\n    --region eu-central-1\n","bash","",[3356,8011,8012,8019,8048,8069,8079,8086,8092,8110,8126,8138,8143,8149,8171,8176,8182,8194,8211,8222],{"__ignoreMap":8009},[3440,8013,8015],{"class":3438,"line":8014},1,[3440,8016,8018],{"class":8017},"spJ8K","# 1. Аутентифікація в ECR\n",[3440,8020,8022,8026,8030,8033,8037,8040,8044],{"class":3438,"line":8021},2,[3440,8023,8025],{"class":8024},"s8Opu","aws",[3440,8027,8029],{"class":8028},"sbdoH"," ecr",[3440,8031,8032],{"class":8028}," get-login-password",[3440,8034,8036],{"class":8035},"su1O8"," --region",[3440,8038,8039],{"class":8028}," eu-central-1",[3440,8041,8043],{"class":8042},"sHH4Y"," | ",[3440,8045,8047],{"class":8046},"sjcCO","\\\n",[3440,8049,8051,8054,8057,8060,8063,8066],{"class":3438,"line":8050},3,[3440,8052,8053],{"class":8024},"    docker",[3440,8055,8056],{"class":8028}," login",[3440,8058,8059],{"class":8035}," --username",[3440,8061,8062],{"class":8028}," AWS",[3440,8064,8065],{"class":8035}," --password-stdin",[3440,8067,8068],{"class":8046}," \\\n",[3440,8070,8072,8076],{"class":3438,"line":8071},4,[3440,8073,8075],{"class":8074},"siwwj","    $ACCOUNT_ID",[3440,8077,8078],{"class":8028},".dkr.ecr.eu-central-1.amazonaws.com\n",[3440,8080,8082],{"class":3438,"line":8081},5,[3440,8083,8085],{"emptyLinePlaceholder":8084},true,"\n",[3440,8087,8089],{"class":3438,"line":8088},6,[3440,8090,8091],{"class":8017},"# 2. Збірка та push\n",[3440,8093,8095,8098,8101,8104,8107],{"class":3438,"line":8094},7,[3440,8096,8097],{"class":8024},"docker",[3440,8099,8100],{"class":8028}," build",[3440,8102,8103],{"class":8035}," -t",[3440,8105,8106],{"class":8028}," my-api:v1.1.0",[3440,8108,8109],{"class":8028}," .\n",[3440,8111,8113,8115,8118,8120,8123],{"class":3438,"line":8112},8,[3440,8114,8097],{"class":8024},[3440,8116,8117],{"class":8028}," tag",[3440,8119,8106],{"class":8028},[3440,8121,8122],{"class":8074}," $REPO_URI",[3440,8124,8125],{"class":8028},":v1.1.0\n",[3440,8127,8129,8131,8134,8136],{"class":3438,"line":8128},9,[3440,8130,8097],{"class":8024},[3440,8132,8133],{"class":8028}," push",[3440,8135,8122],{"class":8074},[3440,8137,8125],{"class":8028},[3440,8139,8141],{"class":3438,"line":8140},10,[3440,8142,8085],{"emptyLinePlaceholder":8084},[3440,8144,8146],{"class":3438,"line":8145},11,[3440,8147,8148],{"class":8017},"# 3. Нова revision Task Definition (з новим образом)\n",[3440,8150,8152,8154,8157,8160,8163,8166,8168],{"class":3438,"line":8151},12,[3440,8153,8025],{"class":8024},[3440,8155,8156],{"class":8028}," ecs",[3440,8158,8159],{"class":8028}," register-task-definition",[3440,8161,8162],{"class":8035}," --cli-input-json",[3440,8164,8165],{"class":8028}," file:\u002F\u002F\u002Ftmp\u002Ftask-def-v1.1.0.json",[3440,8167,8036],{"class":8035},[3440,8169,8170],{"class":8028}," eu-central-1\n",[3440,8172,8174],{"class":3438,"line":8173},13,[3440,8175,8085],{"emptyLinePlaceholder":8084},[3440,8177,8179],{"class":3438,"line":8178},14,[3440,8180,8181],{"class":8017},"# 4. Rolling update Service\n",[3440,8183,8185,8187,8189,8192],{"class":3438,"line":8184},15,[3440,8186,8025],{"class":8024},[3440,8188,8156],{"class":8028},[3440,8190,8191],{"class":8028}," update-service",[3440,8193,8068],{"class":8046},[3440,8195,8197,8200,8203,8206,8209],{"class":3438,"line":8196},16,[3440,8198,8199],{"class":8035},"    --cluster",[3440,8201,8202],{"class":8028}," production",[3440,8204,8205],{"class":8035}," --service",[3440,8207,8208],{"class":8028}," my-api-service",[3440,8210,8068],{"class":8046},[3440,8212,8214,8217,8220],{"class":3438,"line":8213},17,[3440,8215,8216],{"class":8035},"    --task-definition",[3440,8218,8219],{"class":8028}," my-api",[3440,8221,8068],{"class":8046},[3440,8223,8225,8228],{"class":3438,"line":8224},18,[3440,8226,8227],{"class":8035},"    --region",[3440,8229,8170],{"class":8028},[3387,8231,8233],{"id":8232},"діагностика-проблем-із-task","Діагностика проблем із Task",[8004,8235,8237],{"className":8006,"code":8236,"language":8008,"meta":8009,"style":8009},"# Task застряг у PENDING — перевірити причину\naws ecs describe-tasks \\\n    --cluster my-cluster --tasks $TASK_ARN \\\n    --query \"tasks[0].{status:lastStatus,stopped:stoppedReason,containers:containers[*].{name:name,reason:reason}}\" \\\n    --region eu-central-1\n\n# Переглянути логи контейнера\naws logs tail \u002Fecs\u002Fmy-api --since 30m --format short --region eu-central-1\n\n# Підключитись до контейнера напряму (якщо увімкнено ECS Exec)\naws ecs execute-command --cluster my-cluster --task $TASK_ARN \\\n    --container my-api --interactive --command \"\u002Fbin\u002Fbash\" --region eu-central-1\n",[3356,8238,8239,8244,8255,8270,8280,8286,8290,8295,8324,8328,8333,8354],{"__ignoreMap":8009},[3440,8240,8241],{"class":3438,"line":8014},[3440,8242,8243],{"class":8017},"# Task застряг у PENDING — перевірити причину\n",[3440,8245,8246,8248,8250,8253],{"class":3438,"line":8021},[3440,8247,8025],{"class":8024},[3440,8249,8156],{"class":8028},[3440,8251,8252],{"class":8028}," describe-tasks",[3440,8254,8068],{"class":8046},[3440,8256,8257,8259,8262,8265,8268],{"class":3438,"line":8050},[3440,8258,8199],{"class":8035},[3440,8260,8261],{"class":8028}," my-cluster",[3440,8263,8264],{"class":8035}," --tasks",[3440,8266,8267],{"class":8074}," $TASK_ARN",[3440,8269,8068],{"class":8046},[3440,8271,8272,8275,8278],{"class":3438,"line":8071},[3440,8273,8274],{"class":8035},"    --query",[3440,8276,8277],{"class":8028}," \"tasks[0].{status:lastStatus,stopped:stoppedReason,containers:containers[*].{name:name,reason:reason}}\"",[3440,8279,8068],{"class":8046},[3440,8281,8282,8284],{"class":3438,"line":8081},[3440,8283,8227],{"class":8035},[3440,8285,8170],{"class":8028},[3440,8287,8288],{"class":3438,"line":8088},[3440,8289,8085],{"emptyLinePlaceholder":8084},[3440,8291,8292],{"class":3438,"line":8094},[3440,8293,8294],{"class":8017},"# Переглянути логи контейнера\n",[3440,8296,8297,8299,8302,8305,8308,8311,8314,8317,8320,8322],{"class":3438,"line":8112},[3440,8298,8025],{"class":8024},[3440,8300,8301],{"class":8028}," logs",[3440,8303,8304],{"class":8028}," tail",[3440,8306,8307],{"class":8028}," \u002Fecs\u002Fmy-api",[3440,8309,8310],{"class":8035}," --since",[3440,8312,8313],{"class":8028}," 30m",[3440,8315,8316],{"class":8035}," --format",[3440,8318,8319],{"class":8028}," short",[3440,8321,8036],{"class":8035},[3440,8323,8170],{"class":8028},[3440,8325,8326],{"class":3438,"line":8128},[3440,8327,8085],{"emptyLinePlaceholder":8084},[3440,8329,8330],{"class":3438,"line":8140},[3440,8331,8332],{"class":8017},"# Підключитись до контейнера напряму (якщо увімкнено ECS Exec)\n",[3440,8334,8335,8337,8339,8342,8345,8347,8350,8352],{"class":3438,"line":8145},[3440,8336,8025],{"class":8024},[3440,8338,8156],{"class":8028},[3440,8340,8341],{"class":8028}," execute-command",[3440,8343,8344],{"class":8035}," --cluster",[3440,8346,8261],{"class":8028},[3440,8348,8349],{"class":8035}," --task",[3440,8351,8267],{"class":8074},[3440,8353,8068],{"class":8046},[3440,8355,8356,8359,8361,8364,8367,8370,8372],{"class":3438,"line":8151},[3440,8357,8358],{"class":8035},"    --container",[3440,8360,8219],{"class":8028},[3440,8362,8363],{"class":8035}," --interactive",[3440,8365,8366],{"class":8035}," --command",[3440,8368,8369],{"class":8028}," \"\u002Fbin\u002Fbash\"",[3440,8371,8036],{"class":8035},[3440,8373,8170],{"class":8028},[3387,8375,8377],{"id":8376},"очищення-всіх-ресурсів-після-лабораторної-роботи","Очищення всіх ресурсів після лабораторної роботи",[8004,8379,8381],{"className":8006,"code":8380,"language":8008,"meta":8009,"style":8009},"REGION=\"eu-central-1\"\n\n# 1. Зупинити та видалити Service\naws ecs update-service --cluster ecs-lab-cluster --service ecs-lab-service --desired-count 0 --region $REGION\naws ecs delete-service --cluster ecs-lab-cluster --service ecs-lab-service --force --region $REGION\n\n# 2. Видалити кластер\naws ecs delete-cluster --cluster ecs-lab-cluster --region $REGION\n\n# 3. Видалити образи та репозиторій\naws ecr batch-delete-image --repository-name ecs-lab-api --image-ids imageTag=v1.0.0 imageTag=v1.1.0 --region $REGION\naws ecr delete-repository --repository-name ecs-lab-api --force --region $REGION\n\n# 4. Видалити логи\naws logs delete-log-group --log-group-name \u002Fecs\u002Fecs-lab-api --region $REGION\n\n# 5. Видалити Security Group\naws ec2 delete-security-group --group-id $SG_ID --region $REGION\n",[3356,8382,8383,8394,8398,8403,8433,8457,8461,8466,8483,8487,8492,8520,8539,8543,8548,8567,8571,8576],{"__ignoreMap":8009},[3440,8384,8385,8388,8391],{"class":3438,"line":8014},[3440,8386,8387],{"class":8074},"REGION",[3440,8389,8390],{"class":8042},"=",[3440,8392,8393],{"class":8028},"\"eu-central-1\"\n",[3440,8395,8396],{"class":3438,"line":8021},[3440,8397,8085],{"emptyLinePlaceholder":8084},[3440,8399,8400],{"class":3438,"line":8050},[3440,8401,8402],{"class":8017},"# 1. Зупинити та видалити Service\n",[3440,8404,8405,8407,8409,8411,8413,8416,8418,8421,8424,8428,8430],{"class":3438,"line":8071},[3440,8406,8025],{"class":8024},[3440,8408,8156],{"class":8028},[3440,8410,8191],{"class":8028},[3440,8412,8344],{"class":8035},[3440,8414,8415],{"class":8028}," ecs-lab-cluster",[3440,8417,8205],{"class":8035},[3440,8419,8420],{"class":8028}," ecs-lab-service",[3440,8422,8423],{"class":8035}," --desired-count",[3440,8425,8427],{"class":8426},"sJj4R"," 0",[3440,8429,8036],{"class":8035},[3440,8431,8432],{"class":8074}," $REGION\n",[3440,8434,8435,8437,8439,8442,8444,8446,8448,8450,8453,8455],{"class":3438,"line":8081},[3440,8436,8025],{"class":8024},[3440,8438,8156],{"class":8028},[3440,8440,8441],{"class":8028}," delete-service",[3440,8443,8344],{"class":8035},[3440,8445,8415],{"class":8028},[3440,8447,8205],{"class":8035},[3440,8449,8420],{"class":8028},[3440,8451,8452],{"class":8035}," --force",[3440,8454,8036],{"class":8035},[3440,8456,8432],{"class":8074},[3440,8458,8459],{"class":3438,"line":8088},[3440,8460,8085],{"emptyLinePlaceholder":8084},[3440,8462,8463],{"class":3438,"line":8094},[3440,8464,8465],{"class":8017},"# 2. Видалити кластер\n",[3440,8467,8468,8470,8472,8475,8477,8479,8481],{"class":3438,"line":8112},[3440,8469,8025],{"class":8024},[3440,8471,8156],{"class":8028},[3440,8473,8474],{"class":8028}," delete-cluster",[3440,8476,8344],{"class":8035},[3440,8478,8415],{"class":8028},[3440,8480,8036],{"class":8035},[3440,8482,8432],{"class":8074},[3440,8484,8485],{"class":3438,"line":8128},[3440,8486,8085],{"emptyLinePlaceholder":8084},[3440,8488,8489],{"class":3438,"line":8140},[3440,8490,8491],{"class":8017},"# 3. Видалити образи та репозиторій\n",[3440,8493,8494,8496,8498,8501,8504,8507,8510,8513,8516,8518],{"class":3438,"line":8145},[3440,8495,8025],{"class":8024},[3440,8497,8029],{"class":8028},[3440,8499,8500],{"class":8028}," batch-delete-image",[3440,8502,8503],{"class":8035}," --repository-name",[3440,8505,8506],{"class":8028}," ecs-lab-api",[3440,8508,8509],{"class":8035}," --image-ids",[3440,8511,8512],{"class":8028}," imageTag=v1.0.0",[3440,8514,8515],{"class":8028}," imageTag=v1.1.0",[3440,8517,8036],{"class":8035},[3440,8519,8432],{"class":8074},[3440,8521,8522,8524,8526,8529,8531,8533,8535,8537],{"class":3438,"line":8151},[3440,8523,8025],{"class":8024},[3440,8525,8029],{"class":8028},[3440,8527,8528],{"class":8028}," delete-repository",[3440,8530,8503],{"class":8035},[3440,8532,8506],{"class":8028},[3440,8534,8452],{"class":8035},[3440,8536,8036],{"class":8035},[3440,8538,8432],{"class":8074},[3440,8540,8541],{"class":3438,"line":8173},[3440,8542,8085],{"emptyLinePlaceholder":8084},[3440,8544,8545],{"class":3438,"line":8178},[3440,8546,8547],{"class":8017},"# 4. Видалити логи\n",[3440,8549,8550,8552,8554,8557,8560,8563,8565],{"class":3438,"line":8184},[3440,8551,8025],{"class":8024},[3440,8553,8301],{"class":8028},[3440,8555,8556],{"class":8028}," delete-log-group",[3440,8558,8559],{"class":8035}," --log-group-name",[3440,8561,8562],{"class":8028}," \u002Fecs\u002Fecs-lab-api",[3440,8564,8036],{"class":8035},[3440,8566,8432],{"class":8074},[3440,8568,8569],{"class":3438,"line":8196},[3440,8570,8085],{"emptyLinePlaceholder":8084},[3440,8572,8573],{"class":3438,"line":8213},[3440,8574,8575],{"class":8017},"# 5. Видалити Security Group\n",[3440,8577,8578,8580,8583,8586,8589,8592,8594],{"class":3438,"line":8224},[3440,8579,8025],{"class":8024},[3440,8581,8582],{"class":8028}," ec2",[3440,8584,8585],{"class":8028}," delete-security-group",[3440,8587,8588],{"class":8035}," --group-id",[3440,8590,8591],{"class":8074}," $SG_ID",[3440,8593,8036],{"class":8035},[3440,8595,8432],{"class":8074},[8597,8598,8599],"style",{},"html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sjcCO, html code.shiki .sjcCO{--shiki-light:#EE0000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}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 .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}",{"title":8009,"searchDepth":8021,"depth":8021,"links":8601},[8602,8607,8618,8623,8627,8632,8637,8641,8646,8651,8655,8659,8662,8665],{"id":3384,"depth":8021,"text":3385,"children":8603},[8604,8605,8606],{"id":3389,"depth":8050,"text":3373},{"id":3493,"depth":8050,"text":3494},{"id":3583,"depth":8050,"text":3376},{"id":3635,"depth":8021,"text":3636,"children":8608},[8609,8610,8611,8612,8613,8614,8615,8616,8617],{"id":3639,"depth":8050,"text":3640},{"id":3705,"depth":8050,"text":3706},{"id":3880,"depth":8050,"text":3881},{"id":4001,"depth":8050,"text":4002},{"id":4171,"depth":8050,"text":4172},{"id":4291,"depth":8050,"text":4292},{"id":4363,"depth":8050,"text":4364},{"id":4455,"depth":8050,"text":4456},{"id":4537,"depth":8050,"text":4538},{"id":4639,"depth":8021,"text":4640,"children":8619},[8620,8621,8622],{"id":4643,"depth":8050,"text":4644},{"id":4764,"depth":8050,"text":4765},{"id":4832,"depth":8050,"text":4833},{"id":4860,"depth":8021,"text":4861,"children":8624},[8625,8626],{"id":4864,"depth":8050,"text":4865},{"id":5090,"depth":8050,"text":5091},{"id":5175,"depth":8021,"text":5176,"children":8628},[8629,8630,8631],{"id":5179,"depth":8050,"text":5180},{"id":5352,"depth":8050,"text":5353},{"id":5480,"depth":8050,"text":5481},{"id":5558,"depth":8021,"text":5559,"children":8633},[8634,8635,8636],{"id":5562,"depth":8050,"text":5563},{"id":5667,"depth":8050,"text":5668},{"id":5810,"depth":8050,"text":5811},{"id":5933,"depth":8021,"text":5934,"children":8638},[8639,8640],{"id":5937,"depth":8050,"text":5938},{"id":6065,"depth":8050,"text":6066},{"id":6195,"depth":8021,"text":6196,"children":8642},[8643,8644,8645],{"id":6199,"depth":8050,"text":6200},{"id":6310,"depth":8050,"text":6311},{"id":6485,"depth":8050,"text":6486},{"id":6593,"depth":8021,"text":6594,"children":8647},[8648,8649,8650],{"id":6597,"depth":8050,"text":6598},{"id":6740,"depth":8050,"text":6741},{"id":6876,"depth":8050,"text":6877},{"id":7115,"depth":8021,"text":7116,"children":8652},[8653,8654],{"id":7119,"depth":8050,"text":7120},{"id":7225,"depth":8050,"text":7226},{"id":7425,"depth":8021,"text":7426,"children":8656},[8657,8658],{"id":7429,"depth":8050,"text":7430},{"id":7577,"depth":8050,"text":7578},{"id":7624,"depth":8021,"text":7625,"children":8660},[8661],{"id":7628,"depth":8050,"text":7629},{"id":7799,"depth":8021,"text":7800,"children":8663},[8664],{"id":7803,"depth":8050,"text":7804},{"id":7997,"depth":8021,"text":7998,"children":8666},[8667,8668,8669],{"id":8001,"depth":8050,"text":8002},{"id":8232,"depth":8050,"text":8233},{"id":8376,"depth":8050,"text":8377},"Повний довідник AWS CLI команд для ECR та ECS — аутентифікація, репозиторії, кластери, сервіси, мережа, балансувальник, автомасштабування, логи. Усі важливі команди з прикладами та очікуваним виводом.","md",null,{},{"title":3230,"description":8670},"bhdt2GMI9bZfNsvhAuwYHZ_3HdFNaHka1Vl-JXUVC8c",[8677,8679],{"title":3226,"path":3227,"stem":3228,"description":8678,"children":-1},"Від локального Dockerfile до повноцінного задеплоєного .NET Web API на AWS ECS Fargate. Розбираємо ECR, ECS Task Definitions, Clusters, Services, Auto Scaling та порівнюємо ECS, Fargate і EKS.",{"title":3234,"path":3235,"stem":3236,"description":8680,"children":-1},"Повне керівництво з Amazon EC2 для .NET розробників. Instance Types, AMI, Pricing Models, Security Groups, EBS, запуск .NET 10 на Linux та ASP.NET на Windows Server з IIS від А до Я.",1782371303960]