[{"data":1,"prerenderedAt":6285},["ShallowReactive",2],{"navigation_docs":3,"-tools-docker-installation":3099,"-tools-docker-installation-surround":6280},[4,1657,1810,2264,2445,2652,2774,2824,2881,2915,3041,3058,3095],{"title":5,"icon":6,"path":7,"stem":8,"children":9},"C#","i-devicon-csharp","/csharp","01.csharp",[10,13,60,90,120,202,219,253,379,404,457,650,1346,1636,1653],{"title":11,"path":7,"stem":12},"C# та .NET","01.csharp/index",{"title":14,"icon":15,"path":16,"stem":17,"children":18,"page":59},"Fundamentals","i-lucide-book-open","/csharp/fundamentals","01.csharp/01.fundamentals",[19,23,27,31,35,39,43,47,51,55],{"title":20,"path":21,"stem":22},"Вступ до екосистеми .NET","/csharp/fundamentals/introduction-to-ecosystem","01.csharp/01.fundamentals/01.introduction-to-ecosystem",{"title":24,"path":25,"stem":26},"Структура програми на C#","/csharp/fundamentals/program-structure","01.csharp/01.fundamentals/02.program-structure",{"title":28,"path":29,"stem":30},"Змінні та Типи Даних","/csharp/fundamentals/variables-data-types","01.csharp/01.fundamentals/03.variables-data-types",{"title":32,"path":33,"stem":34},"Масиви","/csharp/fundamentals/arrays","01.csharp/01.fundamentals/04.arrays",{"title":36,"path":37,"stem":38},"Strings & Text Handling","/csharp/fundamentals/strings-text-handling","01.csharp/01.fundamentals/05.strings-text-handling",{"title":40,"path":41,"stem":42},"Дати і Час","/csharp/fundamentals/dates-time-handling","01.csharp/01.fundamentals/06.dates-time-handling",{"title":44,"path":45,"stem":46},"Потік Керування","/csharp/fundamentals/control-flow","01.csharp/01.fundamentals/07.control-flow",{"title":48,"path":49,"stem":50},"Методи","/csharp/fundamentals/methods","01.csharp/01.fundamentals/08.methods",{"title":52,"path":53,"stem":54},"Основи Відлагодження","/csharp/fundamentals/debugging-basics","01.csharp/01.fundamentals/09.debugging-basics",{"title":56,"path":57,"stem":58},"Інтерактивна Консоль (Classic)","/csharp/fundamentals/interactive-console","01.csharp/01.fundamentals/10.interactive-console",false,{"title":61,"icon":62,"path":63,"stem":64,"children":65,"page":59},"OOP","i-lucide-box","/csharp/oop","01.csharp/02.oop",[66,70,74,78,82,86],{"title":67,"path":68,"stem":69},"Package Management (Управління Пакетами)","/csharp/oop/package-management","01.csharp/02.oop/01.package-management",{"title":71,"path":72,"stem":73},"Класи та Об'єкти","/csharp/oop/classes-objects","01.csharp/02.oop/02.classes-objects",{"title":75,"path":76,"stem":77},"Властивості та Поля","/csharp/oop/properties-fields","01.csharp/02.oop/03.properties-fields",{"title":79,"path":80,"stem":81},"Стовпи ООП","/csharp/oop/oop-pillars","01.csharp/02.oop/04.oop-pillars",{"title":83,"path":84,"stem":85},"Advanced Types","/csharp/oop/advanced-types","01.csharp/02.oop/05.advanced-types",{"title":87,"path":88,"stem":89},"Namespaces (Простори Імен)","/csharp/oop/namespaces","01.csharp/02.oop/06.namespaces",{"title":91,"icon":92,"path":93,"stem":94,"children":95,"page":59},"Advanced Core","i-lucide-zap","/csharp/advanced-core","01.csharp/03.advanced-core",[96,100,104,108,112,116],{"title":97,"path":98,"stem":99},"Generics (Узагальнення)","/csharp/advanced-core/generics","01.csharp/03.advanced-core/01.generics",{"title":101,"path":102,"stem":103},"Делегати, Події та Лямбда-вирази","/csharp/advanced-core/delegates-events-lambdas","01.csharp/03.advanced-core/02.delegates-events-lambdas",{"title":105,"path":106,"stem":107},"Interfaces Deep Dive (Інтерфейси: Поглиблений Розгляд)","/csharp/advanced-core/interfaces-deep-dive","01.csharp/03.advanced-core/03.interfaces-deep-dive",{"title":109,"path":110,"stem":111},"Обробка Винятків","/csharp/advanced-core/exception-handling","01.csharp/03.advanced-core/04.exception-handling",{"title":113,"path":114,"stem":115},"Pattern Matching","/csharp/advanced-core/pattern-matching","01.csharp/03.advanced-core/05.pattern-matching",{"title":117,"path":118,"stem":119},"Додаткові Можливості C#","/csharp/advanced-core/additional-features","01.csharp/03.advanced-core/06.additional-features",{"title":121,"icon":122,"path":123,"stem":124,"children":125,"page":59},"Architecture Best Practices","i-lucide-building-2","/csharp/architecture-best-practices","01.csharp/04.architecture-best-practices",[126,130,149,153,157,161,165,169],{"title":127,"path":128,"stem":129},"Software Design Principles (Частина 1)","/csharp/architecture-best-practices/software-design-principles","01.csharp/04.architecture-best-practices/01.software-design-principles",{"title":131,"icon":132,"path":133,"stem":134,"children":135,"page":59},"Design Patterns","i-lucide-folder","/csharp/architecture-best-practices/design-patterns","01.csharp/04.architecture-best-practices/02.design-patterns",[136],{"title":137,"icon":132,"path":138,"stem":139,"children":140,"page":59},"Creational","/csharp/architecture-best-practices/design-patterns/creational","01.csharp/04.architecture-best-practices/02.design-patterns/creational",[141,145],{"title":142,"path":143,"stem":144},"Singleton (Одинак)","/csharp/architecture-best-practices/design-patterns/creational/singleton","01.csharp/04.architecture-best-practices/02.design-patterns/creational/01.singleton",{"title":146,"path":147,"stem":148},"Builder (Будівельник)","/csharp/architecture-best-practices/design-patterns/creational/builder","01.csharp/04.architecture-best-practices/02.design-patterns/creational/02.builder",{"title":150,"path":151,"stem":152},"Building Professional CLIs","/csharp/architecture-best-practices/building-professional-clis","01.csharp/04.architecture-best-practices/03.building-professional-clis",{"title":154,"path":155,"stem":156},"Validation & Flow Control","/csharp/architecture-best-practices/validation-flow-control","01.csharp/04.architecture-best-practices/04.validation-flow-control",{"title":158,"path":159,"stem":160},"The Modern .NET Host (Microsoft.Extensions)","/csharp/architecture-best-practices/modern-dotnet-host","01.csharp/04.architecture-best-practices/05.modern-dotnet-host",{"title":162,"path":163,"stem":164},"Data Mapper: Repository та DAO патерни (Частина 1)","/csharp/architecture-best-practices/data-mapper-part1","01.csharp/04.architecture-best-practices/06.data-mapper-part1",{"title":166,"path":167,"stem":168},"Data Mapper: Repository та DAO патерни (Частина 2)","/csharp/architecture-best-practices/data-mapper-part2","01.csharp/04.architecture-best-practices/07.data-mapper-part2",{"title":170,"icon":132,"path":171,"stem":172,"children":173,"page":59},"Di Ioc","/csharp/architecture-best-practices/di-ioc","01.csharp/04.architecture-best-practices/08.di-ioc",[174,178,182,186,190,194,198],{"title":175,"path":176,"stem":177},"Проблема залежностей та Інверсія Контролю","/csharp/architecture-best-practices/di-ioc/the-dependency-problem","01.csharp/04.architecture-best-practices/08.di-ioc/01.the-dependency-problem",{"title":179,"path":180,"stem":181},"Будуємо власний Service Container","/csharp/architecture-best-practices/di-ioc/build-your-own-container","01.csharp/04.architecture-best-practices/08.di-ioc/02.build-your-own-container",{"title":183,"path":184,"stem":185},"Service Locator: Паттерн та Анти-паттерн","/csharp/architecture-best-practices/di-ioc/service-locator-pattern","01.csharp/04.architecture-best-practices/08.di-ioc/03.service-locator-pattern",{"title":187,"path":188,"stem":189},"Паттерни Dependency Injection","/csharp/architecture-best-practices/di-ioc/dependency-injection-patterns","01.csharp/04.architecture-best-practices/08.di-ioc/04.dependency-injection-patterns",{"title":191,"path":192,"stem":193},"Microsoft DI: IServiceCollection та IServiceProvider","/csharp/architecture-best-practices/di-ioc/microsoft-di-deep-dive","01.csharp/04.architecture-best-practices/08.di-ioc/05.microsoft-di-deep-dive",{"title":195,"path":196,"stem":197},"Service Lifetimes та Scopes","/csharp/architecture-best-practices/di-ioc/service-lifetimes-and-scopes","01.csharp/04.architecture-best-practices/08.di-ioc/06.service-lifetimes-and-scopes",{"title":199,"path":200,"stem":201},"DI Анти-паттерни та Найкращі Практики","/csharp/architecture-best-practices/di-ioc/di-anti-patterns-and-best-practices","01.csharp/04.architecture-best-practices/08.di-ioc/07.di-anti-patterns-and-best-practices",{"title":203,"icon":132,"path":204,"stem":205,"children":206,"page":59},"Standard Library","/csharp/standard-library","01.csharp/05.standard-library",[207,211,215],{"title":208,"path":209,"stem":210},"Collections (Колекції)","/csharp/standard-library/collections","01.csharp/05.standard-library/01.collections",{"title":212,"path":213,"stem":214},"High Performance Types (Високопродуктивні Типи)","/csharp/standard-library/high-performance-types","01.csharp/05.standard-library/02.high-performance-types",{"title":216,"path":217,"stem":218},"LINQ (Language Integrated Query)","/csharp/standard-library/linq","01.csharp/05.standard-library/03.linq",{"title":220,"icon":221,"path":222,"stem":223,"children":224,"page":59},"System Internals Concurrency","i-lucide-server","/csharp/system-internals-concurrency","01.csharp/06.system-internals-concurrency",[225,229,233,237,241,245,249],{"title":226,"path":227,"stem":228},"Memory Management","/csharp/system-internals-concurrency/memory-management","01.csharp/06.system-internals-concurrency/01.memory-management",{"title":230,"path":231,"stem":232},"Reflection API: System.Type та Метадані","/csharp/system-internals-concurrency/reflection-fundamentals","01.csharp/06.system-internals-concurrency/02.reflection-fundamentals",{"title":234,"path":235,"stem":236},"Attributes та Dynamic Language Runtime","/csharp/system-internals-concurrency/attributes-dynamic","01.csharp/06.system-internals-concurrency/03.attributes-dynamic",{"title":238,"path":239,"stem":240},"Expression Trees: Швидка Альтернатива Рефлексії","/csharp/system-internals-concurrency/expression-trees-compiled","01.csharp/06.system-internals-concurrency/04.expression-trees-compiled",{"title":242,"path":243,"stem":244},"Source Generators: Compile-Time Code Generation","/csharp/system-internals-concurrency/source-generators","01.csharp/06.system-internals-concurrency/05.source-generators",{"title":246,"path":247,"stem":248},"Multithreading Fundamentals","/csharp/system-internals-concurrency/multithreading-fundamentals","01.csharp/06.system-internals-concurrency/06.multithreading-fundamentals",{"title":250,"path":251,"stem":252},"Synchronization Primitives","/csharp/system-internals-concurrency/synchronization-primitives","01.csharp/06.system-internals-concurrency/07.synchronization-primitives",{"title":254,"icon":255,"path":256,"stem":257,"children":258,"page":59},"System Programming Windows","i-lucide-cpu","/csharp/system-programming-windows","01.csharp/07.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},"Як Працює Операційна Система","/csharp/system-programming-windows/how-os-works","01.csharp/07.system-programming-windows/01.how-os-works",{"title":264,"path":265,"stem":266},"Процеси в .NET — API та Запуск","/csharp/system-programming-windows/processes-in-dotnet","01.csharp/07.system-programming-windows/02.processes-in-dotnet",{"title":268,"path":269,"stem":270},"Процеси в .NET — IPC та Міжпроцесна Комунікація","/csharp/system-programming-windows/02a.processes-ipc","01.csharp/07.system-programming-windows/02a.processes-ipc",{"title":272,"path":273,"stem":274},"Application Domains та Збірки — AppDomain і AssemblyLoadContext","/csharp/system-programming-windows/appdomains-assemblies","01.csharp/07.system-programming-windows/03.appdomains-assemblies",{"title":276,"path":277,"stem":278},"Application Domains та Збірки — Plug-in Система з Hot-Reload","/csharp/system-programming-windows/03a.appdomains-plugin-system","01.csharp/07.system-programming-windows/03a.appdomains-plugin-system",{"title":280,"path":281,"stem":282},"Потоки — Основи та API Thread","/csharp/system-programming-windows/thread-fundamentals","01.csharp/07.system-programming-windows/04.thread-fundamentals",{"title":284,"path":285,"stem":286},"Потоки — Lifecycle, Пріоритети та Безпечне Завершення","/csharp/system-programming-windows/04a.thread-lifecycle-priorities","01.csharp/07.system-programming-windows/04a.thread-lifecycle-priorities",{"title":288,"path":289,"stem":290},"Проблеми Спільного Стану — Race Condition та Data Race","/csharp/system-programming-windows/shared-state-problems","01.csharp/07.system-programming-windows/05.shared-state-problems",{"title":292,"path":293,"stem":294},"Проблеми Спільного Стану — Memory Model та volatile","/csharp/system-programming-windows/05a.shared-state-memory-model","01.csharp/07.system-programming-windows/05a.shared-state-memory-model",{"title":296,"path":297,"stem":298},"Синхронізація — Monitor, lock та еволюція примітивів","/csharp/system-programming-windows/synchronization-fundamentals","01.csharp/07.system-programming-windows/06.synchronization-fundamentals",{"title":300,"path":301,"stem":302},"Синхронізація — Наскрізний Приклад та Deadlock Detection","/csharp/system-programming-windows/06a.synchronization-walkthrough","01.csharp/07.system-programming-windows/06a.synchronization-walkthrough",{"title":304,"path":305,"stem":306},"Синхронізація — Mutex, Semaphore та Event-Based Primitives","/csharp/system-programming-windows/synchronization-advanced","01.csharp/07.system-programming-windows/07.synchronization-advanced",{"title":308,"path":309,"stem":310},"Синхронізація — Interlocked, Volatile та Lock-Free Структури","/csharp/system-programming-windows/07a.synchronization-advanced-walkthrough","01.csharp/07.system-programming-windows/07a.synchronization-advanced-walkthrough",{"title":312,"path":313,"stem":314},"Interlocked, CAS та Lock-Free Структури","/csharp/system-programming-windows/interlocked-cas-lockfree","01.csharp/07.system-programming-windows/08.interlocked-cas-lockfree",{"title":316,"path":317,"stem":318},"Volatile, Memory Model та Spinning","/csharp/system-programming-windows/08a.volatile-memory-model","01.csharp/07.system-programming-windows/08a.volatile-memory-model",{"title":320,"path":321,"stem":322},"ThreadPool — Пул Потоків для Ефективного Виконання","/csharp/system-programming-windows/thread-pool","01.csharp/07.system-programming-windows/09.thread-pool",{"title":324,"path":325,"stem":326},"ThreadPool — Просунуті Сценарії та Внутрішня Будова","/csharp/system-programming-windows/09a.thread-pool-advanced","01.csharp/07.system-programming-windows/09a.thread-pool-advanced",{"title":328,"path":329,"stem":330},"Concurrent та Immutable Collections","/csharp/system-programming-windows/concurrent-collections","01.csharp/07.system-programming-windows/10.concurrent-collections",{"title":332,"path":333,"stem":334},"TPL, Task та Композиція — Від Thread до Task","/csharp/system-programming-windows/tpl-parallel-plinq","01.csharp/07.system-programming-windows/11.tpl-parallel-plinq",{"title":336,"path":337,"stem":338},"Parallel Class та PLINQ — Data Parallelism","/csharp/system-programming-windows/11a.tpl-parallel-plinq-advanced","01.csharp/07.system-programming-windows/11a.tpl-parallel-plinq-advanced",{"title":340,"path":341,"stem":342},"Async/Await — Фундамент Асинхронного Програмування","/csharp/system-programming-windows/async-fundamentals","01.csharp/07.system-programming-windows/12.async-fundamentals",{"title":344,"path":345,"stem":346},"SynchronizationContext та ConfigureAwait — Контекст Виконання","/csharp/system-programming-windows/async-context-configureawait","01.csharp/07.system-programming-windows/13.async-context-configureawait",{"title":348,"path":349,"stem":350},"Async — Просунуті Паттерни","/csharp/system-programming-windows/async-advanced","01.csharp/07.system-programming-windows/14.async-advanced",{"title":352,"path":353,"stem":354},"System.Threading.Channels — Async Producer-Consumer","/csharp/system-programming-windows/channels","01.csharp/07.system-programming-windows/15.channels",{"title":356,"path":357,"stem":358},"Асинхронна Синхронізація","/csharp/system-programming-windows/async-synchronization","01.csharp/07.system-programming-windows/16.async-synchronization",{"title":360,"path":361,"stem":362},"Unsafe Code та Вказівники","/csharp/system-programming-windows/unsafe-code","01.csharp/07.system-programming-windows/17.unsafe-code",{"title":364,"path":365,"stem":366},"P/Invoke та Windows API — Міст між .NET та Native Code","/csharp/system-programming-windows/pinvoke-winapi","01.csharp/07.system-programming-windows/18.pinvoke-winapi",{"title":368,"path":369,"stem":370},"Реєстр Windows — Центральна База Конфігурації Системи","/csharp/system-programming-windows/windows-registry","01.csharp/07.system-programming-windows/19.windows-registry",{"title":372,"path":373,"stem":374},"Windows Hooks, Hotkeys та Services — Глибока Інтеграція з ОС","/csharp/system-programming-windows/windows-hooks-services","01.csharp/07.system-programming-windows/20.windows-hooks-services",{"title":376,"path":377,"stem":378},"Системне Програмування C# (Windows) — 07.system-programming-windows","/csharp/system-programming-windows/implementation_plan","01.csharp/07.system-programming-windows/implementation_plan",{"title":380,"icon":132,"path":381,"stem":382,"children":383,"page":59},"Io","/csharp/io","01.csharp/08.io",[384,388,392,396,400],{"title":385,"path":386,"stem":387},"8.1.1. Основи роботи з файловою системою","/csharp/io/file-system-basics","01.csharp/08.io/01.file-system-basics",{"title":389,"path":390,"stem":391},"8.1.2. Потоки (Streams) та Серіалізація Даних","/csharp/io/streams-serialization","01.csharp/08.io/02.streams-serialization",{"title":393,"path":394,"stem":395},"8.2.1. JSON Serialization з System.Text.Json","/csharp/io/json-serialization","01.csharp/08.io/03.json-serialization",{"title":397,"path":398,"stem":399},"8.2.2. XML Serialization та LINQ to XML","/csharp/io/xml-serialization","01.csharp/08.io/04.xml-serialization",{"title":401,"path":402,"stem":403},"8.2.3. Binary Serialization: MessagePack та Protocol Buffers","/csharp/io/binary-serialization","01.csharp/08.io/05.binary-serialization",{"title":405,"icon":132,"path":406,"stem":407,"children":408,"page":59},"Ado Net","/csharp/ado-net","01.csharp/09.ado-net",[409,413,417,421,425,429,433,437,441,445,449,453],{"title":410,"path":411,"stem":412},"9.1. Введення в ADO.NET","/csharp/ado-net/introduction-to-adonet","01.csharp/09.ado-net/01.introduction-to-adonet",{"title":414,"path":415,"stem":416},"9.2. Клас DbConnection — з'єднання з базою даних","/csharp/ado-net/connection","01.csharp/09.ado-net/02.connection",{"title":418,"path":419,"stem":420},"9.3. Клас DbCommand — виконання SQL-запитів","/csharp/ado-net/command-and-queries","01.csharp/09.ado-net/03.command-and-queries",{"title":422,"path":423,"stem":424},"9.4. Клас DbDataReader — ефективне читання даних","/csharp/ado-net/datareader","01.csharp/09.ado-net/04.datareader",{"title":426,"path":427,"stem":428},"9.5. Параметризовані запити та захист від SQL Injection","/csharp/ado-net/parameters-and-sql-injection","01.csharp/09.ado-net/05.parameters-and-sql-injection",{"title":430,"path":431,"stem":432},"9.6. Транзакції в ADO.NET","/csharp/ado-net/transactions","01.csharp/09.ado-net/06.transactions",{"title":434,"path":435,"stem":436},"9.7. DbProviderFactory — провайдер-незалежний код","/csharp/ado-net/provider-factory","01.csharp/09.ado-net/07.provider-factory",{"title":438,"path":439,"stem":440},"9.8. Асинхронний доступ до даних","/csharp/ado-net/async-data-access","01.csharp/09.ado-net/08.async-data-access",{"title":442,"path":443,"stem":444},"9.9. Від'єднаний режим: DataSet, DataTable, DataRow","/csharp/ado-net/disconnected-mode-dataset","01.csharp/09.ado-net/09.disconnected-mode-dataset",{"title":446,"path":447,"stem":448},"9.10. DataAdapter — міст між DataSet та базою даних","/csharp/ado-net/data-adapter","01.csharp/09.ado-net/10.data-adapter",{"title":450,"path":451,"stem":452},"9.11. Data Mapper та Repository: Архітектура доступу до даних","/csharp/ado-net/data-mapper-repository","01.csharp/09.ado-net/11.data-mapper-repository",{"title":454,"path":455,"stem":456},"9.12. Identity Map, Unit of Work та Specification Pattern","/csharp/ado-net/advanced-patterns","01.csharp/09.ado-net/12.advanced-patterns",{"title":458,"icon":255,"path":459,"stem":460,"children":461,"page":59},"Ef Core","/csharp/ef-core","01.csharp/10.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 до об'єктів","/csharp/ef-core/what-is-orm","01.csharp/10.ef-core/01.what-is-orm",{"title":467,"path":468,"stem":469},"Перший проєкт — від нуля до CRUD","/csharp/ef-core/first-project","01.csharp/10.ef-core/02.first-project",{"title":471,"path":472,"stem":473},"DbContext — Серце EF Core","/csharp/ef-core/dbcontext-deep-dive","01.csharp/10.ef-core/03.dbcontext-deep-dive",{"title":475,"path":476,"stem":477},"Провайдери баз даних — Архітектура та Вибір СУБД","/csharp/ef-core/database-providers","01.csharp/10.ef-core/04.database-providers",{"title":479,"path":480,"stem":481},"Конвенції EF Core — Магія без конфігурації","/csharp/ef-core/conventions","01.csharp/10.ef-core/05.conventions",{"title":483,"path":484,"stem":485},"Fluent API та Data Annotations — Явна конфігурація моделі","/csharp/ef-core/fluent-api-vs-annotations","01.csharp/10.ef-core/06.fluent-api-vs-annotations",{"title":487,"path":488,"stem":489},"Зв'язки — One-to-One та One-to-Many","/csharp/ef-core/relationships-basics","01.csharp/10.ef-core/07.relationships-basics",{"title":491,"path":492,"stem":493},"Зв'язки Advanced — Many-to-Many та Складні Сценарії","/csharp/ef-core/relationships-advanced","01.csharp/10.ef-core/08.relationships-advanced",{"title":495,"path":496,"stem":497},"Властивості — Типи, Конвертери, Компаратори (Частина 1)","/csharp/ef-core/property-configuration-part1","01.csharp/10.ef-core/09.property-configuration-part1",{"title":499,"path":500,"stem":501},"Властивості — Value Comparers, Generators, Shadow Properties (Частина 2)","/csharp/ef-core/property-configuration-part2","01.csharp/10.ef-core/09.property-configuration-part2",{"title":503,"path":504,"stem":505},"Складні типи — Owned Types та Complex Types (Частина 1)","/csharp/ef-core/complex-types-owned-part1","01.csharp/10.ef-core/10.complex-types-owned-part1",{"title":507,"path":508,"stem":509},"Складні типи — Complex Types, Keyless Entities, Порівняння (Частина 2)","/csharp/ef-core/complex-types-owned-part2","01.csharp/10.ef-core/10.complex-types-owned-part2",{"title":511,"path":512,"stem":513},"JSON Columns — Складні дані у JSON (Частина 1)","/csharp/ef-core/json-columns-part1","01.csharp/10.ef-core/11.json-columns-part1",{"title":515,"path":516,"stem":517},"JSON Columns — Value Comparers, Індекси, Провайдери (Частина 2)","/csharp/ef-core/json-columns-part2","01.csharp/10.ef-core/11.json-columns-part2",{"title":519,"path":520,"stem":521},"Успадкування — Абстрактні класи та TPH (Частина 1)","/csharp/ef-core/inheritance-part1","01.csharp/10.ef-core/12.inheritance-part1",{"title":523,"path":524,"stem":525},"Успадкування — TPT, TPC та Порівняння Стратегій (Частина 2)","/csharp/ef-core/inheritance-part2","01.csharp/10.ef-core/12.inheritance-part2",{"title":527,"path":528,"stem":529,"children":530},"Індекси, Обмеження та Схема (Частина 1)","/csharp/ef-core/indexes-constraints-part1","01.csharp/10.ef-core/13.indexes-constraints-part1",[531],{"title":527,"path":528,"stem":529},{"title":533,"path":534,"stem":535,"children":536},"Індекси, Обмеження та Схема (Частина 2)","/csharp/ef-core/indexes-constraints-part2","01.csharp/10.ef-core/13.indexes-constraints-part2",[537],{"title":533,"path":534,"stem":535},{"title":539,"path":540,"stem":541},"Seed Data — Початкові Дані (Частина 1)","/csharp/ef-core/seeding-part1","01.csharp/10.ef-core/14.seeding-part1",{"title":543,"path":544,"stem":545},"Seed Data — SQL-скрипти, Bogus та Стратегії (Частина 2)","/csharp/ef-core/seeding-part2","01.csharp/10.ef-core/14.seeding-part2",{"title":547,"path":548,"stem":549},"Global Query Filters — Глобальні Фільтри (Частина 1)","/csharp/ef-core/global-query-filters-part1","01.csharp/10.ef-core/15.global-query-filters-part1",{"title":551,"path":552,"stem":553},"Global Query Filters — Підводні камені та Інтеграція (Частина 2)","/csharp/ef-core/global-query-filters-part2","01.csharp/10.ef-core/15.global-query-filters-part2",{"title":555,"path":556,"stem":557},"LINQ-запити в EF Core (Частина 1)","/csharp/ef-core/linq-queries-part1","01.csharp/10.ef-core/16.linq-queries-part1",{"title":559,"path":560,"stem":561},"LINQ-запити в EF Core (Частина 2)","/csharp/ef-core/linq-queries-part2","01.csharp/10.ef-core/16.linq-queries-part2",{"title":563,"path":564,"stem":565},"Завантаження Пов'язаних Даних (Частина 1)","/csharp/ef-core/loading-related-data-part1","01.csharp/10.ef-core/17.loading-related-data-part1",{"title":567,"path":568,"stem":569},"Завантаження Пов'язаних Даних (Частина 2)","/csharp/ef-core/loading-related-data-part2","01.csharp/10.ef-core/17.loading-related-data-part2",{"title":571,"path":572,"stem":573},"Raw SQL, Views та Stored Procedures (Частина 1)","/csharp/ef-core/raw-sql-part1","01.csharp/10.ef-core/18.raw-sql-part1",{"title":575,"path":576,"stem":577},"Raw SQL — Stored Procedures, DbFunction та Bulk Operations (Частина 2)","/csharp/ef-core/raw-sql-part2","01.csharp/10.ef-core/18.raw-sql-part2",{"title":579,"path":580,"stem":581},"Продвинуті Запити — Compiled Queries, Bulk та Оптимізація (Частина 1)","/csharp/ef-core/advanced-queries-part1","01.csharp/10.ef-core/19.advanced-queries-part1",{"title":583,"path":584,"stem":585},"Продвинуті Запити — Query Tags, Bulk та Interceptors (Частина 2)","/csharp/ef-core/advanced-queries-part2","01.csharp/10.ef-core/19.advanced-queries-part2",{"title":587,"path":588,"stem":589},"Change Tracker — Відстеження Змін (Частина 1)","/csharp/ef-core/change-tracking-part1","01.csharp/10.ef-core/20.change-tracking-part1",{"title":591,"path":592,"stem":593},"Change Tracker — Графи Об'єктів та Disconnected (Частина 2)","/csharp/ef-core/change-tracking-part2","01.csharp/10.ef-core/20.change-tracking-part2",{"title":595,"path":596,"stem":597},"Збереження Даних та Транзакції (Частина 1)","/csharp/ef-core/saving-data-part1","01.csharp/10.ef-core/21.saving-data-part1",{"title":599,"path":600,"stem":601},"Збереження Даних — Concurrency та Outbox (Частина 2)","/csharp/ef-core/saving-data-part2","01.csharp/10.ef-core/21.saving-data-part2",{"title":603,"path":604,"stem":605},"Конкурентність та Блокування (Частина 1)","/csharp/ef-core/concurrency-part1","01.csharp/10.ef-core/22.concurrency-part1",{"title":607,"path":608,"stem":609},"Конкурентність — Дедлоки та Queue Processing (Частина 2)","/csharp/ef-core/concurrency-part2","01.csharp/10.ef-core/22.concurrency-part2",{"title":611,"path":612,"stem":613},"Міграції в EF Core — Основи (Частина 1)","/csharp/ef-core/migrations-basics-part1","01.csharp/10.ef-core/23.migrations-basics-part1",{"title":615,"path":616,"stem":617},"Міграції в EF Core — Основи (Частина 2)","/csharp/ef-core/migrations-basics-part2","01.csharp/10.ef-core/23.migrations-basics-part2",{"title":619,"path":620,"stem":621},"Міграції — Просунуті Сценарії (Частина 1)","/csharp/ef-core/migrations-advanced-part1","01.csharp/10.ef-core/24.migrations-advanced-part1",{"title":623,"path":624,"stem":625},"Міграції — Просунуті Сценарії (Частина 2)","/csharp/ef-core/migrations-advanced-part2","01.csharp/10.ef-core/24.migrations-advanced-part2",{"title":627,"path":628,"stem":629},"Управління Схемою та Database-First (Частина 1)","/csharp/ef-core/schema-management-part1","01.csharp/10.ef-core/25.schema-management-part1",{"title":631,"path":632,"stem":633},"Управління Схемою та Database-First (Частина 2)","/csharp/ef-core/schema-management-part2","01.csharp/10.ef-core/25.schema-management-part2",{"title":635,"path":636,"stem":637},"Продуктивність EF Core — Основи (Частина 1)","/csharp/ef-core/performance-fundamentals-part1","01.csharp/10.ef-core/26.performance-fundamentals-part1",{"title":639,"path":640,"stem":641},"Interceptors в EF Core (Частина 1)","/csharp/ef-core/interceptors-part1","01.csharp/10.ef-core/29.interceptors-part1",{"title":643,"path":644,"stem":645},"Interceptors в EF Core — Connection, Transaction та Materialization (Частина 2)","/csharp/ef-core/interceptors-part2","01.csharp/10.ef-core/29.interceptors-part2",{"title":647,"path":648,"stem":649},"План вивчення Entity Framework Core — Повний курс","/csharp/ef-core/implementation_plan","01.csharp/10.ef-core/implementation_plan",{"title":651,"icon":652,"path":653,"stem":654,"children":655,"page":59},"ASP.NET","i-devicon-dotnetcore","/csharp/aspnet","01.csharp/11.aspnet",[656,730,791,869,927,941,967,1057,1111,1182,1212,1289],{"title":657,"icon":658,"path":659,"stem":660,"children":661,"page":59},"Minimal API","i-lucide-network","/csharp/aspnet/minimal-api","01.csharp/11.aspnet/01.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 та еволюція фреймворку","/csharp/aspnet/minimal-api/introduction","01.csharp/11.aspnet/01.minimal-api/01.introduction",{"title":667,"path":668,"stem":669},"Перший додаток на ASP.NET Core","/csharp/aspnet/minimal-api/first-application","01.csharp/11.aspnet/01.minimal-api/02.first-application",{"title":671,"path":672,"stem":673},"WebApplication, Builder та Dependency Injection","/csharp/aspnet/minimal-api/webapplication-builder","01.csharp/11.aspnet/01.minimal-api/03.webapplication-builder",{"title":675,"path":676,"stem":677},"Конвеєр запитів та Middleware","/csharp/aspnet/minimal-api/request-pipeline-middleware","01.csharp/11.aspnet/01.minimal-api/04.request-pipeline-middleware",{"title":679,"path":680,"stem":681},"Маршрутизація в ASP.NET Core: Основи","/csharp/aspnet/minimal-api/routing-basics","01.csharp/11.aspnet/01.minimal-api/05.routing-basics",{"title":683,"path":684,"stem":685},"Маршрутизація в ASP.NET Core: Розширені можливості","/csharp/aspnet/minimal-api/routing-advanced","01.csharp/11.aspnet/01.minimal-api/06.routing-advanced",{"title":687,"path":688,"stem":689},"Статичні файли в ASP.NET Core","/csharp/aspnet/minimal-api/static-files","01.csharp/11.aspnet/01.minimal-api/07.static-files",{"title":691,"path":692,"stem":693},"Статичні Активи: MapStaticAssets (ASP.NET Core 9.0)","/csharp/aspnet/minimal-api/static-assets","01.csharp/11.aspnet/01.minimal-api/08.static-assets",{"title":695,"path":696,"stem":697},"Конфігурація в ASP.NET Core: Основи","/csharp/aspnet/minimal-api/configuration-fundamentals","01.csharp/11.aspnet/01.minimal-api/09.configuration-fundamentals",{"title":699,"path":700,"stem":701},"Конфігурація: Паттерн Options","/csharp/aspnet/minimal-api/configuration-options","01.csharp/11.aspnet/01.minimal-api/10.configuration-options",{"title":703,"path":704,"stem":705},"Логування в ASP.NET Core: Основи","/csharp/aspnet/minimal-api/logging-basics","01.csharp/11.aspnet/01.minimal-api/11.logging-basics",{"title":707,"path":708,"stem":709},"Логування: Serilog та Middleware","/csharp/aspnet/minimal-api/logging-advanced","01.csharp/11.aspnet/01.minimal-api/12.logging-advanced",{"title":711,"path":712,"stem":713},"Управління станом: HttpContext.Items та Cookies","/csharp/aspnet/minimal-api/state-management","01.csharp/11.aspnet/01.minimal-api/13.state-management",{"title":715,"path":716,"stem":717},"Стан сесії: Sessions","/csharp/aspnet/minimal-api/session-state","01.csharp/11.aspnet/01.minimal-api/14.session-state",{"title":719,"path":720,"stem":721},"Структура проєкту: від хаосу до архітектури","/csharp/aspnet/minimal-api/project-structure","01.csharp/11.aspnet/01.minimal-api/15.project-structure",{"title":723,"path":724,"stem":725},"Scalar у Minimal API: повний проєкт і Fluent OpenAPI","/csharp/aspnet/minimal-api/scalar-openapi-fluent","01.csharp/11.aspnet/01.minimal-api/16.scalar-openapi-fluent",{"title":727,"path":728,"stem":729},"Swagger / Swashbuckle у Minimal API: окремий класичний шлях","/csharp/aspnet/minimal-api/swagger-swashbuckle","01.csharp/11.aspnet/01.minimal-api/17.swagger-swashbuckle",{"title":731,"icon":658,"path":732,"stem":733,"children":734,"page":59},"API","/csharp/aspnet/api","01.csharp/11.aspnet/02.api",[735,739,743,747,751,755,759,763,767,771,775,779,783,787],{"title":736,"path":737,"stem":738},"Що таке API. Клієнт-серверна архітектура","/csharp/aspnet/api/what-is-api","01.csharp/11.aspnet/02.api/01.what-is-api",{"title":740,"path":741,"stem":742},"Формати даних: JSON, XML, TOML та бінарні формати","/csharp/aspnet/api/data-formats","01.csharp/11.aspnet/02.api/02.data-formats",{"title":744,"path":745,"stem":746},"Парадигми API та концепція REST","/csharp/aspnet/api/api-paradigms-rest","01.csharp/11.aspnet/02.api/03.api-paradigms-rest",{"title":748,"path":749,"stem":750},"HTTP-методи, статус-коди та заголовки","/csharp/aspnet/api/http-methods-status-codes","01.csharp/11.aspnet/02.api/04.http-methods-status-codes",{"title":752,"path":753,"stem":754},"Організація HTTP API за принципами REST","/csharp/aspnet/api/rest-organizing","01.csharp/11.aspnet/02.api/05.rest-organizing",{"title":756,"path":757,"stem":758},"Номенклатура URL та CRUD-операції","/csharp/aspnet/api/url-nomenclature-crud","01.csharp/11.aspnet/02.api/06.url-nomenclature-crud",{"title":760,"path":761,"stem":762},"Правила дизайну: іменування та стандарти","/csharp/aspnet/api/api-design-naming","01.csharp/11.aspnet/02.api/07.api-design-naming",{"title":764,"path":765,"stem":766},"Валідація, ліміти та обробка помилок","/csharp/aspnet/api/api-design-validation","01.csharp/11.aspnet/02.api/08.api-design-validation",{"title":768,"path":769,"stem":770},"Обробка помилок у Minimal API","/csharp/aspnet/api/error-handling-http","01.csharp/11.aspnet/02.api/09.error-handling-http",{"title":772,"path":773,"stem":774},"Ідемпотентність та синхронізація стану","/csharp/aspnet/api/idempotency-sync","01.csharp/11.aspnet/02.api/10.idempotency-sync",{"title":776,"path":777,"stem":778},"Пагінація та організація списків","/csharp/aspnet/api/pagination-lists","01.csharp/11.aspnet/02.api/11.pagination-lists",{"title":780,"path":781,"stem":782},"Безпека API, кешування та інтернаціоналізація","/csharp/aspnet/api/security-auth","01.csharp/11.aspnet/02.api/12.security-auth",{"title":784,"path":785,"stem":786},"Процес проєктування API та документування","/csharp/aspnet/api/api-design-process","01.csharp/11.aspnet/02.api/13.api-design-process",{"title":788,"path":789,"stem":790},"OpenAPI: контракт, специфікація та документація API","/csharp/aspnet/api/openapi","01.csharp/11.aspnet/02.api/14.openapi",{"title":792,"icon":793,"path":794,"stem":795,"children":796,"page":59},"Auth","i-lucide-shield-check","/csharp/aspnet/auth","01.csharp/11.aspnet/03.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},"Основи аутентифікації та авторизації","/csharp/aspnet/auth/auth-fundamentals","01.csharp/11.aspnet/03.auth/01.auth-fundamentals",{"title":802,"path":803,"stem":804},"JWT-аутентифікація","/csharp/aspnet/auth/jwt-authentication","01.csharp/11.aspnet/03.auth/02.jwt-authentication",{"title":806,"path":807,"stem":808},"Авторизація: ролі, політики та resource-based доступ","/csharp/aspnet/auth/authorization-policies","01.csharp/11.aspnet/03.auth/03.authorization-policies",{"title":810,"path":811,"stem":812},"Cookie-аутентифікація та ASP.NET Core Identity","/csharp/aspnet/auth/cookie-auth-identity","01.csharp/11.aspnet/03.auth/04.cookie-auth-identity",{"title":814,"path":815,"stem":816},"JWT + Refresh Tokens (HttpOnly Cookie)","/csharp/aspnet/auth/04b.identity-auth-jwt","01.csharp/11.aspnet/03.auth/04b.identity-auth-jwt",{"title":818,"path":819,"stem":820},"Identity: Підтвердження Email та Скидання Пароля","/csharp/aspnet/auth/identity-email-confirmation","01.csharp/11.aspnet/03.auth/05.identity-email-confirmation",{"title":822,"path":823,"stem":824},"Identity: Двофакторна Аутентифікація (2FA)","/csharp/aspnet/auth/identity-two-factor","01.csharp/11.aspnet/03.auth/06.identity-two-factor",{"title":826,"path":827,"stem":828},"Identity: Внутрішня Архітектура та Кастомізація","/csharp/aspnet/auth/identity-internals","01.csharp/11.aspnet/03.auth/07.identity-internals",{"title":830,"path":831,"stem":832},"OAuth 2.0 та зовнішні провайдери","/csharp/aspnet/auth/oauth-external-providers","01.csharp/11.aspnet/03.auth/08.oauth-external-providers",{"title":834,"path":835,"stem":836},"Безпека на практиці: CORS, HTTPS та захист від атак","/csharp/aspnet/auth/security-hardening","01.csharp/11.aspnet/03.auth/09.security-hardening",{"title":838,"path":839,"stem":840},"Теорія OAuth 2.0: Поняття, Аналогії та Флоу","/csharp/aspnet/auth/oauth-theory","01.csharp/11.aspnet/03.auth/10.oauth-theory",{"title":842,"path":843,"stem":844},"OIDC, OAuth 2.0 та Keycloak в ASP.NET Core","/csharp/aspnet/auth/oidc-keycloak","01.csharp/11.aspnet/03.auth/10.oidc-keycloak",{"title":846,"path":847,"stem":848},"API Keys аутентифікація в ASP.NET Core","/csharp/aspnet/auth/api-keys","01.csharp/11.aspnet/03.auth/11.api-keys",{"title":850,"path":851,"stem":852},"Rate Limiting та Throttling в ASP.NET Core","/csharp/aspnet/auth/rate-limiting","01.csharp/11.aspnet/03.auth/12.rate-limiting",{"title":854,"path":855,"stem":856},"Refresh Token Rotation в ASP.NET Core","/csharp/aspnet/auth/refresh-token-rotation","01.csharp/11.aspnet/03.auth/13.refresh-token-rotation",{"title":858,"path":859,"stem":860},"Certificate Authentication та mTLS в ASP.NET Core","/csharp/aspnet/auth/certificate-auth","01.csharp/11.aspnet/03.auth/14.certificate-auth",{"title":862,"path":863,"stem":864},"RBAC, ABAC та ReBAC в ASP.NET Core","/csharp/aspnet/auth/rbac-abac-rebac","01.csharp/11.aspnet/03.auth/15.rbac-abac-rebac",{"title":866,"path":867,"stem":868},"Multi-tenancy та ізоляція даних в ASP.NET Core","/csharp/aspnet/auth/multi-tenancy","01.csharp/11.aspnet/03.auth/16.multi-tenancy",{"title":870,"icon":871,"path":872,"stem":873,"children":874,"page":59},"Нотифікації","i-lucide-bell","/csharp/aspnet/notifications","01.csharp/11.aspnet/04.notifications",[875,879,883,887,891,895,899,903,907,911,915,919,923],{"title":876,"path":877,"stem":878},"In-App нотифікації через базу даних","/csharp/aspnet/notifications/in-app-database-notifications","01.csharp/11.aspnet/04.notifications/01.in-app-database-notifications",{"title":880,"path":881,"stem":882},"Polling: Регулярний запит оновлень","/csharp/aspnet/notifications/polling","01.csharp/11.aspnet/04.notifications/02.polling",{"title":884,"path":885,"stem":886},"Server-Sent Events: Однострімовий push від сервера","/csharp/aspnet/notifications/server-sent-events","01.csharp/11.aspnet/04.notifications/03.server-sent-events",{"title":888,"path":889,"stem":890},"WebSockets: Двостороннє з'єднання в реальному часі","/csharp/aspnet/notifications/websockets","01.csharp/11.aspnet/04.notifications/04.websockets",{"title":892,"path":893,"stem":894},"SignalR: Абстракція над транспортами реального часу","/csharp/aspnet/notifications/signalr","01.csharp/11.aspnet/04.notifications/05.signalr",{"title":896,"path":897,"stem":898},"Background Services: Фонові задачі в ASP.NET Core","/csharp/aspnet/notifications/background-services","01.csharp/11.aspnet/04.notifications/06.background-services",{"title":900,"path":901,"stem":902},"Web Push нотифікації","/csharp/aspnet/notifications/web-push","01.csharp/11.aspnet/04.notifications/07.web-push",{"title":904,"path":905,"stem":906},"Email нотифікації","/csharp/aspnet/notifications/email-notifications","01.csharp/11.aspnet/04.notifications/08.email-notifications",{"title":908,"path":909,"stem":910},"Порівняння підходів: Як вибрати правильну технологію нотифікацій","/csharp/aspnet/notifications/choosing-the-right-approach","01.csharp/11.aspnet/04.notifications/09.choosing-the-right-approach",{"title":912,"path":913,"stem":914},"Hangfire: Надійне планування фонових задач","/csharp/aspnet/notifications/hangfire","01.csharp/11.aspnet/04.notifications/10.hangfire",{"title":916,"path":917,"stem":918},"Практика: Конвертація зображень у WebP через Hangfire","/csharp/aspnet/notifications/hangfire-image-webp","01.csharp/11.aspnet/04.notifications/11.hangfire-image-webp",{"title":920,"path":921,"stem":922},"Практика: Підготовка відео до HLS-стрімінгу через Hangfire","/csharp/aspnet/notifications/hangfire-video-hls","01.csharp/11.aspnet/04.notifications/12.hangfire-video-hls",{"title":924,"path":925,"stem":926},"Telegram-нотифікації: від одного повідомлення до масових розсилок і мульти-канального підходу","/csharp/aspnet/notifications/telegram-notifications","01.csharp/11.aspnet/04.notifications/13.telegram-notifications",{"title":928,"icon":929,"path":930,"stem":931,"children":932,"page":59},"Інтернаціоналізація","i-lucide-languages","/csharp/aspnet/i18n","01.csharp/11.aspnet/05.i18n",[933,937],{"title":934,"path":935,"stem":936},"Інтернаціоналізація (i18n) у Minimal API: від A до Я","/csharp/aspnet/i18n/internationalization","01.csharp/11.aspnet/05.i18n/01.internationalization",{"title":938,"path":939,"stem":940},"Humanizer: людиномовні рядки у .NET","/csharp/aspnet/i18n/humanizer","01.csharp/11.aspnet/05.i18n/02.humanizer",{"title":942,"icon":943,"path":944,"stem":945,"children":946,"page":59},"Кешування","i-lucide-layers","/csharp/aspnet/caching","01.csharp/11.aspnet/06.caching",[947,951,955,959,963],{"title":948,"path":949,"stem":950},"Огляд кешування: чотири рівні і коли що обирати","/csharp/aspnet/caching/caching","01.csharp/11.aspnet/06.caching/01.caching",{"title":952,"path":953,"stem":954},"IMemoryCache: кеш в оперативній пам'яті","/csharp/aspnet/caching/memory-cache","01.csharp/11.aspnet/06.caching/02.memory-cache",{"title":956,"path":957,"stem":958},"IDistributedCache і Redis: розподілений кеш","/csharp/aspnet/caching/distributed-cache","01.csharp/11.aspnet/06.caching/03.distributed-cache",{"title":960,"path":961,"stem":962},"Response Cache: HTTP-кешування через Cache-Control","/csharp/aspnet/caching/response-cache","01.csharp/11.aspnet/06.caching/04.response-cache",{"title":964,"path":965,"stem":966},"Output Cache: серверний кеш HTTP-відповідей (.NET 7+)","/csharp/aspnet/caching/output-cache","01.csharp/11.aspnet/06.caching/05.output-cache",{"title":968,"icon":969,"path":970,"stem":971,"children":972,"page":59},"Тестування","i-lucide-test-tube","/csharp/aspnet/testing","01.csharp/11.aspnet/07.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},"Що таке тестування? Від інтуїції до науки","/csharp/aspnet/testing/what-is-testing","01.csharp/11.aspnet/07.testing/01.what-is-testing",{"title":978,"path":979,"stem":980},"Піраміда тестування — Стратегія, а не Догма","/csharp/aspnet/testing/testing-pyramid","01.csharp/11.aspnet/07.testing/02.testing-pyramid",{"title":982,"path":983,"stem":984},"Дві Школи Тестування — Лондон проти Детройту","/csharp/aspnet/testing/testing-schools","01.csharp/11.aspnet/07.testing/03.testing-schools",{"title":986,"path":987,"stem":988},"TDD та BDD — Тести як Дизайн-інструмент","/csharp/aspnet/testing/tdd-and-bdd","01.csharp/11.aspnet/07.testing/04.tdd-and-bdd",{"title":990,"path":991,"stem":992},"Що саме тестувати — Техніки аналізу та Циклomatична складність","/csharp/aspnet/testing/what-to-test","01.csharp/11.aspnet/07.testing/05.what-to-test",{"title":994,"path":995,"stem":996},"Тестові Фреймворки — Навіщо вони і що всередині","/csharp/aspnet/testing/test-frameworks","01.csharp/11.aspnet/07.testing/06.test-frameworks",{"title":998,"path":999,"stem":1000},"xUnit — Факти, Теорії та Lifecycle тестів","/csharp/aspnet/testing/xunit-basics","01.csharp/11.aspnet/07.testing/07.xunit-basics",{"title":1002,"path":1003,"stem":1004},"xUnit Advanced — Fixtures, Кастомізація та Розширення","/csharp/aspnet/testing/xunit-advanced","01.csharp/11.aspnet/07.testing/08.xunit-advanced",{"title":1006,"path":1007,"stem":1008},"Moq — Глибоке занурення в мокування","/csharp/aspnet/testing/mocking-with-moq","01.csharp/11.aspnet/07.testing/09.mocking-with-moq",{"title":1010,"path":1011,"stem":1012},"Тестування Баз Даних — EF Core, SQLite та Testcontainers","/csharp/aspnet/testing/database-testing","01.csharp/11.aspnet/07.testing/10.database-testing",{"title":1014,"path":1015,"stem":1016},"Integration Testing — Частина 1 [Теорія та WebApplicationFactory]","/csharp/aspnet/testing/integration-testing","01.csharp/11.aspnet/07.testing/11.integration-testing",{"title":1018,"path":1019,"stem":1020},"Інтеграційне тестування — Практика","/csharp/aspnet/testing/11a.integration-testing-practice","01.csharp/11.aspnet/07.testing/11a.integration-testing-practice",{"title":1022,"path":1023,"stem":1024},"Integration Testing — Частина 2 [Просунуті Сценарії та Testcontainers]","/csharp/aspnet/testing/integration-testing-advanced","01.csharp/11.aspnet/07.testing/12.integration-testing-advanced",{"title":1026,"path":1027,"stem":1028},"Професійний Postman: Колекції, Змінні та GitHub Інтеграція","/csharp/aspnet/testing/postman-professional","01.csharp/11.aspnet/07.testing/13.postman-professional",{"title":1030,"path":1031,"stem":1032},"HttpClient у Тестах Частина 1: Архітектура та MockHttpMessageHandler","/csharp/aspnet/testing/httpclient-testing","01.csharp/11.aspnet/07.testing/14.httpclient-testing",{"title":1034,"path":1035,"stem":1036},"HttpClient у Тестах Частина 2: WireMock.Net та Resilience","/csharp/aspnet/testing/wiremock-net","01.csharp/11.aspnet/07.testing/15.wiremock-net",{"title":1038,"path":1039,"stem":1040},"Патерни та Анти-патерни Тестування: Test Smells","/csharp/aspnet/testing/testing-patterns","01.csharp/11.aspnet/07.testing/16.testing-patterns",{"title":1042,"path":1043,"stem":1044},"Просунуті інструменти: Time, Snapshots та Властивості","/csharp/aspnet/testing/advanced-testing-tools","01.csharp/11.aspnet/07.testing/17.advanced-testing-tools",{"title":1046,"path":1047,"stem":1048},"Тестування Архітектури з NetArchTest","/csharp/aspnet/testing/architecture-testing","01.csharp/11.aspnet/07.testing/18.architecture-testing",{"title":1050,"path":1051,"stem":1052},"Тестування Продуктивності: BenchmarkDotNet, NBomber та k6","/csharp/aspnet/testing/performance-testing","01.csharp/11.aspnet/07.testing/19.performance-testing",{"title":1054,"path":1055,"stem":1056},"Залишок плану для курсу \"Тестування ASP.NET Minimal API\"","/csharp/aspnet/testing/remaining_plan","01.csharp/11.aspnet/07.testing/remaining_plan",{"title":1058,"icon":1059,"path":1060,"stem":1061,"children":1062,"page":59},"Платежі","i-lucide-credit-card","/csharp/aspnet/payments","01.csharp/11.aspnet/08.payments",[1063,1067,1071,1075,1079,1083,1087,1091,1095,1099,1103,1107],{"title":1064,"path":1065,"stem":1066},"Основи платіжної інфраструктури","/csharp/aspnet/payments/payment-fundamentals","01.csharp/11.aspnet/08.payments/01.payment-fundamentals",{"title":1068,"path":1069,"stem":1070},"Методи оплати в Україні","/csharp/aspnet/payments/payment-methods-ukraine","01.csharp/11.aspnet/08.payments/02.payment-methods-ukraine",{"title":1072,"path":1073,"stem":1074},"PCI DSS та безпека платежів","/csharp/aspnet/payments/pci-dss-security","01.csharp/11.aspnet/08.payments/03.pci-dss-security",{"title":1076,"path":1077,"stem":1078},"Архітектура платіжної підсистеми","/csharp/aspnet/payments/payment-architecture","01.csharp/11.aspnet/08.payments/04.payment-architecture",{"title":1080,"path":1081,"stem":1082},"Інтеграція LiqPay (ПриватБанк)","/csharp/aspnet/payments/liqpay-integration","01.csharp/11.aspnet/08.payments/05.liqpay-integration",{"title":1084,"path":1085,"stem":1086},"Інтеграція Monobank Acquiring API","/csharp/aspnet/payments/monobank-acquiring","01.csharp/11.aspnet/08.payments/06.monobank-acquiring",{"title":1088,"path":1089,"stem":1090},"Інтеграція Stripe","/csharp/aspnet/payments/stripe-integration","01.csharp/11.aspnet/08.payments/07.stripe-integration",{"title":1092,"path":1093,"stem":1094},"Webhooks — глибоке занурення","/csharp/aspnet/payments/webhooks-deep-dive","01.csharp/11.aspnet/08.payments/08.webhooks-deep-dive",{"title":1096,"path":1097,"stem":1098},"Підписки та рекурентні платежі","/csharp/aspnet/payments/subscriptions-recurring","01.csharp/11.aspnet/08.payments/09.subscriptions-recurring",{"title":1100,"path":1101,"stem":1102},"Повернення коштів та диспути","/csharp/aspnet/payments/refunds-disputes","01.csharp/11.aspnet/08.payments/10.refunds-disputes",{"title":1104,"path":1105,"stem":1106},"Тестування платіжних інтеграцій","/csharp/aspnet/payments/testing-payments","01.csharp/11.aspnet/08.payments/11.testing-payments",{"title":1108,"path":1109,"stem":1110},"Чекліст виходу в Production","/csharp/aspnet/payments/production-checklist","01.csharp/11.aspnet/08.payments/12.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","/csharp/aspnet/libraries","01.csharp/11.aspnet/09.libraries",[1130,1134,1138,1142,1146,1150,1154,1158,1162,1166,1170,1174,1178],{"title":1131,"path":1132,"stem":1133},"Валідація з FluentValidation в ASP.NET Core","/csharp/aspnet/libraries/fluent-validation","01.csharp/11.aspnet/09.libraries/01.fluent-validation",{"title":1135,"path":1136,"stem":1137},"Маппінг об","/csharp/aspnet/libraries/mapster","01.csharp/11.aspnet/09.libraries/02.mapster",{"title":1139,"path":1140,"stem":1141},"Обробка помилок з ErrorOr та Result Pattern в ASP.NET Core","/csharp/aspnet/libraries/erroror-result-pattern","01.csharp/11.aspnet/09.libraries/03.erroror-result-pattern",{"title":1143,"path":1144,"stem":1145},"Структуроване логування з Serilog в ASP.NET Core","/csharp/aspnet/libraries/serilog","01.csharp/11.aspnet/09.libraries/04.serilog",{"title":1147,"path":1148,"stem":1149},"CQRS та Mediator з MediatR в ASP.NET Core","/csharp/aspnet/libraries/mediatr","01.csharp/11.aspnet/09.libraries/05.mediatr",{"title":1151,"path":1152,"stem":1153},"Відмовостійкість з Polly в ASP.NET Core","/csharp/aspnet/libraries/polly","01.csharp/11.aspnet/09.libraries/06.polly",{"title":1155,"path":1156,"stem":1157},"Health Checks в ASP.NET Core","/csharp/aspnet/libraries/health-checks","01.csharp/11.aspnet/09.libraries/07.health-checks",{"title":1159,"path":1160,"stem":1161},"Feature Management та Feature Flags в ASP.NET Core","/csharp/aspnet/libraries/feature-management","01.csharp/11.aspnet/09.libraries/08.feature-management",{"title":1163,"path":1164,"stem":1165},"Відправка Email з FluentEmail в ASP.NET Core","/csharp/aspnet/libraries/fluent-email","01.csharp/11.aspnet/09.libraries/09.fluent-email",{"title":1167,"path":1168,"stem":1169},"Генерація PDF з QuestPDF в ASP.NET Core","/csharp/aspnet/libraries/quest-pdf","01.csharp/11.aspnet/09.libraries/10.quest-pdf",{"title":1171,"path":1172,"stem":1173},"Генерація тестових даних з Bogus в ASP.NET Core","/csharp/aspnet/libraries/bogus","01.csharp/11.aspnet/09.libraries/11.bogus",{"title":1175,"path":1176,"stem":1177},"Humanizer та Guard Clauses в ASP.NET Core","/csharp/aspnet/libraries/humanizer-guard","01.csharp/11.aspnet/09.libraries/12.humanizer-guard",{"title":1179,"path":1180,"stem":1181},"План модуля 10.libraries — Популярні бібліотеки ASP.NET","/csharp/aspnet/libraries/plan","01.csharp/11.aspnet/09.libraries/plan",{"title":1183,"icon":1184,"path":1185,"stem":1186,"children":1187,"page":59},"Razor Pages","i-lucide-layout-template","/csharp/aspnet/razor-pages","01.csharp/11.aspnet/10.razor-pages",[1188,1192,1196,1200,1204,1208],{"title":1189,"path":1190,"stem":1191},"Від Minimal API до Razor Pages: концептуальний перехід","/csharp/aspnet/razor-pages/from-minimal-api","01.csharp/11.aspnet/10.razor-pages/01.from-minimal-api",{"title":1193,"path":1194,"stem":1195},"PageModel: логіка сторінки Razor Pages","/csharp/aspnet/razor-pages/page-model","01.csharp/11.aspnet/10.razor-pages/02.page-model",{"title":1197,"path":1198,"stem":1199},"Razor синтаксис: шаблонізатор у .cshtml","/csharp/aspnet/razor-pages/razor-syntax","01.csharp/11.aspnet/10.razor-pages/03.razor-syntax",{"title":1201,"path":1202,"stem":1203},"Tag Helpers: типізований HTML","/csharp/aspnet/razor-pages/tag-helpers","01.csharp/11.aspnet/10.razor-pages/04.tag-helpers",{"title":1205,"path":1206,"stem":1207},"Форми і валідація: повний цикл обробки даних","/csharp/aspnet/razor-pages/forms-validation","01.csharp/11.aspnet/10.razor-pages/05.forms-validation",{"title":1209,"path":1210,"stem":1211},"Практичний проєкт: TaskManager на Razor Pages","/csharp/aspnet/razor-pages/project-task-manager","01.csharp/11.aspnet/10.razor-pages/06.project-task-manager",{"title":1213,"path":1214,"stem":1215,"children":1216,"page":59},"ASP.NET Core MVC","/csharp/aspnet/mvc","01.csharp/11.aspnet/11.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: архітектура, що змінила веб","/csharp/aspnet/mvc/mvc-pattern","01.csharp/11.aspnet/11.mvc/01.mvc-pattern",{"title":1222,"path":1223,"stem":1224},"Від Razor Pages до MVC: концептуальний перехід","/csharp/aspnet/mvc/from-razor-pages","01.csharp/11.aspnet/11.mvc/02.from-razor-pages",{"title":1226,"path":1227,"stem":1228},"Controllers та Actions: серце MVC","/csharp/aspnet/mvc/controllers-actions","01.csharp/11.aspnet/11.mvc/03.controllers-actions",{"title":1230,"path":1231,"stem":1232},"Маршрутизація в MVC: Convention vs Attribute Routing","/csharp/aspnet/mvc/routing-mvc","01.csharp/11.aspnet/11.mvc/04.routing-mvc",{"title":1234,"path":1235,"stem":1236},"Model Binding: від HTTP до C#","/csharp/aspnet/mvc/model-binding","01.csharp/11.aspnet/11.mvc/05.model-binding",{"title":1238,"path":1239,"stem":1240},"Views, ViewData, ViewBag, TempData і ViewModel","/csharp/aspnet/mvc/views-viewdata-tempdata","01.csharp/11.aspnet/11.mvc/06.views-viewdata-tempdata",{"title":1242,"path":1243,"stem":1244},"Filters: аспектно-орієнтоване програмування в MVC","/csharp/aspnet/mvc/filters","01.csharp/11.aspnet/11.mvc/07.filters",{"title":1246,"path":1247,"stem":1248},"Areas: структурування великих застосунків","/csharp/aspnet/mvc/areas","01.csharp/11.aspnet/11.mvc/08.areas",{"title":1250,"path":1251,"stem":1252},"View Components: повторювані незалежні блоки UI","/csharp/aspnet/mvc/view-components","01.csharp/11.aspnet/11.mvc/09.view-components",{"title":1254,"path":1255,"stem":1256},"Display та Editor Templates","/csharp/aspnet/mvc/display-editor-templates","01.csharp/11.aspnet/11.mvc/10.display-editor-templates",{"title":1258,"path":1259,"stem":1260},"Валідація: IValidatableObject та FluentValidation","/csharp/aspnet/mvc/validation-advanced","01.csharp/11.aspnet/11.mvc/11.validation-advanced",{"title":1262,"path":1263,"stem":1264},"HTMX: інтерактивність через HTML-атрибути","/csharp/aspnet/mvc/htmx","01.csharp/11.aspnet/11.mvc/12.htmx",{"title":1266,"path":1267,"stem":1268},"HTMX у ASP.NET Core MVC: серверна інтеграція","/csharp/aspnet/mvc/ajax-htmx-mvc","01.csharp/11.aspnet/11.mvc/13.ajax-htmx-mvc",{"title":1270,"path":1271,"stem":1272},"Практичний проєкт: Каталог товарів з HTMX","/csharp/aspnet/mvc/htmx-project","01.csharp/11.aspnet/11.mvc/14.htmx-project",{"title":1274,"path":1275,"stem":1276},"Завантаження та обробка файлів","/csharp/aspnet/mvc/file-upload","01.csharp/11.aspnet/11.mvc/15.file-upload",{"title":1278,"path":1279,"stem":1280},"Глобалізація та Локалізація MVC","/csharp/aspnet/mvc/globalization-localization","01.csharp/11.aspnet/11.mvc/16.globalization-localization",{"title":1282,"path":1283,"stem":1284},"Підсумковий проєкт: Блог-платформа","/csharp/aspnet/mvc/mvc-project","01.csharp/11.aspnet/11.mvc/17.mvc-project",{"title":1286,"path":1287,"stem":1288},"План курсу: ASP.NET Core MVC","/csharp/aspnet/mvc/plan","01.csharp/11.aspnet/11.mvc/plan",{"title":1290,"path":1291,"stem":1292,"children":1293,"page":59},"Web Api","/csharp/aspnet/web-api","01.csharp/11.aspnet/12.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","/csharp/aspnet/web-api/from-minimal-api-to-controllers","01.csharp/11.aspnet/12.web-api/01.from-minimal-api-to-controllers",{"title":1299,"path":1300,"stem":1301},"ControllerBase, ActionResult\u003CT> та Response Types","/csharp/aspnet/web-api/controller-base-actionresult","01.csharp/11.aspnet/12.web-api/02.controller-base-actionresult",{"title":1303,"path":1304,"stem":1305},"Content Negotiation - JSON, XML та власні форматери","/csharp/aspnet/web-api/content-negotiation","01.csharp/11.aspnet/12.web-api/03.content-negotiation",{"title":1307,"path":1308,"stem":1309},"Версіонування API","/csharp/aspnet/web-api/api-versioning","01.csharp/11.aspnet/12.web-api/04.api-versioning",{"title":1311,"path":1312,"stem":1313},"ProblemDetails та структурована обробка помилок","/csharp/aspnet/web-api/problemdetails-error-handling","01.csharp/11.aspnet/12.web-api/05.problemdetails-error-handling",{"title":1315,"path":1316,"stem":1317},"Фільтри у Web API контексті","/csharp/aspnet/web-api/filters-for-api","01.csharp/11.aspnet/12.web-api/06.filters-for-api",{"title":1319,"path":1320,"stem":1321},"Пагінація, фільтрація та сортування","/csharp/aspnet/web-api/pagination-filtering-sorting","01.csharp/11.aspnet/12.web-api/07.pagination-filtering-sorting",{"title":1323,"path":1324,"stem":1325},"HATEOAS та Resource Expansion","/csharp/aspnet/web-api/hateoas-resource-expansion","01.csharp/11.aspnet/12.web-api/08.hateoas-resource-expansion",{"title":1327,"path":1328,"stem":1329},"Гібридна архітектура - Minimal API + Controllers","/csharp/aspnet/web-api/minimal-api-vs-controllers-hybrid","01.csharp/11.aspnet/12.web-api/09.minimal-api-vs-controllers-hybrid",{"title":1331,"path":1332,"stem":1333},"Документація API - Swashbuckle, NSwag та генерація клієнтів","/csharp/aspnet/web-api/api-documentation-generation","01.csharp/11.aspnet/12.web-api/10.api-documentation-generation",{"title":1335,"path":1336,"stem":1337},"Health Checks та моніторинг API","/csharp/aspnet/web-api/health-checks-monitoring","01.csharp/11.aspnet/12.web-api/11.health-checks-monitoring",{"title":1339,"path":1340,"stem":1341},"Підсумковий проєкт - Production-Ready REST API","/csharp/aspnet/web-api/web-api-project","01.csharp/11.aspnet/12.web-api/12.web-api-project",{"title":1343,"path":1344,"stem":1345},"План курсу: ASP.NET Core Web API (Controllers)","/csharp/aspnet/web-api/plan","01.csharp/11.aspnet/12.web-api/plan",{"title":1347,"icon":1348,"path":1349,"stem":1350,"children":1351,"page":59},"Desktop UI","i-lucide-app-window","/csharp/desktop-ui","01.csharp/12.desktop-ui",[1352,1356,1360,1364,1368,1372,1376,1380,1384,1388,1392,1396,1400,1404,1408,1412,1416,1420,1424,1428,1432,1436,1440,1444,1448,1452,1456,1460,1464,1468,1472,1476,1480,1484,1488,1492,1496,1500,1504,1508,1512,1516,1520,1524,1528,1532,1536,1540,1544,1548,1552,1556,1560,1564,1568,1572,1576,1580,1584,1588,1592,1596,1600,1604,1608,1612,1616,1620,1624,1628,1632],{"title":1353,"path":1354,"stem":1355},"Що таке десктопна розробка?","/csharp/desktop-ui/what-is-desktop-dev","01.csharp/12.desktop-ui/01.what-is-desktop-dev",{"title":1357,"path":1358,"stem":1359},"Архітектура WPF — як влаштований графічний інтерфейс","/csharp/desktop-ui/wpf-architecture","01.csharp/12.desktop-ui/02.wpf-architecture",{"title":1361,"path":1362,"stem":1363},"Перший WPF-проєкт — від нуля до вікна","/csharp/desktop-ui/first-wpf-app","01.csharp/12.desktop-ui/03.first-wpf-app",{"title":1365,"path":1366,"stem":1367},"Перший Avalonia-проєкт: WPF для всіх платформ","/csharp/desktop-ui/03a.first-avalonia-app","01.csharp/12.desktop-ui/03a.first-avalonia-app",{"title":1369,"path":1370,"stem":1371},"XAML: декларативний інтерфейс","/csharp/desktop-ui/xaml-basics","01.csharp/12.desktop-ui/04.xaml-basics",{"title":1373,"path":1374,"stem":1375},"Fluent UI у WPF — сучасний дизайн Windows 11","/csharp/desktop-ui/04a.wpf-fluent-ui","01.csharp/12.desktop-ui/04a.wpf-fluent-ui",{"title":1377,"path":1378,"stem":1379},"WPF UI — сучасна бібліотека Fluent контролів","/csharp/desktop-ui/04b.wpf-ui-library","01.csharp/12.desktop-ui/04b.wpf-ui-library",{"title":1381,"path":1382,"stem":1383},"HandyControl — велика бібліотека UI контролів для WPF","/csharp/desktop-ui/04c.handycontrol-library","01.csharp/12.desktop-ui/04c.handycontrol-library",{"title":1385,"path":1386,"stem":1387},"Простори імен та ресурси XAML","/csharp/desktop-ui/xaml-namespaces-resources","01.csharp/12.desktop-ui/05.xaml-namespaces-resources",{"title":1389,"path":1390,"stem":1391},"XAML в Avalonia: ключові відмінності від WPF","/csharp/desktop-ui/05a.avalonia-xaml-differences","01.csharp/12.desktop-ui/05a.avalonia-xaml-differences",{"title":1393,"path":1394,"stem":1395},"Розширення розмітки XAML (Markup Extensions)","/csharp/desktop-ui/xaml-markup-extensions","01.csharp/12.desktop-ui/06.xaml-markup-extensions",{"title":1397,"path":1398,"stem":1399},"Панелі Layout: StackPanel, WrapPanel, DockPanel","/csharp/desktop-ui/layout-panels-part1","01.csharp/12.desktop-ui/07.layout-panels-part1",{"title":1401,"path":1402,"stem":1403},"Grid, Canvas, UniformGrid","/csharp/desktop-ui/layout-panels-part2","01.csharp/12.desktop-ui/07.layout-panels-part2",{"title":1405,"path":1406,"stem":1407},"Просунуті техніки Layout","/csharp/desktop-ui/layout-advanced","01.csharp/12.desktop-ui/08.layout-advanced",{"title":1409,"path":1410,"stem":1411},"Адаптивний Layout та найкращі практики","/csharp/desktop-ui/layout-responsive","01.csharp/12.desktop-ui/09.layout-responsive",{"title":1413,"path":1414,"stem":1415},"Layout в Avalonia: відмінності та нові можливості","/csharp/desktop-ui/09a.layout-avalonia","01.csharp/12.desktop-ui/09a.layout-avalonia",{"title":1417,"path":1418,"stem":1419},"Button, Image, ProgressBar та інші базові контроли","/csharp/desktop-ui/basic-controls","01.csharp/12.desktop-ui/10.basic-controls",{"title":1421,"path":1422,"stem":1423},"Контроли в Avalonia: відмінності від WPF","/csharp/desktop-ui/10a.controls-avalonia","01.csharp/12.desktop-ui/10a.controls-avalonia",{"title":1425,"path":1426,"stem":1427},"Текстові контроли — TextBlock, TextBox, RichTextBox","/csharp/desktop-ui/text-controls","01.csharp/12.desktop-ui/11.text-controls",{"title":1429,"path":1430,"stem":1431},"Контроли вибору — CheckBox, RadioButton, ComboBox, ListBox, DatePicker","/csharp/desktop-ui/selection-controls","01.csharp/12.desktop-ui/12.selection-controls",{"title":1433,"path":1434,"stem":1435},"Content Model — GroupBox, Expander, TabControl, StatusBar","/csharp/desktop-ui/content-controls","01.csharp/12.desktop-ui/13.content-controls",{"title":1437,"path":1438,"stem":1439},"UI/UX принципи десктопних застосунків","/csharp/desktop-ui/13a.ui-ux-principles","01.csharp/12.desktop-ui/13a.ui-ux-principles",{"title":1441,"path":1442,"stem":1443},"Dependency Properties — Концепція та Value Resolution","/csharp/desktop-ui/dependency-properties-part1","01.csharp/12.desktop-ui/14.dependency-properties-part1",{"title":1445,"path":1446,"stem":1447},"Avalonia Property System — StyledProperty та DirectProperty","/csharp/desktop-ui/14a.avalonia-property-system","01.csharp/12.desktop-ui/14a.avalonia-property-system",{"title":1449,"path":1450,"stem":1451},"Attached Properties — Властивості без меж","/csharp/desktop-ui/attached-properties","01.csharp/12.desktop-ui/15.attached-properties",{"title":1453,"path":1454,"stem":1455},"Routed Events — Маршрутизація подій у WPF","/csharp/desktop-ui/routed-events","01.csharp/12.desktop-ui/16.routed-events",{"title":1457,"path":1458,"stem":1459},"Data Binding — Від Code-Behind до Декларативності","/csharp/desktop-ui/data-binding-basics-part1","01.csharp/12.desktop-ui/17.data-binding-basics-part1",{"title":1461,"path":1462,"stem":1463},"INotifyPropertyChanged — Живе оновлення UI","/csharp/desktop-ui/data-binding-basics-part2","01.csharp/12.desktop-ui/17.data-binding-basics-part2",{"title":1465,"path":1466,"stem":1467},"Compiled Bindings в Avalonia — Безпека на етапі компіляції","/csharp/desktop-ui/17a.avalonia-compiled-bindings","01.csharp/12.desktop-ui/17a.avalonia-compiled-bindings",{"title":1469,"path":1470,"stem":1471},"Просунутий Data Binding — ElementName, RelativeSource, MultiBinding","/csharp/desktop-ui/data-binding-advanced","01.csharp/12.desktop-ui/18.data-binding-advanced",{"title":1473,"path":1474,"stem":1475},"Value Converters — Перетворення типів даних у Data Binding","/csharp/desktop-ui/value-converters","01.csharp/12.desktop-ui/19.value-converters",{"title":1477,"path":1478,"stem":1479},"Data Templates — Візуалізація об'єктів у WPF","/csharp/desktop-ui/data-templates","01.csharp/12.desktop-ui/20.data-templates",{"title":1481,"path":1482,"stem":1483},"Collections Binding Part 1 — ObservableCollection та ItemsControl","/csharp/desktop-ui/collections-binding-part1","01.csharp/12.desktop-ui/21.collections-binding-part1",{"title":1485,"path":1486,"stem":1487},"Collections Binding Part 2 — ICollectionView, Filtering, Sorting та Virtualization","/csharp/desktop-ui/collections-binding-part2","01.csharp/12.desktop-ui/21.collections-binding-part2",{"title":1489,"path":1490,"stem":1491},"MVVM Pattern — Від Spaghetti Code до архітектури","/csharp/desktop-ui/mvvm-pattern","01.csharp/12.desktop-ui/22.mvvm-pattern",{"title":1493,"path":1494,"stem":1495},"ViewModel Implementation — Від BaseViewModel до валідації","/csharp/desktop-ui/viewmodel-implementation","01.csharp/12.desktop-ui/23.viewmodel-implementation",{"title":1497,"path":1498,"stem":1499},"Commands — Від event handlers до декларативних команд","/csharp/desktop-ui/commands","01.csharp/12.desktop-ui/24.commands",{"title":1501,"path":1502,"stem":1503},"MVVM Toolkit — MVVM без boilerplate через Source Generators","/csharp/desktop-ui/mvvm-toolkit","01.csharp/12.desktop-ui/25.mvvm-toolkit",{"title":1505,"path":1506,"stem":1507},"Messenger Pattern — Комунікація між ViewModel без прямих посилань","/csharp/desktop-ui/messenger-pattern","01.csharp/12.desktop-ui/26.messenger-pattern",{"title":1509,"path":1510,"stem":1511},"Стилі WPF — CSS для десктопу","/csharp/desktop-ui/styles-basics","01.csharp/12.desktop-ui/27.styles-basics",{"title":1513,"path":1514,"stem":1515},"CSS-like стилі Avalonia","/csharp/desktop-ui/27a.avalonia-css-styling","01.csharp/12.desktop-ui/27a.avalonia-css-styling",{"title":1517,"path":1518,"stem":1519},"Control Templates — Частина 1. Концепція та TemplateBinding","/csharp/desktop-ui/control-templates-part1","01.csharp/12.desktop-ui/28.control-templates-part1",{"title":1521,"path":1522,"stem":1523},"Control Templates — Частина 2. Named Parts та ContentPresenter","/csharp/desktop-ui/control-templates-part2","01.csharp/12.desktop-ui/28.control-templates-part2",{"title":1525,"path":1526,"stem":1527},"Control Themes в Avalonia — нова ера стилізації","/csharp/desktop-ui/28a.avalonia-control-themes","01.csharp/12.desktop-ui/28a.avalonia-control-themes",{"title":1529,"path":1530,"stem":1531},"Triggers та Visual State Manager у WPF","/csharp/desktop-ui/triggers-visual-states","01.csharp/12.desktop-ui/29.triggers-visual-states",{"title":1533,"path":1534,"stem":1535},"Pseudo-classes в Avalonia — замість WPF Triggers","/csharp/desktop-ui/29a.avalonia-pseudo-classes","01.csharp/12.desktop-ui/29a.avalonia-pseudo-classes",{"title":1537,"path":1538,"stem":1539},"Теми та ресурсні словники у WPF","/csharp/desktop-ui/resources-themes","01.csharp/12.desktop-ui/30.resources-themes",{"title":1541,"path":1542,"stem":1543},"Avalonia Themes — Fluent Design та система тематизації","/csharp/desktop-ui/30a.avalonia-themes-fluent","01.csharp/12.desktop-ui/30a.avalonia-themes-fluent",{"title":1545,"path":1546,"stem":1547},"Контроли колекцій — глибоке занурення","/csharp/desktop-ui/collection-controls","01.csharp/12.desktop-ui/31.collection-controls",{"title":1549,"path":1550,"stem":1551},"DataGrid — колонки та базове відображення","/csharp/desktop-ui/datagrid-part1","01.csharp/12.desktop-ui/32.datagrid-part1",{"title":1553,"path":1554,"stem":1555},"DataGrid — сортування, фільтрація, редагування","/csharp/desktop-ui/datagrid-part2","01.csharp/12.desktop-ui/32.datagrid-part2",{"title":1557,"path":1558,"stem":1559},"TreeView та GridView","/csharp/desktop-ui/treeview-listview","01.csharp/12.desktop-ui/33.treeview-listview",{"title":1561,"path":1562,"stem":1563},"Меню, Toolbar, ContextMenu, StatusBar","/csharp/desktop-ui/menus-toolbars","01.csharp/12.desktop-ui/34.menus-toolbars",{"title":1565,"path":1566,"stem":1567},"Навігація та керування вікнами. Частина 1: вікна та сторінки","/csharp/desktop-ui/navigation-windows-part1","01.csharp/12.desktop-ui/35.navigation-windows-part1",{"title":1569,"path":1570,"stem":1571},"Навігація та керування вікнами. Частина 2: MVVM-навігація","/csharp/desktop-ui/navigation-windows-part2","01.csharp/12.desktop-ui/35.navigation-windows-part2",{"title":1573,"path":1574,"stem":1575},"Avalonia — Навігація та діалоги","/csharp/desktop-ui/35a.avalonia-navigation-dialogs","01.csharp/12.desktop-ui/35a.avalonia-navigation-dialogs",{"title":1577,"path":1578,"stem":1579},"Діалоги та File Pickers у WPF","/csharp/desktop-ui/dialogs-file-pickers","01.csharp/12.desktop-ui/36.dialogs-file-pickers",{"title":1581,"path":1582,"stem":1583},"UserControl: компонентний підхід у WPF","/csharp/desktop-ui/user-controls","01.csharp/12.desktop-ui/37.user-controls",{"title":1585,"path":1586,"stem":1587},"Custom Controls: Lookless Controls у WPF","/csharp/desktop-ui/custom-controls","01.csharp/12.desktop-ui/38.custom-controls",{"title":1589,"path":1590,"stem":1591},"Avalonia TemplatedControl — Lookless Controls","/csharp/desktop-ui/38a.avalonia-templated-controls","01.csharp/12.desktop-ui/38a.avalonia-templated-controls",{"title":1593,"path":1594,"stem":1595},"Анімації у WPF: Storyboard та Easing Functions","/csharp/desktop-ui/animations-transitions","01.csharp/12.desktop-ui/39.animations-transitions",{"title":1597,"path":1598,"stem":1599},"Анімації в Avalonia","/csharp/desktop-ui/39a.avalonia-animations","01.csharp/12.desktop-ui/39a.avalonia-animations",{"title":1601,"path":1602,"stem":1603},"2D Графіка та Мультимедіа у WPF","/csharp/desktop-ui/media-graphics","01.csharp/12.desktop-ui/40.media-graphics",{"title":1605,"path":1606,"stem":1607},"Dependency Injection у WPF та Avalonia","/csharp/desktop-ui/di-integration","01.csharp/12.desktop-ui/41.di-integration",{"title":1609,"path":1610,"stem":1611},"SQLite та EF Core у десктопних додатках","/csharp/desktop-ui/data-persistence-part1","01.csharp/12.desktop-ui/42.data-persistence-part1",{"title":1613,"path":1614,"stem":1615},"Repository Pattern та Unit of Work","/csharp/desktop-ui/data-persistence-part2","01.csharp/12.desktop-ui/43.data-persistence-part2",{"title":1617,"path":1618,"stem":1619},"Тестування ViewModels","/csharp/desktop-ui/viewmodel-testing","01.csharp/12.desktop-ui/44.viewmodel-testing",{"title":1621,"path":1622,"stem":1623},"Avalonia Headless Testing — тестування UI без вікон","/csharp/desktop-ui/44a.avalonia-headless-testing","01.csharp/12.desktop-ui/44a.avalonia-headless-testing",{"title":1625,"path":1626,"stem":1627},"Кросплатформна розробка з Avalonia","/csharp/desktop-ui/avalonia-cross-platform","01.csharp/12.desktop-ui/45.avalonia-cross-platform",{"title":1629,"path":1630,"stem":1631},"Пакування та розгортання Avalonia додатків","/csharp/desktop-ui/avalonia-packaging-deployment","01.csharp/12.desktop-ui/46.avalonia-packaging-deployment",{"title":1633,"path":1634,"stem":1635},"Розгортання WPF застосунків","/csharp/desktop-ui/wpf-packaging-deployment","01.csharp/12.desktop-ui/47.wpf-packaging-deployment",{"title":1637,"icon":658,"path":1638,"stem":1639,"children":1640,"page":59},"Network Programming","/csharp/network-programming","01.csharp/13.network-programming",[1641,1645,1649],{"title":1642,"path":1643,"stem":1644},"Основи комп'ютерних мереж","/csharp/network-programming/foundations","01.csharp/13.network-programming/01.foundations",{"title":1646,"path":1647,"stem":1648},"Модель OSI та стек TCP/IP","/csharp/network-programming/osi-model","01.csharp/13.network-programming/02.osi-model",{"title":1650,"path":1651,"stem":1652},"IP-протокол та адресація","/csharp/network-programming/ip-addressing","01.csharp/13.network-programming/03.ip-addressing",{"title":1654,"path":1655,"stem":1656},"C# & .NET: The Ultimate Roadmap","/csharp/roadmap","01.csharp/roadmap",{"title":1658,"icon":1659,"path":1660,"stem":1661,"children":1662,"page":59},"C++","i-devicon-cplusplus","/cpp","02.cpp",[1663,1667,1671,1675,1679,1683,1687,1691,1695,1698,1702,1706,1710,1714,1718,1722,1726,1730,1734,1738,1742,1746,1750,1754,1758,1762,1766,1770,1774,1778,1782,1786,1790,1794,1798,1802,1806],{"title":1664,"path":1665,"stem":1666},"Вступ у програмування та алгоритми","/cpp/intro-algorithms","02.cpp/01.intro-algorithms",{"title":1668,"path":1669,"stem":1670},"Code Style: угоди про оформлення коду","/cpp/code-style","02.cpp/02.code-style",{"title":1672,"path":1673,"stem":1674},"Середовище розробки та перший проєкт","/cpp/ide-setup","02.cpp/03.ide-setup",{"title":1676,"path":1677,"stem":1678},"Вивід даних на екран","/cpp/data-output","02.cpp/04.data-output",{"title":1680,"path":1681,"stem":1682},"Типи даних, змінні та константи","/cpp/data-types-variables","02.cpp/05.data-types-variables",{"title":1684,"path":1685,"stem":1686},"Ввід даних з клавіатури","/cpp/data-input","02.cpp/06.data-input",{"title":1688,"path":1689,"stem":1690},"Оператори, перетворення типів та логічні операції","/cpp/operators-type-conversion","02.cpp/07.operators-type-conversion",{"title":1692,"path":1693,"stem":1694},"Цикли","/cpp/loops","02.cpp/08.loops",{"title":32,"path":1696,"stem":1697},"/cpp/arrays","02.cpp/09.arrays",{"title":1699,"path":1700,"stem":1701},"Алгоритми сортування та аналіз складності","/cpp/sorting","02.cpp/10.sorting",{"title":1703,"path":1704,"stem":1705},"Алгоритми пошуку","/cpp/searching","02.cpp/11.searching",{"title":1707,"path":1708,"stem":1709},"Функції: основи","/cpp/functions-basics","02.cpp/12.functions-basics",{"title":1711,"path":1712,"stem":1713},"Функції: прототипи, область видимості та додаткові можливості","/cpp/functions-scope","02.cpp/13.functions-scope",{"title":1715,"path":1716,"stem":1717},"Функції: перевантаження та шаблони","/cpp/functions-overloading-templates","02.cpp/14.functions-overloading-templates",{"title":1719,"path":1720,"stem":1721},"Вказівники: основи","/cpp/pointers-basics","02.cpp/15.pointers-basics",{"title":1723,"path":1724,"stem":1725},"Посилання (References)","/cpp/references","02.cpp/16.references",{"title":1727,"path":1728,"stem":1729},"Вказівники, const і масиви","/cpp/pointers-const-arrays","02.cpp/17.pointers-const-arrays",{"title":1731,"path":1732,"stem":1733},"Адресна арифметика","/cpp/pointer-arithmetic","02.cpp/18.pointer-arithmetic",{"title":1735,"path":1736,"stem":1737},"Динамічна пам'ять","/cpp/dynamic-memory","02.cpp/19.dynamic-memory",{"title":1739,"path":1740,"stem":1741},"Вказівники типу void","/cpp/void-pointers","02.cpp/20.void-pointers",{"title":1743,"path":1744,"stem":1745},"Вказівники на вказівники","/cpp/pointers-to-pointers","02.cpp/21.pointers-to-pointers",{"title":1747,"path":1748,"stem":1749},"Оператор доступу до членів через вказівник (->)","/cpp/member-access-operator","02.cpp/22.member-access-operator",{"title":1751,"path":1752,"stem":1753},"Цикл for-each (Range-based for)","/cpp/foreach-loop","02.cpp/23.foreach-loop",{"title":1755,"path":1756,"stem":1757},"Вказівники на функції","/cpp/function-pointers","02.cpp/24.function-pointers",{"title":1759,"path":1760,"stem":1761},"Лямбда-вирази","/cpp/lambdas","02.cpp/25.lambdas",{"title":1763,"path":1764,"stem":1765},"Лямбда-захоплення","/cpp/lambda-captures","02.cpp/26.lambda-captures",{"title":1767,"path":1768,"stem":1769},"Еліпсис","/cpp/ellipsis","02.cpp/27.ellipsis",{"title":1771,"path":1772,"stem":1773},"Аргументи командного рядка","/cpp/command-line-arguments","02.cpp/28.command-line-arguments",{"title":1775,"path":1776,"stem":1777},"Перерахування (enum)","/cpp/enum","02.cpp/29.enum",{"title":1779,"path":1780,"stem":1781},"Класи-перерахування (enum class)","/cpp/enum-class","02.cpp/30.enum-class",{"title":1783,"path":1784,"stem":1785},"Псевдоніми типів (typedef і using)","/cpp/type-aliases","02.cpp/31.type-aliases",{"title":1787,"path":1788,"stem":1789},"Системи числення та двійкова арифметика","/cpp/number-systems","02.cpp/32.number-systems",{"title":1791,"path":1792,"stem":1793},"Структури (struct): агрегування даних","/cpp/struct","02.cpp/33.struct",{"title":1795,"path":1796,"stem":1797},"Структури у функціях","/cpp/struct-functions","02.cpp/34.struct-functions",{"title":1799,"path":1800,"stem":1801},"Масиви структур і вкладені структури","/cpp/struct-arrays","02.cpp/35.struct-arrays",{"title":1803,"path":1804,"stem":1805},"Патерни struct та межі застосування","/cpp/struct-patterns","02.cpp/36.struct-patterns",{"title":1807,"path":1808,"stem":1809},"План навчання: Курс C++ — Продовження (Статті 29–60+)","/cpp/curriculum-plan","02.cpp/curriculum-plan",{"title":1811,"icon":1812,"path":1813,"stem":1814,"children":1815,"page":59},"JavaScript","i-devicon-javascript","/javascript","03.javascript",[1816,1842,1896,1918,2222,2260],{"title":1817,"icon":1818,"path":1819,"stem":1820,"children":1821,"page":59},"Events","i-lucide-mouse-pointer-click","/javascript/events","03.javascript/01.events",[1822,1826,1830,1834,1838],{"title":1823,"path":1824,"stem":1825},"Вступ до подій браузера","/javascript/events/intro","03.javascript/01.events/01.intro",{"title":1827,"path":1828,"stem":1829},"Бульбашковий механізм (Bubbling) та занурення (Capturing)","/javascript/events/bubbling-capturing","03.javascript/01.events/02.bubbling-capturing",{"title":1831,"path":1832,"stem":1833},"Делегування подій (Event Delegation)","/javascript/events/delegate-events","03.javascript/01.events/03.delegate-events",{"title":1835,"path":1836,"stem":1837},"Типові дії браузера та preventDefault()","/javascript/events/prevent-default","03.javascript/01.events/04.prevent-default",{"title":1839,"path":1840,"stem":1841},"Запуск користувацьких подій (Custom Events)","/javascript/events/custom-events","03.javascript/01.events/05.custom-events",{"title":1843,"icon":1844,"path":1845,"stem":1846,"children":1847,"page":59},"Network","i-lucide-globe","/javascript/network","03.javascript/02.network",[1848,1852,1856,1860,1864,1868,1872,1876,1880,1884,1888,1892],{"title":1849,"path":1850,"stem":1851},"Fetch API - Сучасний підхід до HTTP-запитів","/javascript/network/01-fetch-api","03.javascript/02.network/01-fetch-api",{"title":1853,"path":1854,"stem":1855},"FormData - Робота з формами та файлами","/javascript/network/02-formdata","03.javascript/02.network/02-formdata",{"title":1857,"path":1858,"stem":1859},"Відстеження прогресу завантаження","/javascript/network/03-download-progress","03.javascript/02.network/03-download-progress",{"title":1861,"path":1862,"stem":1863},"Переривання fetch-запитів","/javascript/network/04-abort-requests","03.javascript/02.network/04-abort-requests",{"title":1865,"path":1866,"stem":1867},"CORS - Запити між різними джерелами","/javascript/network/05-cors","03.javascript/02.network/05-cors",{"title":1869,"path":1870,"stem":1871},"Fetch API - Повний довідник опцій","/javascript/network/06-fetch-options","03.javascript/02.network/06-fetch-options",{"title":1873,"path":1874,"stem":1875},"URL Objects - Робота з посиланнями","/javascript/network/07-url-objects","03.javascript/02.network/07-url-objects",{"title":1877,"path":1878,"stem":1879},"XMLHttpRequest - AJAX та низькорівневі запити","/javascript/network/08-xmlhttprequest","03.javascript/02.network/08-xmlhttprequest",{"title":1881,"path":1882,"stem":1883},"Відновлюване завантаження файлів","/javascript/network/09-resumable-upload","03.javascript/02.network/09-resumable-upload",{"title":1885,"path":1886,"stem":1887},"Cookies, document.cookie та світ після \"Cookiepocalypse\"","/javascript/network/10-cookies","03.javascript/02.network/10-cookies",{"title":1889,"path":1890,"stem":1891},"js-cookie: Керування Cookies без Болю","/javascript/network/11-js-cookie","03.javascript/02.network/11-js-cookie",{"title":1893,"path":1894,"stem":1895},"Axios: Потужний HTTP-клієнт для JavaScript","/javascript/network/12-axios","03.javascript/02.network/12-axios",{"title":1897,"icon":1898,"path":1899,"stem":1900,"children":1901,"page":59},"Bom","i-lucide-monitor","/javascript/bom","03.javascript/03.bom",[1902,1906,1910,1914],{"title":1903,"path":1904,"stem":1905},"LocalStorage, SessionStorage та patterns збереження даних","/javascript/bom/01-localstorage","03.javascript/03.bom/01-localstorage",{"title":1907,"path":1908,"stem":1909},"Location Object - Керування адресою сторінки","/javascript/bom/02-location-object","03.javascript/03.bom/02-location-object",{"title":1911,"path":1912,"stem":1913},"History API - Керування історією браузера","/javascript/bom/03-history-api","03.javascript/03.bom/03-history-api",{"title":1915,"path":1916,"stem":1917},"Navigator Object - Ідентифікація та Можливості Пристрою","/javascript/bom/04-navigator-object","03.javascript/03.bom/04-navigator-object",{"title":1919,"icon":1920,"path":1921,"stem":1922,"children":1923},"React","i-devicon-react","/javascript/react","03.javascript/04.react/index",[1924,1925,1929,1933,1937,1941,2004,2039,2191],{"title":1919,"path":1921,"stem":1922},{"title":1926,"path":1927,"stem":1928},"Робота з Формами в React","/javascript/react/react-forms","03.javascript/04.react/01.react-forms",{"title":1930,"path":1931,"stem":1932},"React Hook Form: Професійна Робота з Формами","/javascript/react/react-hook-form","03.javascript/04.react/02.react-hook-form",{"title":1934,"path":1935,"stem":1936},"React Hook Form: Глибоке Розуміння Архітектури та Оптимізації","/javascript/react/react-hook-form-new","03.javascript/04.react/02.react-hook-form-new",{"title":1938,"path":1939,"stem":1940},"Axios та React: Професійна Архітектура Запитів","/javascript/react/data-fetching-axios","03.javascript/04.react/03.data-fetching-axios",{"title":1942,"icon":132,"path":1943,"stem":1944,"children":1945},"Tanstack Query","/javascript/react/tanstack-query","03.javascript/04.react/04.tanstack-query/index",[1946,1948,1952,1956,1960,1964,1968,1972,1976,1980,1984,1988,1992,1996,2000],{"title":1947,"path":1943,"stem":1944},"TanStack Query: Майстерність Керування Станом Сервера",{"title":1949,"path":1950,"stem":1951},"Парадигма Server State: Чому useEffect недостатньо","/javascript/react/tanstack-query/server-state-paradigm","03.javascript/04.react/04.tanstack-query/01.server-state-paradigm",{"title":1953,"path":1954,"stem":1955},"Встановлення та Налаштування: Фундамент","/javascript/react/tanstack-query/installation-and-devtools","03.javascript/04.react/04.tanstack-query/02.installation-and-devtools",{"title":1957,"path":1958,"stem":1959},"Основи Запитів та Магія Ключів","/javascript/react/tanstack-query/query-basics-and-keys","03.javascript/04.react/04.tanstack-query/03.query-basics-and-keys",{"title":1961,"path":1962,"stem":1963},"Синхронізація Даних: Життєвий Цикл Запиту","/javascript/react/tanstack-query/data-synchronization","03.javascript/04.react/04.tanstack-query/04.data-synchronization",{"title":1965,"path":1966,"stem":1967},"Мутації та Інвалідація: Зміна Даних","/javascript/react/tanstack-query/mutations-and-invalidation","03.javascript/04.react/04.tanstack-query/05.mutations-and-invalidation",{"title":1969,"path":1970,"stem":1971},"Оптимістичні Оновлення: Швидше за Світло","/javascript/react/tanstack-query/optimistic-updates","03.javascript/04.react/04.tanstack-query/06.optimistic-updates",{"title":1973,"path":1974,"stem":1975},"Пагінація та Infinite Scroll","/javascript/react/tanstack-query/pagination-and-load-more","03.javascript/04.react/04.tanstack-query/07.pagination-and-load-more",{"title":1977,"path":1978,"stem":1979},"Просунуті Патерни та Оптимізація","/javascript/react/tanstack-query/advanced-patterns","03.javascript/04.react/04.tanstack-query/08.advanced-patterns",{"title":1981,"path":1982,"stem":1983},"Архітектура та Best Practices","/javascript/react/tanstack-query/architecture-and-best-practices","03.javascript/04.react/04.tanstack-query/09.architecture-and-best-practices",{"title":1985,"path":1986,"stem":1987},"Server-Side Rendering (SSR) та Гідратація","/javascript/react/tanstack-query/server-side-rendering","03.javascript/04.react/04.tanstack-query/10.server-side-rendering",{"title":1989,"path":1990,"stem":1991},"Стратегії Тестування","/javascript/react/tanstack-query/testing-strategies","03.javascript/04.react/04.tanstack-query/11.testing-strategies",{"title":1993,"path":1994,"stem":1995},"Аутентифікація та Обробка Помилок","/javascript/react/tanstack-query/authentication-and-errors","03.javascript/04.react/04.tanstack-query/12.authentication-and-errors",{"title":1997,"path":1998,"stem":1999},"React Suspense та Майбутнє","/javascript/react/tanstack-query/react-suspense","03.javascript/04.react/04.tanstack-query/13.react-suspense",{"title":2001,"path":2002,"stem":2003},"Глибоке Занурення в Продуктивність","/javascript/react/tanstack-query/performance-deep-dive","03.javascript/04.react/04.tanstack-query/14.performance-deep-dive",{"title":2005,"icon":1920,"path":2006,"stem":2007,"children":2008},"React Router","/javascript/react/react-router","03.javascript/04.react/05.react-router/index",[2009,2011,2015,2019,2023,2027,2031,2035],{"title":2010,"path":2006,"stem":2007},"React Router: Навігаційна система сучасного вебу",{"title":2012,"path":2013,"stem":2014},"Налаштування та Базовий Роутинг","/javascript/react/react-router/setup-and-basic-routing","03.javascript/04.react/05.react-router/01.setup-and-basic-routing",{"title":2016,"path":2017,"stem":2018},"Динамічна Навігація","/javascript/react/react-router/navigation-and-links","03.javascript/04.react/05.react-router/02.navigation-and-links",{"title":2020,"path":2021,"stem":2022},"Вкладені Маршрути та Макети","/javascript/react/react-router/nested-routes-and-layouts","03.javascript/04.react/05.react-router/03.nested-routes-and-layouts",{"title":2024,"path":2025,"stem":2026},"Динамічні Маршрути та Параметри","/javascript/react/react-router/dynamic-routing","03.javascript/04.react/05.react-router/04.dynamic-routing",{"title":2028,"path":2029,"stem":2030},"Data APIs: Loaders та Actions","/javascript/react/react-router/data-loading","03.javascript/04.react/05.react-router/05.data-loading",{"title":2032,"path":2033,"stem":2034},"Просунуті Патерни","/javascript/react/react-router/advanced-patterns","03.javascript/04.react/05.react-router/06.advanced-patterns",{"title":2036,"path":2037,"stem":2038},"Legacy Routing: Компонентний підхід","/javascript/react/react-router/legacy-routing","03.javascript/04.react/05.react-router/07.legacy-routing",{"title":2040,"icon":132,"path":2041,"stem":2042,"children":2043},"Redux","/javascript/react/redux","03.javascript/04.react/06.redux/index",[2044,2046,2062,2091,2100,2121,2137,2166],{"title":2045,"path":2041,"stem":2042},"Redux: Еволюція управління станом",{"title":14,"icon":15,"path":2047,"stem":2048,"children":2049,"page":59},"/javascript/react/redux/fundamentals","03.javascript/04.react/06.redux/01.fundamentals",[2050,2054,2058],{"title":2051,"path":2052,"stem":2053},"Вступ до State Management","/javascript/react/redux/fundamentals/intro-state-management","03.javascript/04.react/06.redux/01.fundamentals/01.intro-state-management",{"title":2055,"path":2056,"stem":2057},"Філософія Redux та Три Принципи","/javascript/react/redux/fundamentals/redux-philosophy","03.javascript/04.react/06.redux/01.fundamentals/02.redux-philosophy",{"title":2059,"path":2060,"stem":2061},"Чисті функції та Іммутабельність","/javascript/react/redux/fundamentals/pure-functions-immutability","03.javascript/04.react/06.redux/01.fundamentals/03.pure-functions-immutability",{"title":2063,"icon":132,"path":2064,"stem":2065,"children":2066,"page":59},"Classic Redux","/javascript/react/redux/classic-redux","03.javascript/04.react/06.redux/02.classic-redux",[2067,2071,2075,2079,2083,2087],{"title":2068,"path":2069,"stem":2070},"Створення Store (Classic Redux)","/javascript/react/redux/classic-redux/store-setup","03.javascript/04.react/06.redux/02.classic-redux/01.store-setup",{"title":2072,"path":2073,"stem":2074},"Actions, Constants та Action Creators","/javascript/react/redux/classic-redux/actions-constants","03.javascript/04.react/06.redux/02.classic-redux/02.actions-constants",{"title":2076,"path":2077,"stem":2078},"Логіка Reducers","/javascript/react/redux/classic-redux/reducers","03.javascript/04.react/06.redux/02.classic-redux/03.reducers",{"title":2080,"path":2081,"stem":2082},"Комбінування Reducers (Root Reducer)","/javascript/react/redux/classic-redux/data-flow","03.javascript/04.react/06.redux/02.classic-redux/04.data-flow",{"title":2084,"path":2085,"stem":2086},"Підключення до React (React-Redux)","/javascript/react/redux/classic-redux/react-redux-connection","03.javascript/04.react/06.redux/02.classic-redux/05.react-redux-connection",{"title":2088,"path":2089,"stem":2090},"Middleware та Асинхронність (Redux Thunk)","/javascript/react/redux/classic-redux/middleware-thunk","03.javascript/04.react/06.redux/02.classic-redux/06.middleware-thunk",{"title":2092,"icon":132,"path":2093,"stem":2094,"children":2095,"page":59},"Transition To Rtk","/javascript/react/redux/transition-to-rtk","03.javascript/04.react/06.redux/03.transition-to-rtk",[2096],{"title":2097,"path":2098,"stem":2099},"Проблеми класичного Redux","/javascript/react/redux/transition-to-rtk/problems-with-classic","03.javascript/04.react/06.redux/03.transition-to-rtk/01.problems-with-classic",{"title":2101,"icon":132,"path":2102,"stem":2103,"children":2104,"page":59},"Redux Toolkit","/javascript/react/redux/redux-toolkit","03.javascript/04.react/06.redux/04.redux-toolkit",[2105,2109,2113,2117],{"title":2106,"path":2107,"stem":2108},"Налаштування Store з configureStore","/javascript/react/redux/redux-toolkit/configure-store","03.javascript/04.react/06.redux/04.redux-toolkit/01.configure-store",{"title":2110,"path":2111,"stem":2112},"createSlice: Революція в Redux","/javascript/react/redux/redux-toolkit/create-slice","03.javascript/04.react/06.redux/04.redux-toolkit/02.create-slice",{"title":2114,"path":2115,"stem":2116},"Асинхронність з createAsyncThunk","/javascript/react/redux/redux-toolkit/async-thunks","03.javascript/04.react/06.redux/04.redux-toolkit/03.async-thunks",{"title":2118,"path":2119,"stem":2120},"04. Entity Adapter: Керування нормалізованим станом","/javascript/react/redux/redux-toolkit/entity-adapter","03.javascript/04.react/06.redux/04.redux-toolkit/04.entity-adapter",{"title":2122,"icon":92,"path":2123,"stem":2124,"children":2125,"page":59},"Advanced","/javascript/react/redux/advanced","03.javascript/04.react/06.redux/05.advanced",[2126,2130,2134],{"title":2127,"path":2128,"stem":2129},"Мемоізація та Селектори: Повний Гайд по Reselect","/javascript/react/redux/advanced/selectors-reselect","03.javascript/04.react/06.redux/05.advanced/01.selectors-reselect",{"title":2131,"path":2132,"stem":2133},"RTK Query: Архітектура Серверного Кешу","/javascript/react/redux/advanced/rtk-query-intro","03.javascript/04.react/06.redux/05.advanced/02.rtk-query-intro",{"title":1981,"path":2135,"stem":2136},"/javascript/react/redux/advanced/architecture-best-practices","03.javascript/04.react/06.redux/05.advanced/03.architecture-best-practices",{"title":2138,"icon":132,"path":2139,"stem":2140,"children":2141,"page":59},"Project Kanban","/javascript/react/redux/project-kanban","03.javascript/04.react/06.redux/06.project-kanban",[2142,2146,2150,2154,2158,2162],{"title":2143,"path":2144,"stem":2145},"Проєкт: Kanban Board (Trello Clone)","/javascript/react/redux/project-kanban/project-overview","03.javascript/04.react/06.redux/06.project-kanban/01.project-overview",{"title":2147,"path":2148,"stem":2149},"Налаштування та Типізація","/javascript/react/redux/project-kanban/setup-and-types","03.javascript/04.react/06.redux/06.project-kanban/02.setup-and-types",{"title":2151,"path":2152,"stem":2153},"Board Slice: Серце Дошки","/javascript/react/redux/project-kanban/board-slice","03.javascript/04.react/06.redux/06.project-kanban/03.board-slice",{"title":2155,"path":2156,"stem":2157},"Логіка Drag & Drop","/javascript/react/redux/project-kanban/drag-and-drop-logic","03.javascript/04.react/06.redux/06.project-kanban/04.drag-and-drop-logic",{"title":2159,"path":2160,"stem":2161},"Інтеграція з RTK Query","/javascript/react/redux/project-kanban/rtk-query-integration","03.javascript/04.react/06.redux/06.project-kanban/05.rtk-query-integration",{"title":2163,"path":2164,"stem":2165},"Optimistic Updates","/javascript/react/redux/project-kanban/optimistic-updates","03.javascript/04.react/06.redux/06.project-kanban/06.optimistic-updates",{"title":2167,"icon":132,"path":2168,"stem":2169,"children":2170,"page":59},"Testing","/javascript/react/redux/testing","03.javascript/04.react/06.redux/07.testing",[2171,2175,2179,2183,2187],{"title":2172,"path":2173,"stem":2174},"Тестування Redux","/javascript/react/redux/testing/intro-testing","03.javascript/04.react/06.redux/07.testing/01.intro-testing",{"title":2176,"path":2177,"stem":2178},"Тестування Reducers","/javascript/react/redux/testing/testing-reducers","03.javascript/04.react/06.redux/07.testing/02.testing-reducers",{"title":2180,"path":2181,"stem":2182},"Тестування Селекторів","/javascript/react/redux/testing/testing-selectors","03.javascript/04.react/06.redux/07.testing/03.testing-selectors",{"title":2184,"path":2185,"stem":2186},"Тестування Компонентів (Integration)","/javascript/react/redux/testing/testing-components","03.javascript/04.react/06.redux/07.testing/04.testing-components",{"title":2188,"path":2189,"stem":2190},"Тестування Async Thunks","/javascript/react/redux/testing/testing-thunks","03.javascript/04.react/06.redux/07.testing/05.testing-thunks",{"title":2192,"icon":132,"path":2193,"stem":2194,"children":2195},"Ui Libraries","/javascript/react/ui-libraries","03.javascript/04.react/07.ui-libraries/index",[2196,2198,2202,2206,2210,2214,2218],{"title":2197,"path":2193,"stem":2194},"UI Бібліотеки в React",{"title":2199,"path":2200,"stem":2201},"Вступ до UI Бібліотек: Навіщо Винаходити Велосипед Двічі?","/javascript/react/ui-libraries/introduction-to-ui-libraries","03.javascript/04.react/07.ui-libraries/01.introduction-to-ui-libraries",{"title":2203,"path":2204,"stem":2205},"Філософія shadcn/ui: \"Not a Component Library\"","/javascript/react/ui-libraries/shadcn-philosophy","03.javascript/04.react/07.ui-libraries/02.shadcn-philosophy",{"title":2207,"path":2208,"stem":2209},"Установка та Налаштування shadcn/ui","/javascript/react/ui-libraries/shadcn-installation","03.javascript/04.react/07.ui-libraries/03.shadcn-installation",{"title":2211,"path":2212,"stem":2213},"Базові Компоненти shadcn/ui: Фундамент Інтерфейсу","/javascript/react/ui-libraries/shadcn-components-basics","03.javascript/04.react/07.ui-libraries/04.shadcn-components-basics",{"title":2215,"path":2216,"stem":2217},"Компоненти Форм: Побудова Інтерактивних Form","/javascript/react/ui-libraries/shadcn-components-forms","03.javascript/04.react/07.ui-libraries/05.shadcn-components-forms",{"title":2219,"path":2220,"stem":2221},"Складні Компоненти: Dialog, Dropdown, Table та Command","/javascript/react/ui-libraries/shadcn-components-advanced","03.javascript/04.react/07.ui-libraries/06.shadcn-components-advanced",{"title":2223,"icon":2224,"path":2225,"stem":2226,"children":2227,"page":59},"TypeScript","i-devicon-typescript","/javascript/typescript","03.javascript/05.typescript",[2228,2232,2236,2240,2244,2248,2252,2256],{"title":2229,"path":2230,"stem":2231},"TypeScript: Броня для вашого коду","/javascript/typescript/intro-and-basic-types","03.javascript/05.typescript/01.intro-and-basic-types",{"title":2233,"path":2234,"stem":2235},"Майстерність Моделювання Даних: Інтерфейси та Просунуті Типи","/javascript/typescript/interfaces-and-advanced-types","03.javascript/05.typescript/02.interfaces-and-advanced-types",{"title":2237,"path":2238,"stem":2239},"Алхімія Типів: Generics та Utility Types","/javascript/typescript/generics-and-utilities","03.javascript/05.typescript/03.generics-and-utilities",{"title":2241,"path":2242,"stem":2243},"Архітектура та Шаблони: Класи в TypeScript","/javascript/typescript/classes-and-oop","03.javascript/05.typescript/04.classes-and-oop",{"title":2245,"path":2246,"stem":2247},"Продакшн та Екосистема: Advanced Config & Workflow","/javascript/typescript/advanced-patterns-and-config","03.javascript/05.typescript/05.advanced-patterns-and-config",{"title":2249,"path":2250,"stem":2251},"TypeScript у світі React","/javascript/typescript/react-basics","03.javascript/05.typescript/06.react-basics",{"title":2253,"path":2254,"stem":2255},"React + TypeScript: Продвинуті патерни","/javascript/typescript/react-advanced","03.javascript/05.typescript/07.react-advanced",{"title":2257,"path":2258,"stem":2259},"React + TypeScript: Екосистема та бібліотеки","/javascript/typescript/react-ecosystem","03.javascript/05.typescript/08.react-ecosystem",{"title":2261,"path":2262,"stem":2263},"Atomic Design","/javascript/atomic-design","03.javascript/2.atomic-design",{"title":2265,"icon":2266,"path":2267,"stem":2268,"children":2269,"page":59},"Java","i-devicon-java","/java","04.java",[2270,2273,2276,2280,2284,2288,2292],{"title":162,"path":2271,"stem":2272},"/java/data-mapper-part1","04.java/01.data-mapper-part1",{"title":166,"path":2274,"stem":2275},"/java/data-mapper-part2","04.java/02.data-mapper-part2",{"title":2277,"path":2278,"stem":2279},"Service Layer: Організація бізнес-логіки","/java/service-layer","04.java/03.service-layer",{"title":2281,"path":2282,"stem":2283},"Rich Domain Model та State Pattern","/java/rich-domain-model","04.java/04.rich-domain-model",{"title":2285,"path":2286,"stem":2287},"Патерни для складної бізнес-логіки","/java/business-logic-patterns","04.java/05.business-logic-patterns",{"title":2289,"path":2290,"stem":2291},"Обробка помилок та валідація","/java/error-handling-validation","04.java/06.error-handling-validation",{"title":2293,"path":2294,"stem":2295,"children":2296,"page":59},"Проектування баз даних","/java/pr2","04.java/pr2",[2297,2301,2305,2309,2313,2317,2321,2325,2329,2333,2337,2341,2345,2349,2353,2357,2361,2365,2369,2373,2377,2381,2385,2389,2393,2397,2401,2405,2409,2413,2417,2421,2425,2429,2433,2437,2441],{"title":2298,"path":2299,"stem":2300},"Концептуальне моделювання: Мистецтво розуміння предметної області","/java/pr2/conceptual-modeling","04.java/pr2/01.conceptual-modeling",{"title":2302,"path":2303,"stem":2304},"Логічне моделювання: Від бізнес-ідей до структур даних","/java/pr2/logical-modeling","04.java/pr2/02.logical-modeling",{"title":2306,"path":2307,"stem":2308},"Нормалізація: Гігієна даних та боротьба з аномаліями","/java/pr2/normalization","04.java/pr2/03.normalization",{"title":2310,"path":2311,"stem":2312},"Фізична схема: Від абстракції до DDL","/java/pr2/physical-schema","04.java/pr2/04.physical-schema",{"title":2314,"path":2315,"stem":2316},"Архітектурна класифікація таблиць","/java/pr2/table-classification","04.java/pr2/05.table-classification",{"title":2318,"path":2319,"stem":2320},"Database Migrations: Версіонування схеми з Flyway","/java/pr2/database-migrations","04.java/pr2/06.database-migrations",{"title":2322,"path":2323,"stem":2324},"А що, якби це була не реляційна БД?","/java/pr2/beyond-relational","04.java/pr2/07.beyond-relational",{"title":2326,"path":2327,"stem":2328},"Object-Relational Impedance Mismatch: Два світи, що не хочуть дружити","/java/pr2/impedance-mismatch","04.java/pr2/09.impedance-mismatch",{"title":2330,"path":2331,"stem":2332},"JDBC: Перший контакт із базою даних","/java/pr2/jdbc-fundamentals","04.java/pr2/10.jdbc-fundamentals",{"title":2334,"path":2335,"stem":2336},"Якість коду: Spotless, SpotBugs та SonarQube","/java/pr2/10a.code-quality","04.java/pr2/10a.code-quality",{"title":2338,"path":2339,"stem":2340},"Connection Pool: Патерн Object Pool для JDBC-з'єднань","/java/pr2/connection-pool","04.java/pr2/11.connection-pool",{"title":2342,"path":2343,"stem":2344},"Row Data Gateway: Об'єкт як обгортка рядка таблиці","/java/pr2/row-data-gateway","04.java/pr2/12.row-data-gateway",{"title":2346,"path":2347,"stem":2348},"Table Data Gateway: Фасад таблиці як архітектурний відступ","/java/pr2/table-data-gateway","04.java/pr2/13.table-data-gateway",{"title":2350,"path":2351,"stem":2352},"Repository + Data Mapper: Правильна шарова архітектура з JDBC","/java/pr2/repository-data-mapper","04.java/pr2/14.repository-data-mapper",{"title":2354,"path":2355,"stem":2356},"Identity Map: Кешування сутностей у рамках сесії","/java/pr2/identity-map","04.java/pr2/15.identity-map",{"title":2358,"path":2359,"stem":2360},"Unit of Work: Відстеження змін і координація JDBC-транзакцій","/java/pr2/unit-of-work","04.java/pr2/16.unit-of-work",{"title":2362,"path":2363,"stem":2364},"Strategy: Замінювані SQL-стратегії для підтримки різних СУБД","/java/pr2/strategy-sql","04.java/pr2/17.strategy-sql",{"title":2366,"path":2367,"stem":2368},"Proxy: Lazy Loading для One-To-Many колекцій","/java/pr2/proxy-lazy-loading","04.java/pr2/18.proxy-lazy-loading",{"title":2370,"path":2371,"stem":2372},"Generic Repository через Java Reflection: анотації та динамічний SQL","/java/pr2/generic-repository-reflection","04.java/pr2/19.generic-repository-reflection",{"title":2374,"path":2375,"stem":2376},"Specification Pattern: Композиція бізнес-правил для складних запитів","/java/pr2/specification-pattern","04.java/pr2/20.specification-pattern",{"title":2378,"path":2379,"stem":2380},"Розширені можливості Specification Pattern: підзапити, агрегації та гібридний підхід","/java/pr2/20a.advanced-specifications","04.java/pr2/20a.advanced-specifications",{"title":2382,"path":2383,"stem":2384},"Асинхронність у JDBC: Від блокуючих викликів до CompletableFuture","/java/pr2/asynchronous-jdbc","04.java/pr2/21.asynchronous-jdbc",{"title":2386,"path":2387,"stem":2388},"Інтеграційне тестування JDBC-репозиторіїв: Embedded H2 та патерн AAA","/java/pr2/integration-testing-h2","04.java/pr2/22.integration-testing-h2",{"title":2390,"path":2391,"stem":2392},"Testcontainers: Тестування з реальною PostgreSQL у Docker-контейнерах","/java/pr2/integration-testing-testcontainers","04.java/pr2/23.integration-testing-testcontainers",{"title":2394,"path":2395,"stem":2396},"Google Guice: Впровадження залежностей у JavaFX-проєкті","/java/pr2/dependency-injection-guice","04.java/pr2/24.dependency-injection-guice",{"title":2398,"path":2399,"stem":2400},"JavaFX: Основи побудови графічних інтерфейсів","/java/pr2/javafx-fundamentals","04.java/pr2/25.javafx-fundamentals",{"title":2402,"path":2403,"stem":2404},"Properties та Bindings: Реактивність у JavaFX","/java/pr2/javafx-properties-bindings","04.java/pr2/26.javafx-properties-bindings",{"title":2406,"path":2407,"stem":2408},"MVC vs MVP vs MVVM: Еволюція архітектурних патернів UI","/java/pr2/ui-architecture-patterns","04.java/pr2/27.ui-architecture-patterns",{"title":2410,"path":2411,"stem":2412},"MVVM на практиці: Побудова ViewModel","/java/pr2/mvvm-viewmodel-implementation","04.java/pr2/28.mvvm-viewmodel-implementation",{"title":2414,"path":2415,"stem":2416},"View та Controller: Зв'язування з ViewModel через FXML","/java/pr2/mvvm-view-controller","04.java/pr2/29.mvvm-view-controller",{"title":2418,"path":2419,"stem":2420},"Інтеграція MVVM з Guice: Автоматична ін'єкція залежностей","/java/pr2/mvvm-guice-integration","04.java/pr2/30.mvvm-guice-integration",{"title":2422,"path":2423,"stem":2424},"Валідація та обробка помилок у MVVM","/java/pr2/mvvm-validation-error-handling","04.java/pr2/31.mvvm-validation-error-handling",{"title":2426,"path":2427,"stem":2428},"Навігація та управління екранами у JavaFX MVVM","/java/pr2/mvvm-navigation-screen-management","04.java/pr2/32.mvvm-navigation-screen-management",{"title":2430,"path":2431,"stem":2432},"Тестування JavaFX MVVM-додатків","/java/pr2/mvvm-testing","04.java/pr2/33.mvvm-testing",{"title":2434,"path":2435,"stem":2436},"Стилізація та теми у JavaFX: CSS та User Experience","/java/pr2/javafx-styling-themes","04.java/pr2/34.javafx-styling-themes",{"title":2438,"path":2439,"stem":2440},"AtlantaFX: Сучасні теми для JavaFX додатків","/java/pr2/atlantafx-modern-themes","04.java/pr2/35.atlantafx-modern-themes",{"title":2442,"path":2443,"stem":2444},"Пакування та розповсюдження JavaFX-додатків","/java/pr2/jar-packaging-distribution","04.java/pr2/36.jar-packaging-distribution",{"title":2446,"icon":2447,"path":2448,"stem":2449,"children":2450,"page":59},"Бази даних","i-lucide-database","/databases","06.databases",[2451,2481,2504,2541,2570,2588,2622,2634,2643],{"title":2452,"icon":2453,"path":2454,"stem":2455,"children":2456,"page":59},"Intro","i-lucide-play","/databases/intro","06.databases/01.intro",[2457,2461,2465,2469,2473,2477],{"title":2458,"path":2459,"stem":2460},"Введення в теорію баз даних","/databases/intro/introduction-to-databases","06.databases/01.intro/01.introduction-to-databases",{"title":2462,"path":2463,"stem":2464},"Реляційна модель даних","/databases/intro/relational-model-theory","06.databases/01.intro/02.relational-model-theory",{"title":2466,"path":2467,"stem":2468},"ER-моделювання","/databases/intro/er-modeling","06.databases/01.intro/03.er-modeling",{"title":2470,"path":2471,"stem":2472},"Логічне проектування БД","/databases/intro/logical-schema","06.databases/01.intro/04.logical-schema",{"title":2474,"path":2475,"stem":2476},"Класифікація таблиць","/databases/intro/table-classification","06.databases/01.intro/05.table-classification",{"title":2478,"path":2479,"stem":2480},"PlantUML для баз даних","/databases/intro/plantuml-diagrams","06.databases/01.intro/06.plantuml-diagrams",{"title":2482,"icon":2447,"path":2483,"stem":2484,"children":2485,"page":59},"MS SQL Server Start","/databases/ms-sql-server-start","06.databases/02.ms-sql-server-start",[2486,2490,2496,2500],{"title":2487,"path":2488,"stem":2489},"Типи даних у MS SQL Server","/databases/ms-sql-server-start/data-types","06.databases/02.ms-sql-server-start/01.data-types",{"title":2491,"path":2492,"stem":2493,"children":2494},"Індекси у MS SQL Server","/databases/ms-sql-server-start/sql-indexes","06.databases/02.ms-sql-server-start/02.sql-indexes",[2495],{"title":2491,"path":2492,"stem":2493},{"title":2497,"path":2498,"stem":2499},"Системні бази даних MS SQL Server","/databases/ms-sql-server-start/system-databases","06.databases/02.ms-sql-server-start/03.system-databases",{"title":2501,"path":2502,"stem":2503},"Огляд мови SQL та запитів","/databases/ms-sql-server-start/sql-queries-overview","06.databases/02.ms-sql-server-start/04.sql-queries-overview",{"title":2505,"icon":2447,"path":2506,"stem":2507,"children":2508,"page":59},"SQL","/databases/sql","06.databases/03.sql",[2509,2513,2517,2521,2525,2529,2533,2537],{"title":2510,"path":2511,"stem":2512},"Налаштування демонстраційної бази даних","/databases/sql/sample-database-setup","06.databases/03.sql/00.sample-database-setup",{"title":2514,"path":2515,"stem":2516},"DDL - Створення таблиць (CREATE TABLE)","/databases/sql/ddl-create-table","06.databases/03.sql/01.ddl-create-table",{"title":2518,"path":2519,"stem":2520},"DDL - Зміна та видалення таблиць (ALTER, DROP)","/databases/sql/ddl-alter-drop-table","06.databases/03.sql/02.ddl-alter-drop-table",{"title":2522,"path":2523,"stem":2524},"SELECT запити - Основи","/databases/sql/select-queries-fundamentals","06.databases/03.sql/03.select-queries-fundamentals",{"title":2526,"path":2527,"stem":2528},"SELECT запити - Розширені можливості","/databases/sql/select-queries-advanced","06.databases/03.sql/04.select-queries-advanced",{"title":2530,"path":2531,"stem":2532},"INSERT запити - Додавання даних","/databases/sql/insert-queries","06.databases/03.sql/05.insert-queries",{"title":2534,"path":2535,"stem":2536},"UPDATE та DELETE запити","/databases/sql/update-delete-queries","06.databases/03.sql/06.update-delete-queries",{"title":2538,"path":2539,"stem":2540},"Транзакції в SQL","/databases/sql/transactions","06.databases/03.sql/07.transactions",{"title":2542,"icon":2447,"path":2543,"stem":2544,"children":2545,"page":59},"Multi Table Databases","/databases/multi-table-databases","06.databases/04.multi-table-databases",[2546,2550,2554,2558,2562,2566],{"title":2547,"path":2548,"stem":2549},"Зв'язки та нормалізація БД","/databases/multi-table-databases/relationships-and-normalization","06.databases/04.multi-table-databases/00.relationships-and-normalization",{"title":2551,"path":2552,"stem":2553},"INNER JOIN - З'єднання таблиць","/databases/multi-table-databases/inner-join","06.databases/04.multi-table-databases/01.inner-join",{"title":2555,"path":2556,"stem":2557},"OUTER JOINs - LEFT, RIGHT, FULL","/databases/multi-table-databases/outer-joins","06.databases/04.multi-table-databases/02.outer-joins",{"title":2559,"path":2560,"stem":2561},"CROSS та SELF JOINs","/databases/multi-table-databases/cross-self-joins","06.databases/04.multi-table-databases/03.cross-self-joins",{"title":2563,"path":2564,"stem":2565},"Підзапити (Subqueries)","/databases/multi-table-databases/subqueries","06.databases/04.multi-table-databases/04.subqueries",{"title":2567,"path":2568,"stem":2569},"Агрегації з JOIN","/databases/multi-table-databases/aggregations-with-joins","06.databases/04.multi-table-databases/05.aggregations-with-joins",{"title":2571,"icon":2572,"path":2573,"stem":2574,"children":2575,"page":59},"Aggregate Functions","i-lucide-calculator","/databases/aggregate-functions","06.databases/05.aggregate-functions",[2576,2580,2584],{"title":2577,"path":2578,"stem":2579},"Функції агрегування в MS SQL Server","/databases/aggregate-functions/introduction-aggregate-functions","06.databases/05.aggregate-functions/01.introduction-aggregate-functions",{"title":2581,"path":2582,"stem":2583},"Групування даних в MS SQL Server","/databases/aggregate-functions/grouping-data","06.databases/05.aggregate-functions/02.grouping-data",{"title":2585,"path":2586,"stem":2587},"Підзапити з агрегатними функціями","/databases/aggregate-functions/subqueries-aggregates","06.databases/05.aggregate-functions/03.subqueries-aggregates",{"title":2589,"icon":2590,"path":2591,"stem":2592,"children":2593,"page":59},"Тригери та зберігаємі процедури","i-lucide-database-zap","/databases/triggers-stored-procedures","06.databases/07.triggers-stored-procedures",[2594,2598,2602,2606,2610,2614,2618],{"title":2595,"path":2596,"stem":2597},"DML-тригери","/databases/triggers-stored-procedures/dml-triggers","06.databases/07.triggers-stored-procedures/01.dml-triggers",{"title":2599,"path":2600,"stem":2601},"DDL-тригери","/databases/triggers-stored-procedures/ddl-triggers","06.databases/07.triggers-stored-procedures/02.ddl-triggers",{"title":2603,"path":2604,"stem":2605},"Transact-SQL розширення","/databases/triggers-stored-procedures/transact-sql-extensions","06.databases/07.triggers-stored-procedures/03.transact-sql-extensions",{"title":2607,"path":2608,"stem":2609},"Транзакції","/databases/triggers-stored-procedures/transactions","06.databases/07.triggers-stored-procedures/04.transactions",{"title":2611,"path":2612,"stem":2613},"Зберігаємі процедури","/databases/triggers-stored-procedures/stored-procedures","06.databases/07.triggers-stored-procedures/05.stored-procedures",{"title":2615,"path":2616,"stem":2617},"Користувацькі функції","/databases/triggers-stored-procedures/user-defined-functions","06.databases/07.triggers-stored-procedures/06.user-defined-functions",{"title":2619,"path":2620,"stem":2621},"Безпека баз даних","/databases/triggers-stored-procedures/security","06.databases/07.triggers-stored-procedures/08.security",{"title":2619,"icon":793,"path":2623,"stem":2624,"children":2625,"page":59},"/databases/security","06.databases/08.security",[2626,2630],{"title":2627,"path":2628,"stem":2629},"Вступ до безпеки баз даних","/databases/security/introduction","06.databases/08.security/01.introduction",{"title":2631,"path":2632,"stem":2633},"Системні представлення та метадані","/databases/security/system-views","06.databases/08.security/02.system-views",{"title":2635,"icon":2636,"path":2637,"stem":2638,"children":2639,"page":59},"Резервне копіювання та відновлення","i-lucide-database-backup","/databases/backup-recovery","06.databases/09.backup-recovery",[2640],{"title":2635,"path":2641,"stem":2642},"/databases/backup-recovery/backup-restore","06.databases/09.backup-recovery/01.backup-restore",{"title":2644,"icon":2645,"path":2646,"stem":2647,"children":2648,"page":59},"Повнотекстовий пошук","i-lucide-search","/databases/full-text-search","06.databases/10.full-text-search",[2649],{"title":2644,"path":2650,"stem":2651},"/databases/full-text-search/full-text-search","06.databases/10.full-text-search/01.full-text-search",{"title":2653,"icon":2654,"path":2655,"stem":2656,"children":2657,"page":59},"Tools","i-lucide-wrench","/tools","07.tools",[2658,2734],{"title":2659,"icon":2660,"path":2661,"stem":2662,"children":2663},"Docker","i-simple-icons-docker","/tools/docker","07.tools/01.docker/index",[2664,2666,2670,2674,2678,2682,2686,2690,2694,2698,2702,2706,2710,2714,2718,2722,2726,2730],{"title":2665,"path":2661,"stem":2662},"Docker: від нуля до production",{"title":2667,"path":2668,"stem":2669},"Контейнеризація — від проблеми до рішення","/tools/docker/containerization-concept","07.tools/01.docker/01.containerization-concept",{"title":2671,"path":2672,"stem":2673},"Docker — що це і навіщо?","/tools/docker/docker-what-and-why","07.tools/01.docker/02.docker-what-and-why",{"title":2675,"path":2676,"stem":2677},"Архітектура Docker Engine","/tools/docker/docker-architecture","07.tools/01.docker/03.docker-architecture",{"title":2679,"path":2680,"stem":2681},"Встановлення Docker","/tools/docker/installation","07.tools/01.docker/04.installation",{"title":2683,"path":2684,"stem":2685},"Перший контейнер — docker run","/tools/docker/first-container","07.tools/01.docker/05.first-container",{"title":2687,"path":2688,"stem":2689},"Життєвий цикл контейнера","/tools/docker/container-lifecycle","07.tools/01.docker/06.container-lifecycle",{"title":2691,"path":2692,"stem":2693},"Docker Images — фундаментальні концепції","/tools/docker/docker-images-fundamentals","07.tools/01.docker/07.docker-images-fundamentals",{"title":2695,"path":2696,"stem":2697},"Dockerfile — основи","/tools/docker/dockerfile-basics","07.tools/01.docker/08.dockerfile-basics",{"title":2699,"path":2700,"stem":2701},"Dockerfile — просунуті техніки","/tools/docker/dockerfile-advanced","07.tools/01.docker/09.dockerfile-advanced",{"title":2703,"path":2704,"stem":2705},"Build Context та кешування шарів","/tools/docker/build-context-and-cache","07.tools/01.docker/10.build-context-and-cache",{"title":2707,"path":2708,"stem":2709},"Реєстри Docker-образів","/tools/docker/image-registries","07.tools/01.docker/11.image-registries",{"title":2711,"path":2712,"stem":2713},"Контейнеризація .NET додатків","/tools/docker/dotnet-containerization","07.tools/01.docker/12.dotnet-containerization",{"title":2715,"path":2716,"stem":2717},"Томи та збереження даних","/tools/docker/volumes-and-data","07.tools/01.docker/13.volumes-and-data",{"title":2719,"path":2720,"stem":2721},"Основи мережі в Docker","/tools/docker/networking-basics","07.tools/01.docker/14.networking-basics",{"title":2723,"path":2724,"stem":2725},"Змінні оточення та конфігурація","/tools/docker/environment-and-configuration","07.tools/01.docker/15.environment-and-configuration",{"title":2727,"path":2728,"stem":2729},"Docker Compose — оркестрація контейнерів","/tools/docker/docker-compose-basics","07.tools/01.docker/16.docker-compose-basics",{"title":2731,"path":2732,"stem":2733},"Docker Compose — Multi-Service застосунки","/tools/docker/compose-multi-service","07.tools/01.docker/17.compose-multi-service",{"title":2735,"icon":2736,"path":2737,"stem":2738,"children":2739},"Kubernetes","simple-icons:kubernetes","/tools/kubernetes","07.tools/02.kubernetes/index",[2740,2742,2746,2750,2754,2758,2762,2766,2770],{"title":2741,"path":2737,"stem":2738},"Kubernetes: від розробки до production",{"title":2743,"path":2744,"stem":2745},"Kubernetes — коли Docker Compose більше не вистачає","/tools/kubernetes/why-kubernetes","07.tools/02.kubernetes/01.why-kubernetes",{"title":2747,"path":2748,"stem":2749},"Архітектура Kubernetes — анатомія кластера","/tools/kubernetes/kubernetes-architecture","07.tools/02.kubernetes/02.kubernetes-architecture",{"title":2751,"path":2752,"stem":2753},"Локальне середовище — minikube, kind та k3s","/tools/kubernetes/local-environment","07.tools/02.kubernetes/03.local-environment",{"title":2755,"path":2756,"stem":2757},"Pod — атомарна одиниця Kubernetes","/tools/kubernetes/pods-and-containers","07.tools/02.kubernetes/04.pods-and-containers",{"title":2759,"path":2760,"stem":2761},"Патерни використання Pod","/tools/kubernetes/pod-patterns","07.tools/02.kubernetes/05.pod-patterns",{"title":2763,"path":2764,"stem":2765},"Deployment — декларативне управління Pod","/tools/kubernetes/deployment-basics","07.tools/02.kubernetes/06.deployment-basics",{"title":2767,"path":2768,"stem":2769},"Rolling Updates та управління життєвим циклом Deployment","/tools/kubernetes/deployment-rolling-updates","07.tools/02.kubernetes/07.deployment-rolling-updates",{"title":2771,"path":2772,"stem":2773},"Service — мережева абстракція для Pod","/tools/kubernetes/services-networking","07.tools/02.kubernetes/08.services-networking",{"title":2775,"icon":2776,"path":2777,"stem":2778,"children":2779,"page":59},"Software Engineering","i-lucide-code-2","/software-engineering","09.software-engineering",[2780,2784,2788,2792,2796,2800,2804,2808,2812,2816,2820],{"title":2781,"path":2782,"stem":2783},"1. Аналіз предметної області. Експертні знання та складність","/software-engineering/intro-subdomains","09.software-engineering/01.intro-subdomains",{"title":2785,"path":2786,"stem":2787},"2. Обмежені контексти. Інтеграція обмежених контекстів","/software-engineering/integrating-limited-contexts","09.software-engineering/02.integrating-limited-contexts",{"title":2789,"path":2790,"stem":2791},"3. Реалізація простої бізнес-логіки","/software-engineering/simple","09.software-engineering/03.simple",{"title":2793,"path":2794,"stem":2795},"4. Опрацювання складної бізнес-логіки","/software-engineering/complex-business-logic","09.software-engineering/04.complex-business-logic",{"title":2797,"path":2798,"stem":2799},"5. Моделювання фактора часу. Подієво-орієнтована архітектура.","/software-engineering/modelling-the-time-factor","09.software-engineering/05.modelling-the-time-factor",{"title":2801,"path":2802,"stem":2803},"6. Архітектурні патерни","/software-engineering/architectural-patterns","09.software-engineering/06.architectural-patterns",{"title":2805,"path":2806,"stem":2807},"Паттерни взаємодії","/software-engineering/patterns-of-interaction","09.software-engineering/07.patterns-of-interaction",{"title":2809,"path":2810,"stem":2811},"Евристика проєктування","/software-engineering/design-heuristics","09.software-engineering/08.design-heuristics",{"title":2813,"path":2814,"stem":2815},"Еволюція проєктних рішень","/software-engineering/evolution-of-design-solutions","09.software-engineering/09.evolution-of-design-solutions",{"title":2817,"path":2818,"stem":2819},"EventStorming","/software-engineering/eventstorming","09.software-engineering/10.eventstorming",{"title":2821,"path":2822,"stem":2823},"DDD на практиці","/software-engineering/ddd-in-practice","09.software-engineering/11.ddd-in-practice",{"title":2825,"icon":943,"path":2826,"stem":2827,"children":2828,"page":59},"DDD","/ddd","10.ddd",[2829,2833,2837,2841,2845,2849,2853,2857,2861,2865,2869,2873,2877],{"title":2830,"path":2831,"stem":2832},"Аналіз предметної області","/ddd/domain-analysis","10.ddd/01.domain-analysis",{"title":2834,"path":2835,"stem":2836},"Експертні знання про предметну область","/ddd/domain-expert-knowledge","10.ddd/02.domain-expert-knowledge",{"title":2838,"path":2839,"stem":2840},"Як осмислити складність предметної області","/ddd/managing-domain-complexity","10.ddd/03.managing-domain-complexity",{"title":2842,"path":2843,"stem":2844},"Інтеграція обмежених контекстів","/ddd/bounded-context-integration","10.ddd/04.bounded-context-integration",{"title":2846,"path":2847,"stem":2848},"Реалізація простої бізнес-логіки","/ddd/simple-business-logic","10.ddd/05.simple-business-logic",{"title":2850,"path":2851,"stem":2852},"Обробка складної бізнес-логіки","/ddd/complex-business-logic","10.ddd/06.complex-business-logic",{"title":2854,"path":2855,"stem":2856},"Моделювання фактора часу","/ddd/time-modeling","10.ddd/07.time-modeling",{"title":2858,"path":2859,"stem":2860},"Глава 8. Архітектурні Патерни","/ddd/architectural-patterns","10.ddd/08.architectural-patterns",{"title":2862,"path":2863,"stem":2864},"Глава 9. Патерни Взаємодії","/ddd/interaction-patterns","10.ddd/09.interaction-patterns",{"title":2866,"path":2867,"stem":2868},"Глава 10. Проектні Евристики","/ddd/design-heuristics","10.ddd/10.design-heuristics",{"title":2870,"path":2871,"stem":2872},"Глава 11. Еволюція Проектних Рішень","/ddd/evolution-of-design-decisions","10.ddd/11.evolution-of-design-decisions",{"title":2874,"path":2875,"stem":2876},"Глава 12. EventStorming","/ddd/event-storming","10.ddd/12.event-storming",{"title":2878,"path":2879,"stem":2880},"Глава 13. DDD на Практиці","/ddd/ddd-in-practice","10.ddd/13.ddd-in-practice",{"title":2882,"icon":2883,"path":2884,"stem":2885,"children":2886,"page":59},"Media Streaming","i-lucide-video","/media-streaming","11.media-streaming",[2887,2891,2895,2899,2903,2907,2911],{"title":2888,"path":2889,"stem":2890},"01. Магія Стрімінгу: Що відбувається, коли ви натискаєте \"Play\"","/media-streaming/introduction","11.media-streaming/01.introduction",{"title":2892,"path":2893,"stem":2894},"02. Анатомія Медіа: Кодеки, Контейнери та Стиснення","/media-streaming/audio-video-anatomy","11.media-streaming/02.audio-video-anatomy",{"title":2896,"path":2897,"stem":2898},"03. The Gym: FFmpeg Deep Dive","/media-streaming/ffmpeg-gym","11.media-streaming/03.ffmpeg-gym",{"title":2900,"path":2901,"stem":2902},"04. HLS Protocol: HTTP Live Streaming у Деталях","/media-streaming/hls-protocol","11.media-streaming/04.hls-protocol",{"title":2904,"path":2905,"stem":2906},"05. DASH Protocol: Відкритий Стандарт","/media-streaming/dash-protocol","11.media-streaming/05.dash-protocol",{"title":2908,"path":2909,"stem":2910},"06. Масштабування: CDN та Adaptive Bitrate","/media-streaming/cdn-and-adaptive-bitrate","11.media-streaming/06.cdn-and-adaptive-bitrate",{"title":2912,"path":2913,"stem":2914},"07. Війна із Затримкою (Latency)","/media-streaming/realtime-latency","11.media-streaming/07.realtime-latency",{"title":2916,"icon":2917,"path":2918,"stem":2919,"children":2920,"page":59},"HTML & CSS","i-devicon-html5","/html-css","12.html-css",[2921,2925,2929,2933,2937,2941,2945,2949,2953,2957,2961,2965,2969,2973,2977,2981,2985,2989,2993,2997,3001,3005,3009,3013,3017,3021,3025,3029,3033,3037],{"title":2922,"path":2923,"stem":2924},"Вступ до HTML. Структура документа","/html-css/intro-html-structure","12.html-css/01.intro-html-structure",{"title":2926,"path":2927,"stem":2928},"Форматування тексту в HTML","/html-css/html-text-formatting","12.html-css/02.html-text-formatting",{"title":2930,"path":2931,"stem":2932},"Посилання та зображення в HTML","/html-css/html-links-images","12.html-css/03.html-links-images",{"title":2934,"path":2935,"stem":2936},"Списки та таблиці в HTML","/html-css/html-lists-tables","12.html-css/04.html-lists-tables",{"title":2938,"path":2939,"stem":2940},"Форми в HTML","/html-css/html-forms","12.html-css/05.html-forms",{"title":2942,"path":2943,"stem":2944},"Семантичні елементи HTML5","/html-css/html-semantic-elements","12.html-css/06.html-semantic-elements",{"title":2946,"path":2947,"stem":2948},"Мультимедіа та розширені елементи HTML","/html-css/html-multimedia-advanced","12.html-css/07.html-multimedia-advanced",{"title":2950,"path":2951,"stem":2952},"Мікророзмітка та SEO в HTML","/html-css/html-microdata-seo","12.html-css/08.html-microdata-seo",{"title":2954,"path":2955,"stem":2956},"Вступ до CSS. Селектори та специфічність","/html-css/css-intro-selectors","12.html-css/09.css-intro-selectors",{"title":2958,"path":2959,"stem":2960},"Блокова модель CSS. Відступи. Box Sizing","/html-css/css-box-model","12.html-css/10.css-box-model",{"title":2962,"path":2963,"stem":2964},"Розміри у CSS: повний довідник одиниць і ключових слів","/html-css/10a.css-sizing","12.html-css/10a.css-sizing",{"title":2966,"path":2967,"stem":2968},"Типографіка в CSS. Шрифти та текст","/html-css/css-typography","12.html-css/11.css-typography",{"title":2970,"path":2971,"stem":2972},"Кольори та фони в CSS","/html-css/css-colors-backgrounds","12.html-css/12.css-colors-backgrounds",{"title":2974,"path":2975,"stem":2976},"Тіні та фільтри в CSS","/html-css/12b.css-shadows-filters","12.html-css/12b.css-shadows-filters",{"title":2978,"path":2979,"stem":2980},"CSS Flexbox: Фундамент гнучких макетів","/html-css/css-flexbox-fundamentals","12.html-css/13.css-flexbox-fundamentals",{"title":2982,"path":2983,"stem":2984},"CSS Flexbox: Вирівнювання та Позиціонування","/html-css/css-flexbox-alignment-sizing-and-patterns","12.html-css/14.css-flexbox-alignment-sizing-and-patterns",{"title":2986,"path":2987,"stem":2988},"CSS Grid. Двовимірний макет. Частина 1","/html-css/css-layout-grid","12.html-css/15.css-layout-grid",{"title":2990,"path":2991,"stem":2992},"CSS Grid. Двовимірний макет. Частина 2","/html-css/css-layout-grid-advanced","12.html-css/16.css-layout-grid-advanced",{"title":2994,"path":2995,"stem":2996},"Позиціонування в CSS. Z-index. Stacking Context","/html-css/css-positioning","12.html-css/17.css-positioning",{"title":2998,"path":2999,"stem":3000},"CSS Анімації та Переходи","/html-css/css-animations-transitions","12.html-css/18.css-animations-transitions",{"title":3002,"path":3003,"stem":3004},"Адаптивний дизайн. Media Queries. Частина 1","/html-css/css-responsive-media-queries","12.html-css/19.css-responsive-media-queries",{"title":3006,"path":3007,"stem":3008},"Адаптивний дизайн. Частина 2: clamp(), Container Queries, @layer","/html-css/css-responsive-advanced","12.html-css/20.css-responsive-advanced",{"title":3010,"path":3011,"stem":3012},"CSS Custom Properties. Методології. Сучасний CSS","/html-css/css-variables-methodologies","12.html-css/21.css-variables-methodologies",{"title":3014,"path":3015,"stem":3016},"Сучасний CSS 2023–2025: Нові можливості","/html-css/css-modern-features","12.html-css/22.css-modern-features",{"title":3018,"path":3019,"stem":3020},"CSS Nesting, @layer, @scope та @property: нативний препроцесор","/html-css/22a.css-nesting-modern-syntax","12.html-css/22a.css-nesting-modern-syntax",{"title":3022,"path":3023,"stem":3024},"CSS для форм та інтерактивних станів","/html-css/css-forms-interactive-states","12.html-css/23.css-forms-interactive-states",{"title":3026,"path":3027,"stem":3028},"Доступність у CSS (CSS Accessibility)","/html-css/css-accessibility","12.html-css/24.css-accessibility",{"title":3030,"path":3031,"stem":3032},"CSS-функції та сучасні sizing primitives","/html-css/css-functions-sizing","12.html-css/25.css-functions-sizing",{"title":3034,"path":3035,"stem":3036},"Rendering Pipeline і CSS Performance","/html-css/css-rendering-performance","12.html-css/26.css-rendering-performance",{"title":3038,"path":3039,"stem":3040},"CSS Best Practices: типові ситуації та правильні рішення","/html-css/css-best-practices","12.html-css/27.css-best-practices",{"title":3042,"path":3043,"stem":3044,"children":3045,"page":59},"AWS","/aws","13.aws",[3046,3050,3054],{"title":3047,"path":3048,"stem":3049},"Реєстрація AWS акаунту та студентські програми","/aws/account-registration","13.aws/00.account-registration",{"title":3051,"path":3052,"stem":3053},"Вступ до хмарних обчислень та AWS","/aws/introduction-to-cloud","13.aws/01.introduction-to-cloud",{"title":3055,"path":3056,"stem":3057},"AWS IAM — Identity and Access Management","/aws/iam","13.aws/02.iam",{"title":3059,"path":3060,"stem":3061,"children":3062,"page":59},"Tailwind","/tailwind","21.tailwind",[3063,3067,3071,3075,3079,3083,3087,3091],{"title":3064,"path":3065,"stem":3066},"Що таке Tailwind CSS і навіщо він потрібен","/tailwind/tailwind-intro-philosophy","21.tailwind/01.tailwind-intro-philosophy",{"title":3068,"path":3069,"stem":3070},"Встановлення та налаштування Tailwind CSS v4","/tailwind/tailwind-installation-setup","21.tailwind/02.tailwind-installation-setup",{"title":3072,"path":3073,"stem":3074},"Utility-класи: основи та система Tailwind","/tailwind/tailwind-utility-classes-core","21.tailwind/03.tailwind-utility-classes-core",{"title":3076,"path":3077,"stem":3078},"Layout: Flexbox та Grid через Tailwind","/tailwind/tailwind-flexbox-grid","21.tailwind/04.tailwind-flexbox-grid",{"title":3080,"path":3081,"stem":3082},"Кастомізація теми через @theme у Tailwind v4","/tailwind/tailwind-theme-customization","21.tailwind/05.tailwind-theme-customization",{"title":3084,"path":3085,"stem":3086},"Варіанти: hover, focus, responsive, dark mode та нові v4","/tailwind/tailwind-variants-states","21.tailwind/06.tailwind-variants-states",{"title":3088,"path":3089,"stem":3090},"Типографіка та система кольорів у Tailwind v4","/tailwind/tailwind-typography-colors","21.tailwind/07.tailwind-typography-colors",{"title":3092,"path":3093,"stem":3094},"Компоненти та повторюваність: @apply, @utility та патерни","/tailwind/tailwind-components-patterns","21.tailwind/08.tailwind-components-patterns",{"title":3096,"path":3097,"stem":3098},"Тестування компонентів діаграм","/test-components","98.test-components",{"id":3100,"title":2679,"body":3101,"description":6274,"extension":6275,"links":6276,"meta":6277,"navigation":3330,"path":2680,"seo":6278,"stem":2681,"__hash__":6279},"docs/07.tools/01.docker/04.installation.md",{"type":3102,"value":3103,"toc":6217},"minimark",[3104,3108,3113,3117,3120,3129,3132,3136,3139,3144,3150,3156,3166,3172,3178,3182,3188,3194,3211,3217,3221,3227,3233,3241,3246,3250,3254,3260,3266,3271,3276,3278,3282,3285,3289,3292,3364,3367,3371,3374,3549,3560,3564,3567,3639,3642,3681,3685,3688,3711,3718,3741,3744,3752,3761,3869,3873,3876,3916,3918,3922,3925,3929,3935,3940,3999,4008,4040,4047,4051,4054,4106,4113,4117,4123,4143,4146,4212,4215,4218,4234,4241,4243,4247,4250,4254,4261,4278,4281,4285,4327,4330,4341,4344,4347,4413,4417,4423,4433,4439,4442,4444,4448,4454,4458,4461,4496,4499,4510,4513,4542,4545,4576,4580,4605,4607,4618,4621,4624,4671,4675,4678,4689,4692,4714,4717,4719,4723,4726,4730,4737,4748,4751,4757,4760,4766,4772,4778,4788,4795,4799,4805,4816,4819,4825,4835,4848,4854,4860,4869,4875,4878,4882,4888,4901,4904,4931,4934,4940,4943,4945,4949,4952,4956,4959,4965,4968,5012,5019,5051,5054,5088,5091,5095,5098,5149,5152,5156,5159,5298,5301,5309,5311,5315,5318,5322,5332,5338,5346,5351,5397,5401,5415,5420,5471,5476,5489,5493,5498,5502,5566,5570,5578,5582,5636,5640,5645,5649,5716,5723,5725,5729,5732,5737,5743,5749,5754,5759,5771,5777,5784,5786,5790,5794,5797,5874,5879,5890,5894,5897,5956,5960,5971,5975,5981,6080,6083,6117,6121,6133,6137,6140,6210,6213],[3105,3106,2679],"h1",{"id":3107},"встановлення-docker",[3109,3110,3112],"h2",{"id":3111},"від-теорії-до-практики","Від теорії до практики",[3114,3115,3116],"p",{},"У попередніх статтях ми розглянули концептуальні основи контейнеризації, історію Docker та його внутрішню архітектуру. Тепер настав час перейти від теорії до практики — встановити Docker на вашу робочу машину та виконати перші команди.",[3114,3118,3119],{},"Встановлення Docker — це не просто завантаження та запуск інсталятора. Це процес, який вимагає розуміння особливостей вашої операційної системи, вимог до апаратного забезпечення та правильного налаштування після встановлення. У цій статті ми детально розглянемо встановлення Docker на трьох основних платформах: Linux, macOS та Windows, з акцентом на CLI-підхід та розуміння того, що відбувається \"під капотом\".",[3121,3122,3123,3124,3128],"note",{},"Ця стаття фокусується на встановленні ",[3125,3126,3127],"strong",{},"Docker Engine"," — основного компонента для роботи з контейнерами через командний рядок. Docker Desktop (GUI-інструмент) згадується лише там, де це необхідно для macOS та Windows.",[3130,3131],"hr",{},[3109,3133,3135],{"id":3134},"системні-вимоги","Системні вимоги",[3114,3137,3138],{},"Перш ніж розпочати встановлення, важливо переконатися, що ваша система відповідає мінімальним вимогам Docker. Хоча Docker є відносно легковісним, він має певні залежності від операційної системи та апаратного забезпечення.",[3140,3141,3143],"h3",{"id":3142},"загальні-вимоги","Загальні вимоги",[3114,3145,3146,3149],{},[3125,3147,3148],{},"64-бітна архітектура",": Docker підтримує лише 64-бітні системи (x86_64/amd64 або ARM64/aarch64). 32-бітні системи не підтримуються.",[3114,3151,3152,3155],{},[3125,3153,3154],{},"Віртуалізація",": На Windows та macOS Docker використовує віртуалізацію для запуску Linux-ядра. Переконайтеся, що віртуалізація увімкнена в BIOS/UEFI:",[3157,3158,3159,3163],"ul",{},[3160,3161,3162],"li",{},"Intel: VT-x (Intel Virtualization Technology)",[3160,3164,3165],{},"AMD: AMD-V (AMD Virtualization)",[3114,3167,3168,3171],{},[3125,3169,3170],{},"Оперативна пам'ять",": Мінімум 4 ГБ RAM, рекомендовано 8 ГБ або більше для комфортної роботи з кількома контейнерами.",[3114,3173,3174,3177],{},[3125,3175,3176],{},"Дисковий простір",": Мінімум 10 ГБ вільного місця для Docker Engine та образів. Для активної розробки рекомендовано 50+ ГБ.",[3140,3179,3181],{"id":3180},"вимоги-для-linux","Вимоги для Linux",[3114,3183,3184,3187],{},[3125,3185,3186],{},"Ядро Linux",": версія 3.10 або новіша (рекомендовано 5.x для повної підтримки всіх функцій)",[3114,3189,3190,3193],{},[3125,3191,3192],{},"Дистрибутиви",": Docker офіційно підтримує:",[3157,3195,3196,3199,3202,3205,3208],{},[3160,3197,3198],{},"Ubuntu 20.04 LTS, 22.04 LTS, 24.04 LTS",[3160,3200,3201],{},"Debian 10 (Buster), 11 (Bullseye), 12 (Bookworm)",[3160,3203,3204],{},"Fedora 38, 39, 40",[3160,3206,3207],{},"CentOS 7, 8 (через CentOS Stream)",[3160,3209,3210],{},"RHEL 7, 8, 9",[3114,3212,3213,3216],{},[3125,3214,3215],{},"Архітектура",": x86_64 (amd64), ARM64 (aarch64), ARMv7 (armhf)",[3140,3218,3220],{"id":3219},"вимоги-для-macos","Вимоги для macOS",[3114,3222,3223,3226],{},[3125,3224,3225],{},"Версія macOS",": macOS Monterey (12) або новіша (станом на 2026 рік підтримуються macOS 12, 13, 14, 15)",[3114,3228,3229,3232],{},[3125,3230,3231],{},"Процесор",":",[3157,3234,3235,3238],{},[3160,3236,3237],{},"Intel Core i5 або новіший (для Intel Mac)",[3160,3239,3240],{},"Apple Silicon (M1, M2, M3, M4) — нативна підтримка ARM64",[3114,3242,3243,3245],{},[3125,3244,3154],{},": Hypervisor.framework (вбудований у macOS, додаткове налаштування не потрібне)",[3247,3248,3249],"tip",{},"На Apple Silicon (M1/M2/M3/M4) Docker працює нативно через ARM64, що забезпечує відмінну продуктивність. Більшість популярних образів (включно з офіційними .NET образами) мають ARM64-варіанти.",[3140,3251,3253],{"id":3252},"вимоги-для-windows","Вимоги для Windows",[3114,3255,3256,3259],{},[3125,3257,3258],{},"Версія Windows",": Windows 10 версії 21H2 або новіша, Windows 11",[3114,3261,3262,3265],{},[3125,3263,3264],{},"WSL 2",": Windows Subsystem for Linux версії 2 — обов'язкова для Docker Desktop",[3114,3267,3268,3270],{},[3125,3269,3154],{},": Hyper-V або WSL 2 backend (WSL 2 рекомендовано)",[3114,3272,3273,3275],{},[3125,3274,3231],{},": 64-бітний процесор з підтримкою SLAT (Second Level Address Translation)",[3130,3277],{},[3109,3279,3281],{"id":3280},"встановлення-на-linux-ubuntudebian","Встановлення на Linux (Ubuntu/Debian)",[3114,3283,3284],{},"Linux — це нативна платформа для Docker, оскільки Docker використовує можливості ядра Linux (namespaces, cgroups). На Linux ми встановлюємо Docker Engine безпосередньо, без проміжних шарів віртуалізації.",[3140,3286,3288],{"id":3287},"підготовка-системи","Підготовка системи",[3114,3290,3291],{},"Перш за все, оновимо список пакетів та встановимо необхідні залежності:",[3293,3294,3299],"pre",{"className":3295,"code":3296,"language":3297,"meta":3298,"style":3298},"language-bash shiki shiki-themes light-plus dark-plus dark-plus","# Оновлення індексу пакетів\nsudo apt update\n\n# Встановлення залежностей для роботи з HTTPS-репозиторіями\nsudo apt install -y ca-certificates curl gnupg lsb-release\n","bash","",[3300,3301,3302,3311,3325,3332,3338],"code",{"__ignoreMap":3298},[3303,3304,3307],"span",{"class":3305,"line":3306},"line",1,[3303,3308,3310],{"class":3309},"spJ8K","# Оновлення індексу пакетів\n",[3303,3312,3314,3318,3322],{"class":3305,"line":3313},2,[3303,3315,3317],{"class":3316},"s8Opu","sudo",[3303,3319,3321],{"class":3320},"sbdoH"," apt",[3303,3323,3324],{"class":3320}," update\n",[3303,3326,3328],{"class":3305,"line":3327},3,[3303,3329,3331],{"emptyLinePlaceholder":3330},true,"\n",[3303,3333,3335],{"class":3305,"line":3334},4,[3303,3336,3337],{"class":3309},"# Встановлення залежностей для роботи з HTTPS-репозиторіями\n",[3303,3339,3341,3343,3345,3348,3352,3355,3358,3361],{"class":3305,"line":3340},5,[3303,3342,3317],{"class":3316},[3303,3344,3321],{"class":3320},[3303,3346,3347],{"class":3320}," install",[3303,3349,3351],{"class":3350},"su1O8"," -y",[3303,3353,3354],{"class":3320}," ca-certificates",[3303,3356,3357],{"class":3320}," curl",[3303,3359,3360],{"class":3320}," gnupg",[3303,3362,3363],{"class":3320}," lsb-release\n",[3114,3365,3366],{},"Ці пакети необхідні для безпечного завантаження Docker з офіційного репозиторію через HTTPS.",[3140,3368,3370],{"id":3369},"додавання-офіційного-репозиторію-docker","Додавання офіційного репозиторію Docker",[3114,3372,3373],{},"Docker не входить до стандартних репозиторіїв Ubuntu/Debian, тому ми додамо офіційний репозиторій Docker:",[3293,3375,3377],{"className":3295,"code":3376,"language":3297,"meta":3298,"style":3298},"# Створення директорії для GPG-ключів\nsudo install -m 0755 -d /etc/apt/keyrings\n\n# Завантаження офіційного GPG-ключа Docker\nsudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg \\\n  -o /etc/apt/keyrings/docker.asc\n\n# Встановлення прав доступу до ключа\nsudo chmod a+r /etc/apt/keyrings/docker.asc\n\n# Додавання репозиторію Docker до списку джерел APT\necho \"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] \\\n  https://download.docker.com/linux/ubuntu \\\n  $(. /etc/os-release && echo \"$VERSION_CODENAME\") stable\" | \\\n  sudo tee /etc/apt/sources.list.d/docker.list > /dev/null\n",[3300,3378,3379,3384,3403,3407,3412,3428,3437,3442,3448,3461,3466,3472,3493,3501,3531],{"__ignoreMap":3298},[3303,3380,3381],{"class":3305,"line":3306},[3303,3382,3383],{"class":3309},"# Створення директорії для GPG-ключів\n",[3303,3385,3386,3388,3390,3393,3397,3400],{"class":3305,"line":3313},[3303,3387,3317],{"class":3316},[3303,3389,3347],{"class":3320},[3303,3391,3392],{"class":3350}," -m",[3303,3394,3396],{"class":3395},"sJj4R"," 0755",[3303,3398,3399],{"class":3350}," -d",[3303,3401,3402],{"class":3320}," /etc/apt/keyrings\n",[3303,3404,3405],{"class":3305,"line":3327},[3303,3406,3331],{"emptyLinePlaceholder":3330},[3303,3408,3409],{"class":3305,"line":3334},[3303,3410,3411],{"class":3309},"# Завантаження офіційного GPG-ключа Docker\n",[3303,3413,3414,3416,3418,3421,3424],{"class":3305,"line":3340},[3303,3415,3317],{"class":3316},[3303,3417,3357],{"class":3320},[3303,3419,3420],{"class":3350}," -fsSL",[3303,3422,3423],{"class":3320}," https://download.docker.com/linux/ubuntu/gpg",[3303,3425,3427],{"class":3426},"sjcCO"," \\\n",[3303,3429,3431,3434],{"class":3305,"line":3430},6,[3303,3432,3433],{"class":3350},"  -o",[3303,3435,3436],{"class":3320}," /etc/apt/keyrings/docker.asc\n",[3303,3438,3440],{"class":3305,"line":3439},7,[3303,3441,3331],{"emptyLinePlaceholder":3330},[3303,3443,3445],{"class":3305,"line":3444},8,[3303,3446,3447],{"class":3309},"# Встановлення прав доступу до ключа\n",[3303,3449,3451,3453,3456,3459],{"class":3305,"line":3450},9,[3303,3452,3317],{"class":3316},[3303,3454,3455],{"class":3320}," chmod",[3303,3457,3458],{"class":3320}," a+r",[3303,3460,3436],{"class":3320},[3303,3462,3464],{"class":3305,"line":3463},10,[3303,3465,3331],{"emptyLinePlaceholder":3330},[3303,3467,3469],{"class":3305,"line":3468},11,[3303,3470,3471],{"class":3309},"# Додавання репозиторію Docker до списку джерел APT\n",[3303,3473,3475,3478,3481,3484,3487,3490],{"class":3305,"line":3474},12,[3303,3476,3477],{"class":3316},"echo",[3303,3479,3480],{"class":3320}," \"deb [arch=$(",[3303,3482,3483],{"class":3316},"dpkg",[3303,3485,3486],{"class":3350}," --print-architecture",[3303,3488,3489],{"class":3320},") signed-by=/etc/apt/keyrings/docker.asc] ",[3303,3491,3492],{"class":3426},"\\\n",[3303,3494,3496,3499],{"class":3305,"line":3495},13,[3303,3497,3498],{"class":3320},"  https://download.docker.com/linux/ubuntu ",[3303,3500,3492],{"class":3426},[3303,3502,3504,3507,3510,3513,3515,3518,3522,3525,3529],{"class":3305,"line":3503},14,[3303,3505,3506],{"class":3320},"  $(",[3303,3508,3509],{"class":3316},".",[3303,3511,3512],{"class":3320}," /etc/os-release && ",[3303,3514,3477],{"class":3316},[3303,3516,3517],{"class":3320}," \"",[3303,3519,3521],{"class":3520},"siwwj","$VERSION_CODENAME",[3303,3523,3524],{"class":3320},"\") stable\"",[3303,3526,3528],{"class":3527},"sHH4Y"," | ",[3303,3530,3492],{"class":3426},[3303,3532,3534,3537,3540,3543,3546],{"class":3305,"line":3533},15,[3303,3535,3536],{"class":3316},"  sudo",[3303,3538,3539],{"class":3320}," tee",[3303,3541,3542],{"class":3320}," /etc/apt/sources.list.d/docker.list",[3303,3544,3545],{"class":3527}," > ",[3303,3547,3548],{"class":3320},"/dev/null\n",[3121,3550,3551,3552,3555,3556,3559],{},"Для Debian замініть ",[3300,3553,3554],{},"ubuntu"," на ",[3300,3557,3558],{},"debian"," в URL репозиторію. Решта команд залишаються ідентичними.",[3140,3561,3563],{"id":3562},"встановлення-docker-engine","Встановлення Docker Engine",[3114,3565,3566],{},"Тепер встановимо Docker Engine та супутні компоненти:",[3293,3568,3570],{"className":3295,"code":3569,"language":3297,"meta":3298,"style":3298},"# Оновлення індексу пакетів з новим репозиторієм\nsudo apt update\n\n# Встановлення Docker Engine, CLI, containerd та плагінів\nsudo apt install -y \\\n  docker-ce \\\n  docker-ce-cli \\\n  containerd.io \\\n  docker-buildx-plugin \\\n  docker-compose-plugin\n",[3300,3571,3572,3577,3585,3589,3594,3606,3613,3620,3627,3634],{"__ignoreMap":3298},[3303,3573,3574],{"class":3305,"line":3306},[3303,3575,3576],{"class":3309},"# Оновлення індексу пакетів з новим репозиторієм\n",[3303,3578,3579,3581,3583],{"class":3305,"line":3313},[3303,3580,3317],{"class":3316},[3303,3582,3321],{"class":3320},[3303,3584,3324],{"class":3320},[3303,3586,3587],{"class":3305,"line":3327},[3303,3588,3331],{"emptyLinePlaceholder":3330},[3303,3590,3591],{"class":3305,"line":3334},[3303,3592,3593],{"class":3309},"# Встановлення Docker Engine, CLI, containerd та плагінів\n",[3303,3595,3596,3598,3600,3602,3604],{"class":3305,"line":3340},[3303,3597,3317],{"class":3316},[3303,3599,3321],{"class":3320},[3303,3601,3347],{"class":3320},[3303,3603,3351],{"class":3350},[3303,3605,3427],{"class":3426},[3303,3607,3608,3611],{"class":3305,"line":3430},[3303,3609,3610],{"class":3320},"  docker-ce",[3303,3612,3427],{"class":3426},[3303,3614,3615,3618],{"class":3305,"line":3439},[3303,3616,3617],{"class":3320},"  docker-ce-cli",[3303,3619,3427],{"class":3426},[3303,3621,3622,3625],{"class":3305,"line":3444},[3303,3623,3624],{"class":3320},"  containerd.io",[3303,3626,3427],{"class":3426},[3303,3628,3629,3632],{"class":3305,"line":3450},[3303,3630,3631],{"class":3320},"  docker-buildx-plugin",[3303,3633,3427],{"class":3426},[3303,3635,3636],{"class":3305,"line":3463},[3303,3637,3638],{"class":3320},"  docker-compose-plugin\n",[3114,3640,3641],{},"Розберемо, що встановлюється:",[3157,3643,3644,3654,3663,3669,3675],{},[3160,3645,3646,3649,3650,3653],{},[3125,3647,3648],{},"docker-ce"," (Community Edition) — Docker Engine (демон ",[3300,3651,3652],{},"dockerd",")",[3160,3655,3656,3659,3660,3653],{},[3125,3657,3658],{},"docker-ce-cli"," — Docker CLI (команда ",[3300,3661,3662],{},"docker",[3160,3664,3665,3668],{},[3125,3666,3667],{},"containerd.io"," — containerd runtime",[3160,3670,3671,3674],{},[3125,3672,3673],{},"docker-buildx-plugin"," — розширений builder для multi-platform образів",[3160,3676,3677,3680],{},[3125,3678,3679],{},"docker-compose-plugin"," — Docker Compose v2 як плагін CLI",[3140,3682,3684],{"id":3683},"перевірка-встановлення","Перевірка встановлення",[3114,3686,3687],{},"Після встановлення Docker Daemon автоматично запускається. Перевіримо статус:",[3293,3689,3691],{"className":3295,"code":3690,"language":3297,"meta":3298,"style":3298},"# Перевірка статусу Docker Daemon\nsudo systemctl status docker\n",[3300,3692,3693,3698],{"__ignoreMap":3298},[3303,3694,3695],{"class":3305,"line":3306},[3303,3696,3697],{"class":3309},"# Перевірка статусу Docker Daemon\n",[3303,3699,3700,3702,3705,3708],{"class":3305,"line":3313},[3303,3701,3317],{"class":3316},[3303,3703,3704],{"class":3320}," systemctl",[3303,3706,3707],{"class":3320}," status",[3303,3709,3710],{"class":3320}," docker\n",[3114,3712,3713,3714,3717],{},"Ви повинні побачити ",[3300,3715,3716],{},"active (running)"," у виводі. Тепер виконаємо тестовий запуск контейнера:",[3293,3719,3721],{"className":3295,"code":3720,"language":3297,"meta":3298,"style":3298},"# Запуск тестового контейнера hello-world\nsudo docker run hello-world\n",[3300,3722,3723,3728],{"__ignoreMap":3298},[3303,3724,3725],{"class":3305,"line":3306},[3303,3726,3727],{"class":3309},"# Запуск тестового контейнера hello-world\n",[3303,3729,3730,3732,3735,3738],{"class":3305,"line":3313},[3303,3731,3317],{"class":3316},[3303,3733,3734],{"class":3320}," docker",[3303,3736,3737],{"class":3320}," run",[3303,3739,3740],{"class":3320}," hello-world\n",[3114,3742,3743],{},"Якщо все налаштовано правильно, ви побачите повідомлення:",[3293,3745,3750],{"className":3746,"code":3748,"language":3749},[3747],"language-text","Hello from Docker!\nThis message shows that your installation appears to be working correctly.\n","text",[3300,3751,3748],{"__ignoreMap":3298},[3114,3753,3754],{},[3755,3756],"img",{"alt":3757,"className":3758,"src":3760},"docker engine installation process step by step flow on linux",[3759],"diagram-img","/images/tools/docker/installation/01.png",[3762,3763,3764],"plant-uml",{},[3293,3765,3769],{"className":3766,"code":3767,"language":3768,"meta":3298,"style":3298},"language-plantuml shiki shiki-themes light-plus dark-plus dark-plus","@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\nskinparam ArrowColor #2563eb\nskinparam ActivityBorderColor #3b82f6\nskinparam ActivityBackgroundColor #eff6ff\nskinparam ActivityStartColor #10b981\nskinparam ActivityEndColor #ef4444\n\nstart\n:Оновлення індексу пакетів\\n(sudo apt update);\n:Встановлення HTTPS-залежностей\\n(ca-certificates, curl, gnupg);\n:Завантаження GPG-ключа Docker;\n:Додавання офіційного APT репозиторію;\n:Встановлення пакетів Docker\\n(docker-ce, docker-ce-cli, containerd.io);\n:Автоматичний запуск Docker Daemon\\n(active/running);\n:Запуск тестового контейнера\\n(sudo docker run hello-world);\nstop\n@enduml\n","plantuml",[3300,3770,3771,3776,3781,3786,3791,3796,3801,3806,3811,3815,3820,3825,3830,3835,3840,3845,3851,3857,3863],{"__ignoreMap":3298},[3303,3772,3773],{"class":3305,"line":3306},[3303,3774,3775],{},"@startuml\n",[3303,3777,3778],{"class":3305,"line":3313},[3303,3779,3780],{},"skinparam style plain\n",[3303,3782,3783],{"class":3305,"line":3327},[3303,3784,3785],{},"skinparam backgroundColor #ffffff\n",[3303,3787,3788],{"class":3305,"line":3334},[3303,3789,3790],{},"skinparam ArrowColor #2563eb\n",[3303,3792,3793],{"class":3305,"line":3340},[3303,3794,3795],{},"skinparam ActivityBorderColor #3b82f6\n",[3303,3797,3798],{"class":3305,"line":3430},[3303,3799,3800],{},"skinparam ActivityBackgroundColor #eff6ff\n",[3303,3802,3803],{"class":3305,"line":3439},[3303,3804,3805],{},"skinparam ActivityStartColor #10b981\n",[3303,3807,3808],{"class":3305,"line":3444},[3303,3809,3810],{},"skinparam ActivityEndColor #ef4444\n",[3303,3812,3813],{"class":3305,"line":3450},[3303,3814,3331],{"emptyLinePlaceholder":3330},[3303,3816,3817],{"class":3305,"line":3463},[3303,3818,3819],{},"start\n",[3303,3821,3822],{"class":3305,"line":3468},[3303,3823,3824],{},":Оновлення індексу пакетів\\n(sudo apt update);\n",[3303,3826,3827],{"class":3305,"line":3474},[3303,3828,3829],{},":Встановлення HTTPS-залежностей\\n(ca-certificates, curl, gnupg);\n",[3303,3831,3832],{"class":3305,"line":3495},[3303,3833,3834],{},":Завантаження GPG-ключа Docker;\n",[3303,3836,3837],{"class":3305,"line":3503},[3303,3838,3839],{},":Додавання офіційного APT репозиторію;\n",[3303,3841,3842],{"class":3305,"line":3533},[3303,3843,3844],{},":Встановлення пакетів Docker\\n(docker-ce, docker-ce-cli, containerd.io);\n",[3303,3846,3848],{"class":3305,"line":3847},16,[3303,3849,3850],{},":Автоматичний запуск Docker Daemon\\n(active/running);\n",[3303,3852,3854],{"class":3305,"line":3853},17,[3303,3855,3856],{},":Запуск тестового контейнера\\n(sudo docker run hello-world);\n",[3303,3858,3860],{"class":3305,"line":3859},18,[3303,3861,3862],{},"stop\n",[3303,3864,3866],{"class":3305,"line":3865},19,[3303,3867,3868],{},"@enduml\n",[3140,3870,3872],{"id":3871},"що-відбулося-під-час-встановлення","Що відбулося під час встановлення?",[3114,3874,3875],{},"Коли ви встановили Docker Engine, система виконала кілька важливих дій:",[3877,3878,3879,3889,3900,3910],"ol",{},[3160,3880,3881,3884,3885,3888],{},[3125,3882,3883],{},"Створено systemd service",": файл ",[3300,3886,3887],{},"/lib/systemd/system/docker.service"," визначає, як запускати Docker Daemon",[3160,3890,3891,3894,3895,3897,3898],{},[3125,3892,3893],{},"Створено групу docker",": група ",[3300,3896,3662],{}," дозволяє користувачам взаємодіяти з демоном без ",[3300,3899,3317],{},[3160,3901,3902,3905,3906,3909],{},[3125,3903,3904],{},"Створено socket",": ",[3300,3907,3908],{},"/var/run/docker.sock"," — точка входу для Docker CLI",[3160,3911,3912,3915],{},[3125,3913,3914],{},"Налаштовано автозапуск",": Docker Daemon буде автоматично запускатися при завантаженні системи",[3130,3917],{},[3109,3919,3921],{"id":3920},"post-installation-налаштування-для-зручності","Post-Installation: налаштування для зручності",[3114,3923,3924],{},"Після встановлення Docker на Linux є кілька важливих кроків, які зроблять роботу з Docker зручнішою та безпечнішою.",[3140,3926,3928],{"id":3927},"додавання-користувача-до-групи-docker","Додавання користувача до групи docker",[3114,3930,3931,3932,3934],{},"За замовчуванням Docker Daemon працює з правами root, і для взаємодії з ним потрібно використовувати ",[3300,3933,3317],{}," перед кожною командою. Це незручно та може призвести до помилок (наприклад, створення файлів з правами root).",[3114,3936,3937,3938,3232],{},"Рішення — додати вашого користувача до групи ",[3300,3939,3662],{},[3293,3941,3943],{"className":3295,"code":3942,"language":3297,"meta":3298,"style":3298},"# Створення групи docker (якщо вона ще не існує)\nsudo groupadd docker\n\n# Додавання поточного користувача до групи docker\nsudo usermod -aG docker $USER\n\n# Застосування змін (альтернатива перелогіну)\nnewgrp docker\n",[3300,3944,3945,3950,3959,3963,3968,3983,3987,3992],{"__ignoreMap":3298},[3303,3946,3947],{"class":3305,"line":3306},[3303,3948,3949],{"class":3309},"# Створення групи docker (якщо вона ще не існує)\n",[3303,3951,3952,3954,3957],{"class":3305,"line":3313},[3303,3953,3317],{"class":3316},[3303,3955,3956],{"class":3320}," groupadd",[3303,3958,3710],{"class":3320},[3303,3960,3961],{"class":3305,"line":3327},[3303,3962,3331],{"emptyLinePlaceholder":3330},[3303,3964,3965],{"class":3305,"line":3334},[3303,3966,3967],{"class":3309},"# Додавання поточного користувача до групи docker\n",[3303,3969,3970,3972,3975,3978,3980],{"class":3305,"line":3340},[3303,3971,3317],{"class":3316},[3303,3973,3974],{"class":3320}," usermod",[3303,3976,3977],{"class":3350}," -aG",[3303,3979,3734],{"class":3320},[3303,3981,3982],{"class":3520}," $USER\n",[3303,3984,3985],{"class":3305,"line":3430},[3303,3986,3331],{"emptyLinePlaceholder":3330},[3303,3988,3989],{"class":3305,"line":3439},[3303,3990,3991],{"class":3309},"# Застосування змін (альтернатива перелогіну)\n",[3303,3993,3994,3997],{"class":3305,"line":3444},[3303,3995,3996],{"class":3316},"newgrp",[3303,3998,3710],{"class":3320},[3114,4000,4001,4002,4005,4006,3232],{},"Після цього вийдіть з системи та увійдіть знову (або виконайте ",[3300,4003,4004],{},"newgrp docker","), щоб зміни набули чинності. Тепер ви можете виконувати команди Docker без ",[3300,4007,3317],{},[3293,4009,4011],{"className":3295,"code":4010,"language":3297,"meta":3298,"style":3298},"# Тепер працює без sudo\ndocker run hello-world\ndocker ps\ndocker images\n",[3300,4012,4013,4018,4026,4033],{"__ignoreMap":3298},[3303,4014,4015],{"class":3305,"line":3306},[3303,4016,4017],{"class":3309},"# Тепер працює без sudo\n",[3303,4019,4020,4022,4024],{"class":3305,"line":3313},[3303,4021,3662],{"class":3316},[3303,4023,3737],{"class":3320},[3303,4025,3740],{"class":3320},[3303,4027,4028,4030],{"class":3305,"line":3327},[3303,4029,3662],{"class":3316},[3303,4031,4032],{"class":3320}," ps\n",[3303,4034,4035,4037],{"class":3305,"line":3334},[3303,4036,3662],{"class":3316},[3303,4038,4039],{"class":3320}," images\n",[4041,4042,4043,4044,4046],"warning",{},"Додавання користувача до групи ",[3300,4045,3662],{}," надає йому фактично root-привілеї на системі, оскільки через Docker можна монтувати будь-які директорії хоста та виконувати команди з підвищеними правами. Робіть це лише для довірених користувачів.",[3140,4048,4050],{"id":4049},"налаштування-автозапуску-docker-daemon","Налаштування автозапуску Docker Daemon",[3114,4052,4053],{},"Переконаємося, що Docker Daemon запускається автоматично при завантаженні системи:",[3293,4055,4057],{"className":3295,"code":4056,"language":3297,"meta":3298,"style":3298},"# Увімкнення автозапуску Docker\nsudo systemctl enable docker.service\nsudo systemctl enable containerd.service\n\n# Перевірка статусу\nsystemctl is-enabled docker.service\n",[3300,4058,4059,4064,4076,4087,4091,4096],{"__ignoreMap":3298},[3303,4060,4061],{"class":3305,"line":3306},[3303,4062,4063],{"class":3309},"# Увімкнення автозапуску Docker\n",[3303,4065,4066,4068,4070,4073],{"class":3305,"line":3313},[3303,4067,3317],{"class":3316},[3303,4069,3704],{"class":3320},[3303,4071,4072],{"class":3320}," enable",[3303,4074,4075],{"class":3320}," docker.service\n",[3303,4077,4078,4080,4082,4084],{"class":3305,"line":3327},[3303,4079,3317],{"class":3316},[3303,4081,3704],{"class":3320},[3303,4083,4072],{"class":3320},[3303,4085,4086],{"class":3320}," containerd.service\n",[3303,4088,4089],{"class":3305,"line":3334},[3303,4090,3331],{"emptyLinePlaceholder":3330},[3303,4092,4093],{"class":3305,"line":3340},[3303,4094,4095],{"class":3309},"# Перевірка статусу\n",[3303,4097,4098,4101,4104],{"class":3305,"line":3430},[3303,4099,4100],{"class":3316},"systemctl",[3303,4102,4103],{"class":3320}," is-enabled",[3303,4105,4075],{"class":3320},[3114,4107,4108,4109,4112],{},"Якщо вивід ",[3300,4110,4111],{},"enabled"," — все налаштовано правильно.",[3140,4114,4116],{"id":4115},"налаштування-логування","Налаштування логування",[3114,4118,4119,4120,3232],{},"За замовчуванням Docker зберігає логи контейнерів у JSON-файлах, які можуть необмежено зростати. Налаштуємо ротацію логів через ",[3300,4121,4122],{},"/etc/docker/daemon.json",[3293,4124,4126],{"className":3295,"code":4125,"language":3297,"meta":3298,"style":3298},"# Створення конфігураційного файлу\nsudo nano /etc/docker/daemon.json\n",[3300,4127,4128,4133],{"__ignoreMap":3298},[3303,4129,4130],{"class":3305,"line":3306},[3303,4131,4132],{"class":3309},"# Створення конфігураційного файлу\n",[3303,4134,4135,4137,4140],{"class":3305,"line":3313},[3303,4136,3317],{"class":3316},[3303,4138,4139],{"class":3320}," nano",[3303,4141,4142],{"class":3320}," /etc/docker/daemon.json\n",[3114,4144,4145],{},"Додайте наступний вміст:",[3293,4147,4151],{"className":4148,"code":4149,"language":4150,"meta":3298,"style":3298},"language-json shiki shiki-themes light-plus dark-plus dark-plus","{\n  \"log-driver\": \"json-file\",\n  \"log-opts\": {\n    \"max-size\": \"10m\",\n    \"max-file\": \"3\"\n  }\n}\n","json",[3300,4152,4153,4158,4172,4180,4192,4202,4207],{"__ignoreMap":3298},[3303,4154,4155],{"class":3305,"line":3306},[3303,4156,4157],{"class":3527},"{\n",[3303,4159,4160,4164,4166,4169],{"class":3305,"line":3313},[3303,4161,4163],{"class":4162},"sLwNe","  \"log-driver\"",[3303,4165,3905],{"class":3527},[3303,4167,4168],{"class":3320},"\"json-file\"",[3303,4170,4171],{"class":3527},",\n",[3303,4173,4174,4177],{"class":3305,"line":3327},[3303,4175,4176],{"class":4162},"  \"log-opts\"",[3303,4178,4179],{"class":3527},": {\n",[3303,4181,4182,4185,4187,4190],{"class":3305,"line":3334},[3303,4183,4184],{"class":4162},"    \"max-size\"",[3303,4186,3905],{"class":3527},[3303,4188,4189],{"class":3320},"\"10m\"",[3303,4191,4171],{"class":3527},[3303,4193,4194,4197,4199],{"class":3305,"line":3340},[3303,4195,4196],{"class":4162},"    \"max-file\"",[3303,4198,3905],{"class":3527},[3303,4200,4201],{"class":3320},"\"3\"\n",[3303,4203,4204],{"class":3305,"line":3430},[3303,4205,4206],{"class":3527},"  }\n",[3303,4208,4209],{"class":3305,"line":3439},[3303,4210,4211],{"class":3527},"}\n",[3114,4213,4214],{},"Це обмежить розмір кожного лог-файлу до 10 МБ та збереже максимум 3 файли (загалом 30 МБ на контейнер).",[3114,4216,4217],{},"Після зміни конфігурації перезапустіть демон:",[3293,4219,4221],{"className":3295,"code":4220,"language":3297,"meta":3298,"style":3298},"sudo systemctl restart docker\n",[3300,4222,4223],{"__ignoreMap":3298},[3303,4224,4225,4227,4229,4232],{"class":3305,"line":3306},[3303,4226,3317],{"class":3316},[3303,4228,3704],{"class":3320},[3303,4230,4231],{"class":3320}," restart",[3303,4233,3710],{"class":3320},[3247,4235,4236,4237,4240],{},"Файл ",[3300,4238,4239],{},"daemon.json"," — це центральне місце для конфігурації Docker Daemon. Тут можна налаштувати storage driver, мережеві параметри, insecure registries та багато іншого. Детальніше про конфігурацію ми поговоримо в наступних статтях.",[3130,4242],{},[3109,4244,4246],{"id":4245},"встановлення-на-macos","Встановлення на macOS",[3114,4248,4249],{},"На macOS Docker не може працювати нативно, оскільки macOS не має ядра Linux з підтримкою namespaces та cgroups. Тому Docker на macOS працює через віртуалізацію — запускається легковісна Linux-віртуальна машина, всередині якої працює Docker Engine.",[3140,4251,4253],{"id":4252},"docker-desktop-for-mac","Docker Desktop for Mac",[3114,4255,4256,4257,4260],{},"Офіційний спосіб встановлення Docker на macOS — це ",[3125,4258,4259],{},"Docker Desktop",", який включає:",[3157,4262,4263,4266,4269,4272,4275],{},[3160,4264,4265],{},"Docker Engine (працює у віртуальній машині)",[3160,4267,4268],{},"Docker CLI (нативний macOS бінарник)",[3160,4270,4271],{},"Docker Compose",[3160,4273,4274],{},"Kubernetes (опціонально)",[3160,4276,4277],{},"GUI для управління контейнерами",[3121,4279,4280],{},"На відміну від Linux, де можна встановити лише Docker Engine через CLI, на macOS Docker Desktop є єдиним офіційно підтримуваним способом встановлення. Альтернативи (наприклад, Colima) існують, але виходять за межі цього курсу.",[3140,4282,4284],{"id":4283},"завантаження-та-встановлення","Завантаження та встановлення",[3877,4286,4287,4297,4314,4321,4324],{},[3160,4288,4289,4290],{},"Відвідайте ",[4291,4292,4296],"a",{"href":4293,"rel":4294},"https://www.docker.com/products/docker-desktop/",[4295],"nofollow","офіційний сайт Docker",[3160,4298,4299,4300],{},"Завантажте Docker Desktop для Mac:",[3157,4301,4302,4308],{},[3160,4303,4304,4307],{},[3125,4305,4306],{},"Intel Mac",": завантажте версію для x86_64",[3160,4309,4310,4313],{},[3125,4311,4312],{},"Apple Silicon (M1/M2/M3/M4)",": завантажте версію для ARM64",[3160,4315,4316,4317,4320],{},"Відкрийте завантажений ",[3300,4318,4319],{},".dmg"," файл",[3160,4322,4323],{},"Перетягніть Docker.app у папку Applications",[3160,4325,4326],{},"Запустіть Docker з папки Applications",[3114,4328,4329],{},"При першому запуску Docker Desktop:",[3157,4331,4332,4335,4338],{},[3160,4333,4334],{},"Попросить права адміністратора (для встановлення мережевих компонентів)",[3160,4336,4337],{},"Створить віртуальну машину для Docker Engine",[3160,4339,4340],{},"Налаштує Docker CLI у вашому PATH",[3140,4342,3684],{"id":4343},"перевірка-встановлення-1",[3114,4345,4346],{},"Відкрийте Terminal та виконайте:",[3293,4348,4350],{"className":3295,"code":4349,"language":3297,"meta":3298,"style":3298},"# Перевірка версії Docker\ndocker --version\n\n# Детальна інформація про Docker\ndocker version\n\n# Інформація про систему\ndocker info\n\n# Тестовий запуск\ndocker run hello-world\n",[3300,4351,4352,4357,4364,4368,4373,4380,4384,4389,4396,4400,4405],{"__ignoreMap":3298},[3303,4353,4354],{"class":3305,"line":3306},[3303,4355,4356],{"class":3309},"# Перевірка версії Docker\n",[3303,4358,4359,4361],{"class":3305,"line":3313},[3303,4360,3662],{"class":3316},[3303,4362,4363],{"class":3350}," --version\n",[3303,4365,4366],{"class":3305,"line":3327},[3303,4367,3331],{"emptyLinePlaceholder":3330},[3303,4369,4370],{"class":3305,"line":3334},[3303,4371,4372],{"class":3309},"# Детальна інформація про Docker\n",[3303,4374,4375,4377],{"class":3305,"line":3340},[3303,4376,3662],{"class":3316},[3303,4378,4379],{"class":3320}," version\n",[3303,4381,4382],{"class":3305,"line":3430},[3303,4383,3331],{"emptyLinePlaceholder":3330},[3303,4385,4386],{"class":3305,"line":3439},[3303,4387,4388],{"class":3309},"# Інформація про систему\n",[3303,4390,4391,4393],{"class":3305,"line":3444},[3303,4392,3662],{"class":3316},[3303,4394,4395],{"class":3320}," info\n",[3303,4397,4398],{"class":3305,"line":3450},[3303,4399,3331],{"emptyLinePlaceholder":3330},[3303,4401,4402],{"class":3305,"line":3463},[3303,4403,4404],{"class":3309},"# Тестовий запуск\n",[3303,4406,4407,4409,4411],{"class":3305,"line":3468},[3303,4408,3662],{"class":3316},[3303,4410,3737],{"class":3320},[3303,4412,3740],{"class":3320},[3140,4414,4416],{"id":4415},"особливості-docker-на-macos","Особливості Docker на macOS",[3114,4418,4419,4422],{},[3125,4420,4421],{},"Файлова система",": Docker на macOS використовує VirtioFS для монтування директорій хоста у контейнери. Це швидше за попередні рішення (osxfs), але все одно повільніше, ніж нативний Linux.",[3114,4424,4425,4428,4429,4432],{},[3125,4426,4427],{},"Мережа",": Контейнери працюють у віртуальній машині, тому мережева взаємодія проходить через додатковий шар. Для доступу до контейнера з хоста використовуйте ",[3300,4430,4431],{},"localhost"," та проброшені порти.",[3114,4434,4435,4438],{},[3125,4436,4437],{},"Ресурси",": Docker Desktop дозволяє налаштувати, скільки CPU, RAM та дискового простору виділити віртуальній машині. За замовчуванням це 50% доступних ресурсів.",[3247,4440,4441],{},"На Apple Silicon Docker працює дуже ефективно завдяки нативній підтримці ARM64. Більшість популярних образів (Node.js, Python, .NET, PostgreSQL) мають ARM64-варіанти. Для x86_64 образів Docker використовує Rosetta 2 для емуляції, що працює дивовижно швидко.",[3130,4443],{},[3109,4445,4447],{"id":4446},"встановлення-на-windows","Встановлення на Windows",[3114,4449,4450,4451,4453],{},"Windows, як і macOS, не має нативної підтримки Linux-контейнерів. Docker на Windows працює через ",[3125,4452,3264],{}," (Windows Subsystem for Linux 2) — повноцінне Linux-ядро, інтегроване у Windows.",[3140,4455,4457],{"id":4456},"підготовка-встановлення-wsl-2","Підготовка: встановлення WSL 2",[3114,4459,4460],{},"Перш ніж встановлювати Docker Desktop, потрібно налаштувати WSL 2:",[3293,4462,4466],{"className":4463,"code":4464,"language":4465,"meta":3298,"style":3298},"language-powershell shiki shiki-themes light-plus dark-plus dark-plus","# Відкрийте PowerShell від імені адміністратора\n\n# Увімкнення WSL\nwsl --install\n\n# Перезавантажте комп'ютер після встановлення\n","powershell",[3300,4467,4468,4473,4477,4482,4487,4491],{"__ignoreMap":3298},[3303,4469,4470],{"class":3305,"line":3306},[3303,4471,4472],{"class":3309},"# Відкрийте PowerShell від імені адміністратора\n",[3303,4474,4475],{"class":3305,"line":3313},[3303,4476,3331],{"emptyLinePlaceholder":3330},[3303,4478,4479],{"class":3305,"line":3327},[3303,4480,4481],{"class":3309},"# Увімкнення WSL\n",[3303,4483,4484],{"class":3305,"line":3334},[3303,4485,4486],{"class":3527},"wsl --install\n",[3303,4488,4489],{"class":3305,"line":3340},[3303,4490,3331],{"emptyLinePlaceholder":3330},[3303,4492,4493],{"class":3305,"line":3430},[3303,4494,4495],{"class":3309},"# Перезавантажте комп'ютер після встановлення\n",[3114,4497,4498],{},"Ця команда:",[3157,4500,4501,4504,4507],{},[3160,4502,4503],{},"Увімкне необхідні компоненти Windows (Virtual Machine Platform, WSL)",[3160,4505,4506],{},"Завантажить та встановить Linux-ядро для WSL 2",[3160,4508,4509],{},"Встановить Ubuntu як дистрибутив за замовчуванням",[3114,4511,4512],{},"Після перезавантаження перевірте версію WSL:",[3293,4514,4516],{"className":4463,"code":4515,"language":4465,"meta":3298,"style":3298},"# Перевірка версії WSL\nwsl --version\n\n# Перевірка встановлених дистрибутивів\nwsl --list --verbose\n",[3300,4517,4518,4523,4528,4532,4537],{"__ignoreMap":3298},[3303,4519,4520],{"class":3305,"line":3306},[3303,4521,4522],{"class":3309},"# Перевірка версії WSL\n",[3303,4524,4525],{"class":3305,"line":3313},[3303,4526,4527],{"class":3527},"wsl --version\n",[3303,4529,4530],{"class":3305,"line":3327},[3303,4531,3331],{"emptyLinePlaceholder":3330},[3303,4533,4534],{"class":3305,"line":3334},[3303,4535,4536],{"class":3309},"# Перевірка встановлених дистрибутивів\n",[3303,4538,4539],{"class":3305,"line":3340},[3303,4540,4541],{"class":3527},"wsl --list --verbose\n",[3114,4543,4544],{},"Переконайтеся, що ваш дистрибутив використовує WSL 2 (колонка VERSION має показувати 2). Якщо ні, конвертуйте:",[3293,4546,4548],{"className":4463,"code":4547,"language":4465,"meta":3298,"style":3298},"wsl --set-version Ubuntu 2\nwsl --set-default-version 2\n",[3300,4549,4550,4564],{"__ignoreMap":3298},[3303,4551,4552,4555,4558,4561],{"class":3305,"line":3306},[3303,4553,4554],{"class":3527},"wsl --",[3303,4556,4557],{"class":3316},"set-version",[3303,4559,4560],{"class":3527}," Ubuntu ",[3303,4562,4563],{"class":3395},"2\n",[3303,4565,4566,4568,4571,4574],{"class":3305,"line":3313},[3303,4567,4554],{"class":3527},[3303,4569,4570],{"class":3316},"set-default",[3303,4572,4573],{"class":3527},"-version ",[3303,4575,4563],{"class":3395},[3140,4577,4579],{"id":4578},"встановлення-docker-desktop","Встановлення Docker Desktop",[3877,4581,4582,4589,4595,4602],{},[3160,4583,4584,4585],{},"Завантажте ",[4291,4586,4588],{"href":4293,"rel":4587},[4295],"Docker Desktop for Windows",[3160,4590,4591,4592],{},"Запустіть інсталятор ",[3300,4593,4594],{},"Docker Desktop Installer.exe",[3160,4596,4597,4598,4601],{},"Під час встановлення переконайтеся, що опція ",[3125,4599,4600],{},"\"Use WSL 2 instead of Hyper-V\""," увімкнена",[3160,4603,4604],{},"Завершіть встановлення та перезавантажте комп'ютер",[3114,4606,4329],{},[3157,4608,4609,4612,4615],{},[3160,4610,4611],{},"Інтегрується з WSL 2",[3160,4613,4614],{},"Налаштує Docker Engine у WSL-дистрибутиві",[3160,4616,4617],{},"Зробить Docker CLI доступним як у PowerShell/CMD, так і у WSL",[3140,4619,3684],{"id":4620},"перевірка-встановлення-2",[3114,4622,4623],{},"У PowerShell або WSL виконайте:",[3293,4625,4627],{"className":3295,"code":4626,"language":3297,"meta":3298,"style":3298},"# Перевірка версії\ndocker --version\n\n# Детальна інформація\ndocker version\n\n# Тестовий запуск\ndocker run hello-world\n",[3300,4628,4629,4634,4640,4644,4649,4655,4659,4663],{"__ignoreMap":3298},[3303,4630,4631],{"class":3305,"line":3306},[3303,4632,4633],{"class":3309},"# Перевірка версії\n",[3303,4635,4636,4638],{"class":3305,"line":3313},[3303,4637,3662],{"class":3316},[3303,4639,4363],{"class":3350},[3303,4641,4642],{"class":3305,"line":3327},[3303,4643,3331],{"emptyLinePlaceholder":3330},[3303,4645,4646],{"class":3305,"line":3334},[3303,4647,4648],{"class":3309},"# Детальна інформація\n",[3303,4650,4651,4653],{"class":3305,"line":3340},[3303,4652,3662],{"class":3316},[3303,4654,4379],{"class":3320},[3303,4656,4657],{"class":3305,"line":3430},[3303,4658,3331],{"emptyLinePlaceholder":3330},[3303,4660,4661],{"class":3305,"line":3439},[3303,4662,4404],{"class":3309},[3303,4664,4665,4667,4669],{"class":3305,"line":3444},[3303,4666,3662],{"class":3316},[3303,4668,3737],{"class":3320},[3303,4670,3740],{"class":3320},[3140,4672,4674],{"id":4673},"інтеграція-з-wsl-дистрибутивами","Інтеграція з WSL дистрибутивами",[3114,4676,4677],{},"Docker Desktop може інтегруватися з кількома WSL-дистрибутивами. Налаштування:",[3877,4679,4680,4683,4686],{},[3160,4681,4682],{},"Відкрийте Docker Desktop",[3160,4684,4685],{},"Settings → Resources → WSL Integration",[3160,4687,4688],{},"Увімкніть інтеграцію для потрібних дистрибутивів (Ubuntu, Debian тощо)",[3114,4690,4691],{},"Тепер Docker CLI буде доступний всередині WSL:",[3293,4693,4695],{"className":3295,"code":4694,"language":3297,"meta":3298,"style":3298},"# У WSL (наприклад, Ubuntu)\ndocker ps\ndocker images\n",[3300,4696,4697,4702,4708],{"__ignoreMap":3298},[3303,4698,4699],{"class":3305,"line":3306},[3303,4700,4701],{"class":3309},"# У WSL (наприклад, Ubuntu)\n",[3303,4703,4704,4706],{"class":3305,"line":3313},[3303,4705,3662],{"class":3316},[3303,4707,4032],{"class":3320},[3303,4709,4710,4712],{"class":3305,"line":3327},[3303,4711,3662],{"class":3316},[3303,4713,4039],{"class":3320},[3121,4715,4716],{},"Docker Desktop на Windows підтримує як Linux-контейнери (через WSL 2), так і Windows-контейнери (через Hyper-V). За замовчуванням використовуються Linux-контейнери, оскільки більшість образів створені для Linux. Перемикання між режимами доступне через контекстне меню Docker Desktop.",[3130,4718],{},[3109,4720,4722],{"id":4721},"перевірка-встановлення-основні-команди","Перевірка встановлення: основні команди",[3114,4724,4725],{},"Після встановлення Docker на будь-якій платформі важливо переконатися, що все працює коректно. Розглянемо ключові команди для діагностики.",[3140,4727,4729],{"id":4728},"docker-version-детальна-інформація-про-версії","docker version: детальна інформація про версії",[3114,4731,4732,4733,4736],{},"Команда ",[3300,4734,4735],{},"docker version"," показує версії клієнта та сервера (демона):",[3293,4738,4740],{"className":3295,"code":4739,"language":3297,"meta":3298,"style":3298},"docker version\n",[3300,4741,4742],{"__ignoreMap":3298},[3303,4743,4744,4746],{"class":3305,"line":3306},[3303,4745,3662],{"class":3316},[3303,4747,4379],{"class":3320},[3114,4749,4750],{},"Типовий вивід:",[3293,4752,4755],{"className":4753,"code":4754,"language":3749},[3747],"Client:\n Version:           24.0.7\n API version:       1.43\n Go version:        go1.21.5\n Git commit:        afdd53b\n Built:             Thu Dec 14 10:28:22 2023\n OS/Arch:           linux/amd64\n Context:           default\n\nServer: Docker Engine - Community\n Engine:\n  Version:          24.0.7\n  API version:      1.43 (minimum version 1.12)\n  Go version:       go1.21.5\n  Git commit:       311b9ff\n  Built:            Thu Dec 14 10:28:22 2023\n  OS/Arch:          linux/amd64\n  Experimental:     false\n containerd:\n  Version:          1.7.11\n  GitCommit:        64b8a811b07ba6288238eefc14d898ee0b5b99ba\n runc:\n  Version:          1.1.11\n  GitCommit:        v1.1.11-0-g4bccb38\n docker-init:\n  Version:          0.19.0\n  GitCommit:        de40ad0\n",[3300,4756,4754],{"__ignoreMap":3298},[3114,4758,4759],{},"Що показує цей вивід:",[3114,4761,4762,4765],{},[3125,4763,4764],{},"Client"," — версія Docker CLI на вашій машині. Це інструмент, який ви використовуєте для виконання команд.",[3114,4767,4768,4771],{},[3125,4769,4770],{},"Server"," — версія Docker Engine (демона). Це процес, який фактично управляє контейнерами.",[3114,4773,4774,4777],{},[3125,4775,4776],{},"API version"," — версія Docker API, яку використовує клієнт для спілкування з сервером. Docker підтримує зворотну сумісність — новіший сервер може працювати зі старішим клієнтом.",[3114,4779,4780,4783,4784,4787],{},[3125,4781,4782],{},"containerd"," та ",[3125,4785,4786],{},"runc"," — версії низькорівневих компонентів, які ми розглядали в статті про архітектуру.",[3247,4789,4790,4791,4794],{},"Якщо ви бачите помилку \"Cannot connect to the Docker daemon\", це означає, що Docker Daemon не запущений. На Linux виконайте ",[3300,4792,4793],{},"sudo systemctl start docker",", на macOS/Windows запустіть Docker Desktop.",[3140,4796,4798],{"id":4797},"docker-info-системна-інформація","docker info: системна інформація",[3114,4800,4732,4801,4804],{},[3300,4802,4803],{},"docker info"," показує детальну інформацію про конфігурацію Docker:",[3293,4806,4808],{"className":3295,"code":4807,"language":3297,"meta":3298,"style":3298},"docker info\n",[3300,4809,4810],{"__ignoreMap":3298},[3303,4811,4812,4814],{"class":3305,"line":3306},[3303,4813,3662],{"class":3316},[3303,4815,4395],{"class":3320},[3114,4817,4818],{},"Ключові параметри у виводі:",[3114,4820,4821,4824],{},[3125,4822,4823],{},"Server Version"," — версія Docker Engine",[3114,4826,4827,4830,4831,4834],{},[3125,4828,4829],{},"Storage Driver"," — драйвер файлової системи (зазвичай ",[3300,4832,4833],{},"overlay2"," на Linux)",[3114,4836,4837,4840,4841,4844,4845,3653],{},[3125,4838,4839],{},"Cgroup Driver"," — драйвер для управління cgroups (",[3300,4842,4843],{},"cgroupfs"," або ",[3300,4846,4847],{},"systemd",[3114,4849,4850,4853],{},[3125,4851,4852],{},"Containers"," — кількість контейнерів (запущених, зупинених, призупинених)",[3114,4855,4856,4859],{},[3125,4857,4858],{},"Images"," — кількість локально збережених образів",[3114,4861,4862,4865,4866,3653],{},[3125,4863,4864],{},"Docker Root Dir"," — директорія, де Docker зберігає дані (зазвичай ",[3300,4867,4868],{},"/var/lib/docker",[3114,4870,4871,4874],{},[3125,4872,4873],{},"Registry"," — адреса реєстру за замовчуванням (Docker Hub)",[3114,4876,4877],{},"Ця команда корисна для діагностики проблем та розуміння поточної конфігурації системи.",[3140,4879,4881],{"id":4880},"docker-run-hello-world-перший-контейнер","docker run hello-world: перший контейнер",[3114,4883,4732,4884,4887],{},[3300,4885,4886],{},"docker run hello-world"," — це традиційний \"Hello World\" для Docker:",[3293,4889,4891],{"className":3295,"code":4890,"language":3297,"meta":3298,"style":3298},"docker run hello-world\n",[3300,4892,4893],{"__ignoreMap":3298},[3303,4894,4895,4897,4899],{"class":3305,"line":3306},[3303,4896,3662],{"class":3316},[3303,4898,3737],{"class":3320},[3303,4900,3740],{"class":3320},[3114,4902,4903],{},"Що відбувається при виконанні цієї команди:",[3877,4905,4906,4909,4916,4919,4922,4925,4928],{},[3160,4907,4908],{},"Docker CLI відправляє запит до Docker Daemon",[3160,4910,4911,4912,4915],{},"Демон перевіряє, чи є образ ",[3300,4913,4914],{},"hello-world"," локально",[3160,4917,4918],{},"Якщо образу немає, демон завантажує його з Docker Hub",[3160,4920,4921],{},"Демон створює контейнер з образу",[3160,4923,4924],{},"Демон запускає контейнер",[3160,4926,4927],{},"Контейнер виводить повідомлення та завершується",[3160,4929,4930],{},"Демон повертає вивід контейнера до CLI",[3114,4932,4933],{},"Успішний вивід:",[3293,4935,4938],{"className":4936,"code":4937,"language":3749},[3747],"Unable to find image 'hello-world:latest' locally\nlatest: Pulling from library/hello-world\nc1ec31eb5944: Pull complete\nDigest: sha256:4bd78111b6914a99dbc560e6a20eab57ff6655aea4a80c50b0c5491968cbc2e6\nStatus: Downloaded newer image for hello-world:latest\n\nHello from Docker!\nThis message shows that your installation appears to be working correctly.\n\nTo generate this message, Docker took the following steps:\n 1. The Docker client contacted the Docker daemon.\n 2. The Docker daemon pulled the \"hello-world\" image from the Docker Hub.\n 3. The Docker daemon created a new container from that image which runs the\n    executable that produces the output you are currently reading.\n 4. The Docker daemon streamed that output to the Docker client, which sent it\n    to your terminal.\n",[3300,4939,4937],{"__ignoreMap":3298},[3114,4941,4942],{},"Це повідомлення підтверджує, що вся архітектура Docker працює коректно: CLI → API → Daemon → containerd → runc → контейнер.",[3130,4944],{},[3109,4946,4948],{"id":4947},"docker-cli-перше-знайомство","Docker CLI: перше знайомство",[3114,4950,4951],{},"Тепер, коли Docker встановлено, розглянемо базову структуру команд Docker CLI.",[3140,4953,4955],{"id":4954},"структура-команд","Структура команд",[3114,4957,4958],{},"Команди Docker мають ієрархічну структуру:",[3293,4960,4963],{"className":4961,"code":4962,"language":3749},[3747],"docker [OPTIONS] COMMAND [ARG...]\n",[3300,4964,4962],{"__ignoreMap":3298},[3114,4966,4967],{},"Наприклад:",[3293,4969,4971],{"className":3295,"code":4970,"language":3297,"meta":3298,"style":3298},"docker container ls --all\ndocker image pull nginx:latest\ndocker network create my-network\n",[3300,4972,4973,4986,4999],{"__ignoreMap":3298},[3303,4974,4975,4977,4980,4983],{"class":3305,"line":3306},[3303,4976,3662],{"class":3316},[3303,4978,4979],{"class":3320}," container",[3303,4981,4982],{"class":3320}," ls",[3303,4984,4985],{"class":3350}," --all\n",[3303,4987,4988,4990,4993,4996],{"class":3305,"line":3313},[3303,4989,3662],{"class":3316},[3303,4991,4992],{"class":3320}," image",[3303,4994,4995],{"class":3320}," pull",[3303,4997,4998],{"class":3320}," nginx:latest\n",[3303,5000,5001,5003,5006,5009],{"class":3305,"line":3327},[3303,5002,3662],{"class":3316},[3303,5004,5005],{"class":3320}," network",[3303,5007,5008],{"class":3320}," create",[3303,5010,5011],{"class":3320}," my-network\n",[3114,5013,5014,5015,5018],{},"Сучасний Docker CLI організований навколо ",[3125,5016,5017],{},"об'єктів"," (objects):",[3157,5020,5021,5027,5033,5039,5045],{},[3160,5022,5023,5026],{},[3300,5024,5025],{},"docker container"," — операції з контейнерами",[3160,5028,5029,5032],{},[3300,5030,5031],{},"docker image"," — операції з образами",[3160,5034,5035,5038],{},[3300,5036,5037],{},"docker network"," — операції з мережами",[3160,5040,5041,5044],{},[3300,5042,5043],{},"docker volume"," — операції з томами",[3160,5046,5047,5050],{},[3300,5048,5049],{},"docker system"," — системні операції",[3114,5052,5053],{},"Для зворотної сумісності існують скорочені команди:",[3293,5055,5057],{"className":3295,"code":5056,"language":3297,"meta":3298,"style":3298},"# Повна форма\ndocker container ls\n\n# Скорочена форма (legacy)\ndocker ps\n",[3300,5058,5059,5064,5073,5077,5082],{"__ignoreMap":3298},[3303,5060,5061],{"class":3305,"line":3306},[3303,5062,5063],{"class":3309},"# Повна форма\n",[3303,5065,5066,5068,5070],{"class":3305,"line":3313},[3303,5067,3662],{"class":3316},[3303,5069,4979],{"class":3320},[3303,5071,5072],{"class":3320}," ls\n",[3303,5074,5075],{"class":3305,"line":3327},[3303,5076,3331],{"emptyLinePlaceholder":3330},[3303,5078,5079],{"class":3305,"line":3334},[3303,5080,5081],{"class":3309},"# Скорочена форма (legacy)\n",[3303,5083,5084,5086],{"class":3305,"line":3340},[3303,5085,3662],{"class":3316},[3303,5087,4032],{"class":3320},[3114,5089,5090],{},"Обидві форми працюють ідентично, але повна форма більш явна та зрозуміла.",[3140,5092,5094],{"id":5093},"отримання-довідки","Отримання довідки",[3114,5096,5097],{},"Docker CLI має вбудовану систему довідки:",[3293,5099,5101],{"className":3295,"code":5100,"language":3297,"meta":3298,"style":3298},"# Загальна довідка\ndocker --help\n\n# Довідка для конкретної команди\ndocker run --help\n\n# Довідка для групи команд\ndocker container --help\n",[3300,5102,5103,5108,5115,5119,5124,5132,5136,5141],{"__ignoreMap":3298},[3303,5104,5105],{"class":3305,"line":3306},[3303,5106,5107],{"class":3309},"# Загальна довідка\n",[3303,5109,5110,5112],{"class":3305,"line":3313},[3303,5111,3662],{"class":3316},[3303,5113,5114],{"class":3350}," --help\n",[3303,5116,5117],{"class":3305,"line":3327},[3303,5118,3331],{"emptyLinePlaceholder":3330},[3303,5120,5121],{"class":3305,"line":3334},[3303,5122,5123],{"class":3309},"# Довідка для конкретної команди\n",[3303,5125,5126,5128,5130],{"class":3305,"line":3340},[3303,5127,3662],{"class":3316},[3303,5129,3737],{"class":3320},[3303,5131,5114],{"class":3350},[3303,5133,5134],{"class":3305,"line":3430},[3303,5135,3331],{"emptyLinePlaceholder":3330},[3303,5137,5138],{"class":3305,"line":3439},[3303,5139,5140],{"class":3309},"# Довідка для групи команд\n",[3303,5142,5143,5145,5147],{"class":3305,"line":3444},[3303,5144,3662],{"class":3316},[3303,5146,4979],{"class":3320},[3303,5148,5114],{"class":3350},[3114,5150,5151],{},"Довідка показує всі доступні опції, приклади використання та посилання на документацію.",[3140,5153,5155],{"id":5154},"основні-команди-для-початку","Основні команди для початку",[3114,5157,5158],{},"Ось команди, які ви будете використовувати найчастіше:",[3293,5160,5162],{"className":3295,"code":5161,"language":3297,"meta":3298,"style":3298},"# Запуск контейнера\ndocker run nginx\n\n# Перегляд запущених контейнерів\ndocker ps\n\n# Перегляд всіх контейнерів (включно зі зупиненими)\ndocker ps -a\n\n# Перегляд локальних образів\ndocker images\n\n# Зупинка контейнера\ndocker stop \u003Ccontainer_id>\n\n# Видалення контейнера\ndocker rm \u003Ccontainer_id>\n\n# Видалення образу\ndocker rmi \u003Cimage_id>\n",[3300,5163,5164,5169,5178,5182,5187,5193,5197,5202,5212,5216,5221,5227,5231,5236,5252,5256,5261,5274,5278,5283],{"__ignoreMap":3298},[3303,5165,5166],{"class":3305,"line":3306},[3303,5167,5168],{"class":3309},"# Запуск контейнера\n",[3303,5170,5171,5173,5175],{"class":3305,"line":3313},[3303,5172,3662],{"class":3316},[3303,5174,3737],{"class":3320},[3303,5176,5177],{"class":3320}," nginx\n",[3303,5179,5180],{"class":3305,"line":3327},[3303,5181,3331],{"emptyLinePlaceholder":3330},[3303,5183,5184],{"class":3305,"line":3334},[3303,5185,5186],{"class":3309},"# Перегляд запущених контейнерів\n",[3303,5188,5189,5191],{"class":3305,"line":3340},[3303,5190,3662],{"class":3316},[3303,5192,4032],{"class":3320},[3303,5194,5195],{"class":3305,"line":3430},[3303,5196,3331],{"emptyLinePlaceholder":3330},[3303,5198,5199],{"class":3305,"line":3439},[3303,5200,5201],{"class":3309},"# Перегляд всіх контейнерів (включно зі зупиненими)\n",[3303,5203,5204,5206,5209],{"class":3305,"line":3444},[3303,5205,3662],{"class":3316},[3303,5207,5208],{"class":3320}," ps",[3303,5210,5211],{"class":3350}," -a\n",[3303,5213,5214],{"class":3305,"line":3450},[3303,5215,3331],{"emptyLinePlaceholder":3330},[3303,5217,5218],{"class":3305,"line":3463},[3303,5219,5220],{"class":3309},"# Перегляд локальних образів\n",[3303,5222,5223,5225],{"class":3305,"line":3468},[3303,5224,3662],{"class":3316},[3303,5226,4039],{"class":3320},[3303,5228,5229],{"class":3305,"line":3474},[3303,5230,3331],{"emptyLinePlaceholder":3330},[3303,5232,5233],{"class":3305,"line":3495},[3303,5234,5235],{"class":3309},"# Зупинка контейнера\n",[3303,5237,5238,5240,5243,5246,5249],{"class":3305,"line":3503},[3303,5239,3662],{"class":3316},[3303,5241,5242],{"class":3320}," stop",[3303,5244,5245],{"class":3527}," \u003C",[3303,5247,5248],{"class":3320},"container_i",[3303,5250,5251],{"class":3527},"d>\n",[3303,5253,5254],{"class":3305,"line":3533},[3303,5255,3331],{"emptyLinePlaceholder":3330},[3303,5257,5258],{"class":3305,"line":3847},[3303,5259,5260],{"class":3309},"# Видалення контейнера\n",[3303,5262,5263,5265,5268,5270,5272],{"class":3305,"line":3853},[3303,5264,3662],{"class":3316},[3303,5266,5267],{"class":3320}," rm",[3303,5269,5245],{"class":3527},[3303,5271,5248],{"class":3320},[3303,5273,5251],{"class":3527},[3303,5275,5276],{"class":3305,"line":3859},[3303,5277,3331],{"emptyLinePlaceholder":3330},[3303,5279,5280],{"class":3305,"line":3865},[3303,5281,5282],{"class":3309},"# Видалення образу\n",[3303,5284,5286,5288,5291,5293,5296],{"class":3305,"line":5285},20,[3303,5287,3662],{"class":3316},[3303,5289,5290],{"class":3320}," rmi",[3303,5292,5245],{"class":3527},[3303,5294,5295],{"class":3320},"image_i",[3303,5297,5251],{"class":3527},[3114,5299,5300],{},"Детальний розбір цих команд буде в наступній статті \"Перший контейнер\".",[3121,5302,5303,5304,4844,5306,5308],{},"Docker CLI підтримує автодоповнення (tab completion) у більшості сучасних shell (bash, zsh, fish). Це значно прискорює роботу — просто натисніть Tab після ",[3300,5305,3662],{},[3300,5307,5025],{},", щоб побачити доступні команди.",[3130,5310],{},[3109,5312,5314],{"id":5313},"troubleshooting-типові-проблеми-при-встановленні","Troubleshooting: типові проблеми при встановленні",[3114,5316,5317],{},"Навіть при дотриманні інструкцій можуть виникнути проблеми. Розглянемо найпоширеніші та способи їх вирішення.",[3140,5319,5321],{"id":5320},"linux-permission-denied-при-доступі-до-docker-socket","Linux: \"permission denied\" при доступі до Docker socket",[3114,5323,5324,5327,5328,5331],{},[3125,5325,5326],{},"Проблема",": При виконанні ",[3300,5329,5330],{},"docker ps"," отримуєте помилку:",[3293,5333,5336],{"className":5334,"code":5335,"language":3749},[3747],"permission denied while trying to connect to the Docker daemon socket\n",[3300,5337,5335],{"__ignoreMap":3298},[3114,5339,5340,5343,5344,3509],{},[3125,5341,5342],{},"Причина",": Ваш користувач не має прав на доступ до ",[3300,5345,3908],{},[3114,5347,5348,3232],{},[3125,5349,5350],{},"Рішення",[3293,5352,5354],{"className":3295,"code":5353,"language":3297,"meta":3298,"style":3298},"# Додайте користувача до групи docker\nsudo usermod -aG docker $USER\n\n# Застосуйте зміни\nnewgrp docker\n\n# Або вийдіть та увійдіть знову\n",[3300,5355,5356,5361,5373,5377,5382,5388,5392],{"__ignoreMap":3298},[3303,5357,5358],{"class":3305,"line":3306},[3303,5359,5360],{"class":3309},"# Додайте користувача до групи docker\n",[3303,5362,5363,5365,5367,5369,5371],{"class":3305,"line":3313},[3303,5364,3317],{"class":3316},[3303,5366,3974],{"class":3320},[3303,5368,3977],{"class":3350},[3303,5370,3734],{"class":3320},[3303,5372,3982],{"class":3520},[3303,5374,5375],{"class":3305,"line":3327},[3303,5376,3331],{"emptyLinePlaceholder":3330},[3303,5378,5379],{"class":3305,"line":3334},[3303,5380,5381],{"class":3309},"# Застосуйте зміни\n",[3303,5383,5384,5386],{"class":3305,"line":3340},[3303,5385,3996],{"class":3316},[3303,5387,3710],{"class":3320},[3303,5389,5390],{"class":3305,"line":3430},[3303,5391,3331],{"emptyLinePlaceholder":3330},[3303,5393,5394],{"class":3305,"line":3439},[3303,5395,5396],{"class":3309},"# Або вийдіть та увійдіть знову\n",[3140,5398,5400],{"id":5399},"linux-docker-daemon-не-запускається","Linux: Docker Daemon не запускається",[3114,5402,5403,3905,5405,5408,5409,4844,5412,3509],{},[3125,5404,5326],{},[3300,5406,5407],{},"systemctl status docker"," показує ",[3300,5410,5411],{},"failed",[3300,5413,5414],{},"inactive",[3114,5416,5417,3232],{},[3125,5418,5419],{},"Діагностика",[3293,5421,5423],{"className":3295,"code":5422,"language":3297,"meta":3298,"style":3298},"# Перегляд логів демона\nsudo journalctl -u docker.service -n 50 --no-pager\n\n# Спроба запуску вручну для детальних помилок\nsudo dockerd --debug\n",[3300,5424,5425,5430,5452,5456,5461],{"__ignoreMap":3298},[3303,5426,5427],{"class":3305,"line":3306},[3303,5428,5429],{"class":3309},"# Перегляд логів демона\n",[3303,5431,5432,5434,5437,5440,5443,5446,5449],{"class":3305,"line":3313},[3303,5433,3317],{"class":3316},[3303,5435,5436],{"class":3320}," journalctl",[3303,5438,5439],{"class":3350}," -u",[3303,5441,5442],{"class":3320}," docker.service",[3303,5444,5445],{"class":3350}," -n",[3303,5447,5448],{"class":3395}," 50",[3303,5450,5451],{"class":3350}," --no-pager\n",[3303,5453,5454],{"class":3305,"line":3327},[3303,5455,3331],{"emptyLinePlaceholder":3330},[3303,5457,5458],{"class":3305,"line":3334},[3303,5459,5460],{"class":3309},"# Спроба запуску вручну для детальних помилок\n",[3303,5462,5463,5465,5468],{"class":3305,"line":3340},[3303,5464,3317],{"class":3316},[3303,5466,5467],{"class":3320}," dockerd",[3303,5469,5470],{"class":3350}," --debug\n",[3114,5472,5473,3232],{},[3125,5474,5475],{},"Типові причини",[3157,5477,5478,5481,5486],{},[3160,5479,5480],{},"Конфлікт портів (якщо налаштовано TCP listener)",[3160,5482,5483,5484],{},"Некоректний ",[3300,5485,4239],{},[3160,5487,5488],{},"Проблеми з storage driver",[3140,5490,5492],{"id":5491},"macos-docker-desktop-не-запускається","macOS: Docker Desktop не запускається",[3114,5494,5495,5497],{},[3125,5496,5326],{},": Docker Desktop показує помилку при запуску або зависає на \"Starting...\".",[3114,5499,5500,3232],{},[3125,5501,5350],{},[3293,5503,5505],{"className":3295,"code":5504,"language":3297,"meta":3298,"style":3298},"# Повне видалення та перевстановлення\n# 1. Видаліть Docker.app\n# 2. Видаліть дані Docker\nrm -rf ~/Library/Group\\ Containers/group.com.docker\nrm -rf ~/Library/Containers/com.docker.docker\nrm -rf ~/.docker\n\n# 3. Перевстановіть Docker Desktop\n",[3300,5506,5507,5512,5517,5522,5539,5548,5557,5561],{"__ignoreMap":3298},[3303,5508,5509],{"class":3305,"line":3306},[3303,5510,5511],{"class":3309},"# Повне видалення та перевстановлення\n",[3303,5513,5514],{"class":3305,"line":3313},[3303,5515,5516],{"class":3309},"# 1. Видаліть Docker.app\n",[3303,5518,5519],{"class":3305,"line":3327},[3303,5520,5521],{"class":3309},"# 2. Видаліть дані Docker\n",[3303,5523,5524,5527,5530,5533,5536],{"class":3305,"line":3334},[3303,5525,5526],{"class":3316},"rm",[3303,5528,5529],{"class":3350}," -rf",[3303,5531,5532],{"class":3320}," ~/Library/Group",[3303,5534,5535],{"class":3426},"\\ ",[3303,5537,5538],{"class":3320},"Containers/group.com.docker\n",[3303,5540,5541,5543,5545],{"class":3305,"line":3340},[3303,5542,5526],{"class":3316},[3303,5544,5529],{"class":3350},[3303,5546,5547],{"class":3320}," ~/Library/Containers/com.docker.docker\n",[3303,5549,5550,5552,5554],{"class":3305,"line":3430},[3303,5551,5526],{"class":3316},[3303,5553,5529],{"class":3350},[3303,5555,5556],{"class":3320}," ~/.docker\n",[3303,5558,5559],{"class":3305,"line":3439},[3303,5560,3331],{"emptyLinePlaceholder":3330},[3303,5562,5563],{"class":3305,"line":3444},[3303,5564,5565],{"class":3309},"# 3. Перевстановіть Docker Desktop\n",[3140,5567,5569],{"id":5568},"windows-wsl-2-не-встановлюється","Windows: WSL 2 не встановлюється",[3114,5571,5572,3905,5574,5577],{},[3125,5573,5326],{},[3300,5575,5576],{},"wsl --install"," завершується з помилкою.",[3114,5579,5580,3232],{},[3125,5581,5350],{},[3293,5583,5585],{"className":4463,"code":5584,"language":4465,"meta":3298,"style":3298},"# Увімкнення необхідних компонентів Windows вручну\ndism.exe /online /enable-feature /featurename:Microsoft-Windows-Subsystem-Linux /all /norestart\ndism.exe /online /enable-feature /featurename:VirtualMachinePlatform /all /norestart\n\n# Перезавантаження\n# Завантаження та встановлення WSL 2 kernel update\n# https://aka.ms/wsl2kernel\n",[3300,5586,5587,5592,5606,5617,5621,5626,5631],{"__ignoreMap":3298},[3303,5588,5589],{"class":3305,"line":3306},[3303,5590,5591],{"class":3309},"# Увімкнення необхідних компонентів Windows вручну\n",[3303,5593,5594,5597,5600,5603],{"class":3305,"line":3313},[3303,5595,5596],{"class":3316},"dism.exe",[3303,5598,5599],{"class":3527}," /online /",[3303,5601,5602],{"class":3316},"enable-feature",[3303,5604,5605],{"class":3527}," /featurename:Microsoft-Windows-Subsystem-Linux /all /norestart\n",[3303,5607,5608,5610,5612,5614],{"class":3305,"line":3327},[3303,5609,5596],{"class":3316},[3303,5611,5599],{"class":3527},[3303,5613,5602],{"class":3316},[3303,5615,5616],{"class":3527}," /featurename:VirtualMachinePlatform /all /norestart\n",[3303,5618,5619],{"class":3305,"line":3334},[3303,5620,3331],{"emptyLinePlaceholder":3330},[3303,5622,5623],{"class":3305,"line":3340},[3303,5624,5625],{"class":3309},"# Перезавантаження\n",[3303,5627,5628],{"class":3305,"line":3430},[3303,5629,5630],{"class":3309},"# Завантаження та встановлення WSL 2 kernel update\n",[3303,5632,5633],{"class":3305,"line":3439},[3303,5634,5635],{"class":3309},"# https://aka.ms/wsl2kernel\n",[3140,5637,5639],{"id":5638},"загальна-проблема-cannot-connect-to-the-docker-daemon","Загальна проблема: \"Cannot connect to the Docker daemon\"",[3114,5641,5642,5644],{},[3125,5643,5326],{},": Docker CLI не може з'єднатися з демоном.",[3114,5646,5647,3232],{},[3125,5648,5419],{},[3293,5650,5652],{"className":3295,"code":5651,"language":3297,"meta":3298,"style":3298},"# Перевірка, чи працює демон\n# Linux:\nsudo systemctl status docker\n\n# macOS/Windows: переконайтеся, що Docker Desktop запущений\n\n# Перевірка змінної DOCKER_HOST\necho $DOCKER_HOST\n\n# Якщо вона встановлена, спробуйте скинути\nunset DOCKER_HOST\n",[3300,5653,5654,5659,5664,5674,5678,5683,5687,5692,5699,5703,5708],{"__ignoreMap":3298},[3303,5655,5656],{"class":3305,"line":3306},[3303,5657,5658],{"class":3309},"# Перевірка, чи працює демон\n",[3303,5660,5661],{"class":3305,"line":3313},[3303,5662,5663],{"class":3309},"# Linux:\n",[3303,5665,5666,5668,5670,5672],{"class":3305,"line":3327},[3303,5667,3317],{"class":3316},[3303,5669,3704],{"class":3320},[3303,5671,3707],{"class":3320},[3303,5673,3710],{"class":3320},[3303,5675,5676],{"class":3305,"line":3334},[3303,5677,3331],{"emptyLinePlaceholder":3330},[3303,5679,5680],{"class":3305,"line":3340},[3303,5681,5682],{"class":3309},"# macOS/Windows: переконайтеся, що Docker Desktop запущений\n",[3303,5684,5685],{"class":3305,"line":3430},[3303,5686,3331],{"emptyLinePlaceholder":3330},[3303,5688,5689],{"class":3305,"line":3439},[3303,5690,5691],{"class":3309},"# Перевірка змінної DOCKER_HOST\n",[3303,5693,5694,5696],{"class":3305,"line":3444},[3303,5695,3477],{"class":3316},[3303,5697,5698],{"class":3520}," $DOCKER_HOST\n",[3303,5700,5701],{"class":3305,"line":3450},[3303,5702,3331],{"emptyLinePlaceholder":3330},[3303,5704,5705],{"class":3305,"line":3463},[3303,5706,5707],{"class":3309},"# Якщо вона встановлена, спробуйте скинути\n",[3303,5709,5710,5713],{"class":3305,"line":3468},[3303,5711,5712],{"class":3316},"unset",[3303,5714,5715],{"class":3320}," DOCKER_HOST\n",[3247,5717,5718,5719,5722],{},"Більшість проблем з Docker вирішуються перезапуском демона (Linux: ",[3300,5720,5721],{},"sudo systemctl restart docker",") або Docker Desktop (macOS/Windows). Якщо це не допомагає, перегляньте логи — вони зазвичай містять детальну інформацію про причину проблеми.",[3130,5724],{},[3109,5726,5728],{"id":5727},"резюме","Резюме",[3114,5730,5731],{},"Встановлення Docker — це перший практичний крок у вивченні контейнеризації. У цій статті ми розглянули:",[3114,5733,5734,5736],{},[3125,5735,3135],{}," для Linux, macOS та Windows, включно з особливостями кожної платформи.",[3114,5738,5739,5742],{},[3125,5740,5741],{},"Встановлення на Linux"," через офіційний репозиторій Docker — найпростіший та найнадійніший спосіб отримати останню версію Docker Engine.",[3114,5744,5745,5748],{},[3125,5746,5747],{},"Post-installation налаштування"," на Linux: додавання користувача до групи docker, налаштування автозапуску, конфігурація логування.",[3114,5750,5751,5753],{},[3125,5752,4246],{}," через Docker Desktop — єдиний офіційно підтримуваний спосіб, який використовує віртуалізацію для запуску Linux-ядра.",[3114,5755,5756,5758],{},[3125,5757,4447],{}," через Docker Desktop та WSL 2 — сучасний підхід, який забезпечує майже нативну продуктивність Linux-контейнерів на Windows.",[3114,5760,5761,5763,5764,5766,5767,4783,5769,3509],{},[3125,5762,3684],{}," через команди ",[3300,5765,4735],{},", ",[3300,5768,4803],{},[3300,5770,4886],{},[3114,5772,5773,5776],{},[3125,5774,5775],{},"Troubleshooting"," типових проблем при встановленні на різних платформах.",[3114,5778,5779,5780,5783],{},"Тепер, коли Docker встановлено та налаштовано, ми готові до запуску першого контейнера та детального вивчення команди ",[3300,5781,5782],{},"docker run"," у наступній статті.",[3130,5785],{},[3109,5787,5789],{"id":5788},"практичні-завдання","Практичні завдання",[3140,5791,5793],{"id":5792},"завдання-1-перевірка-конфігурації","Завдання 1: Перевірка конфігурації",[3114,5795,5796],{},"Виконайте наступні команди та проаналізуйте вивід:",[3293,5798,5800],{"className":3295,"code":5799,"language":3297,"meta":3298,"style":3298},"# Версія Docker\ndocker version\n\n# Системна інформація\ndocker info\n\n# Перевірка storage driver\ndocker info | grep \"Storage Driver\"\n\n# Перевірка Docker Root Dir\ndocker info | grep \"Docker Root Dir\"\n",[3300,5801,5802,5807,5813,5817,5822,5828,5832,5837,5852,5856,5861],{"__ignoreMap":3298},[3303,5803,5804],{"class":3305,"line":3306},[3303,5805,5806],{"class":3309},"# Версія Docker\n",[3303,5808,5809,5811],{"class":3305,"line":3313},[3303,5810,3662],{"class":3316},[3303,5812,4379],{"class":3320},[3303,5814,5815],{"class":3305,"line":3327},[3303,5816,3331],{"emptyLinePlaceholder":3330},[3303,5818,5819],{"class":3305,"line":3334},[3303,5820,5821],{"class":3309},"# Системна інформація\n",[3303,5823,5824,5826],{"class":3305,"line":3340},[3303,5825,3662],{"class":3316},[3303,5827,4395],{"class":3320},[3303,5829,5830],{"class":3305,"line":3430},[3303,5831,3331],{"emptyLinePlaceholder":3330},[3303,5833,5834],{"class":3305,"line":3439},[3303,5835,5836],{"class":3309},"# Перевірка storage driver\n",[3303,5838,5839,5841,5844,5846,5849],{"class":3305,"line":3444},[3303,5840,3662],{"class":3316},[3303,5842,5843],{"class":3320}," info",[3303,5845,3528],{"class":3527},[3303,5847,5848],{"class":3316},"grep",[3303,5850,5851],{"class":3320}," \"Storage Driver\"\n",[3303,5853,5854],{"class":3305,"line":3450},[3303,5855,3331],{"emptyLinePlaceholder":3330},[3303,5857,5858],{"class":3305,"line":3463},[3303,5859,5860],{"class":3309},"# Перевірка Docker Root Dir\n",[3303,5862,5863,5865,5867,5869,5871],{"class":3305,"line":3468},[3303,5864,3662],{"class":3316},[3303,5866,5843],{"class":3320},[3303,5868,3528],{"class":3527},[3303,5870,5848],{"class":3316},[3303,5872,5873],{"class":3320}," \"Docker Root Dir\"\n",[3114,5875,5876],{},[3125,5877,5878],{},"Питання:",[3157,5880,5881,5884,5887],{},[3160,5882,5883],{},"Яка версія Docker Engine встановлена?",[3160,5885,5886],{},"Який storage driver використовується?",[3160,5888,5889],{},"Де Docker зберігає образи та контейнери?",[3140,5891,5893],{"id":5892},"завдання-2-дослідження-docker-daemon","Завдання 2: Дослідження Docker Daemon",[3114,5895,5896],{},"На Linux дослідіть systemd service для Docker:",[3293,5898,5900],{"className":3295,"code":5899,"language":3297,"meta":3298,"style":3298},"# Перегляд конфігурації service\nsystemctl cat docker.service\n\n# Перегляд логів демона\nsudo journalctl -u docker.service -n 100\n\n# Перевірка автозапуску\nsystemctl is-enabled docker.service\n",[3300,5901,5902,5907,5916,5920,5924,5939,5943,5948],{"__ignoreMap":3298},[3303,5903,5904],{"class":3305,"line":3306},[3303,5905,5906],{"class":3309},"# Перегляд конфігурації service\n",[3303,5908,5909,5911,5914],{"class":3305,"line":3313},[3303,5910,4100],{"class":3316},[3303,5912,5913],{"class":3320}," cat",[3303,5915,4075],{"class":3320},[3303,5917,5918],{"class":3305,"line":3327},[3303,5919,3331],{"emptyLinePlaceholder":3330},[3303,5921,5922],{"class":3305,"line":3334},[3303,5923,5429],{"class":3309},[3303,5925,5926,5928,5930,5932,5934,5936],{"class":3305,"line":3340},[3303,5927,3317],{"class":3316},[3303,5929,5436],{"class":3320},[3303,5931,5439],{"class":3350},[3303,5933,5442],{"class":3320},[3303,5935,5445],{"class":3350},[3303,5937,5938],{"class":3395}," 100\n",[3303,5940,5941],{"class":3305,"line":3430},[3303,5942,3331],{"emptyLinePlaceholder":3330},[3303,5944,5945],{"class":3305,"line":3439},[3303,5946,5947],{"class":3309},"# Перевірка автозапуску\n",[3303,5949,5950,5952,5954],{"class":3305,"line":3444},[3303,5951,4100],{"class":3316},[3303,5953,4103],{"class":3320},[3303,5955,4075],{"class":3320},[3114,5957,5958],{},[3125,5959,5878],{},[3157,5961,5962,5965,5968],{},[3160,5963,5964],{},"Яка команда запускає Docker Daemon?",[3160,5966,5967],{},"Які залежності має docker.service?",[3160,5969,5970],{},"Чи налаштовано автозапуск?",[3140,5972,5974],{"id":5973},"завдання-3-експеримент-з-конфігурацією","Завдання 3: Експеримент з конфігурацією",[3114,5976,5977,5978,5980],{},"Створіть файл ",[3300,5979,4122],{}," з наступним вмістом:",[3293,5982,5984],{"className":4148,"code":5983,"language":4150,"meta":3298,"style":3298},"{\n  \"log-driver\": \"json-file\",\n  \"log-opts\": {\n    \"max-size\": \"5m\",\n    \"max-file\": \"2\"\n  },\n  \"default-address-pools\": [\n    {\n      \"base\": \"172.20.0.0/16\",\n      \"size\": 24\n    }\n  ]\n}\n",[3300,5985,5986,5990,6000,6006,6017,6026,6031,6039,6044,6056,6066,6071,6076],{"__ignoreMap":3298},[3303,5987,5988],{"class":3305,"line":3306},[3303,5989,4157],{"class":3527},[3303,5991,5992,5994,5996,5998],{"class":3305,"line":3313},[3303,5993,4163],{"class":4162},[3303,5995,3905],{"class":3527},[3303,5997,4168],{"class":3320},[3303,5999,4171],{"class":3527},[3303,6001,6002,6004],{"class":3305,"line":3327},[3303,6003,4176],{"class":4162},[3303,6005,4179],{"class":3527},[3303,6007,6008,6010,6012,6015],{"class":3305,"line":3334},[3303,6009,4184],{"class":4162},[3303,6011,3905],{"class":3527},[3303,6013,6014],{"class":3320},"\"5m\"",[3303,6016,4171],{"class":3527},[3303,6018,6019,6021,6023],{"class":3305,"line":3340},[3303,6020,4196],{"class":4162},[3303,6022,3905],{"class":3527},[3303,6024,6025],{"class":3320},"\"2\"\n",[3303,6027,6028],{"class":3305,"line":3430},[3303,6029,6030],{"class":3527},"  },\n",[3303,6032,6033,6036],{"class":3305,"line":3439},[3303,6034,6035],{"class":4162},"  \"default-address-pools\"",[3303,6037,6038],{"class":3527},": [\n",[3303,6040,6041],{"class":3305,"line":3444},[3303,6042,6043],{"class":3527},"    {\n",[3303,6045,6046,6049,6051,6054],{"class":3305,"line":3450},[3303,6047,6048],{"class":4162},"      \"base\"",[3303,6050,3905],{"class":3527},[3303,6052,6053],{"class":3320},"\"172.20.0.0/16\"",[3303,6055,4171],{"class":3527},[3303,6057,6058,6061,6063],{"class":3305,"line":3463},[3303,6059,6060],{"class":4162},"      \"size\"",[3303,6062,3905],{"class":3527},[3303,6064,6065],{"class":3395},"24\n",[3303,6067,6068],{"class":3305,"line":3468},[3303,6069,6070],{"class":3527},"    }\n",[3303,6072,6073],{"class":3305,"line":3474},[3303,6074,6075],{"class":3527},"  ]\n",[3303,6077,6078],{"class":3305,"line":3495},[3303,6079,4211],{"class":3527},[3114,6081,6082],{},"Перезапустіть Docker та перевірте, чи застосувалися зміни:",[3293,6084,6086],{"className":3295,"code":6085,"language":3297,"meta":3298,"style":3298},"sudo systemctl restart docker\ndocker info | grep -A 5 \"Default Address Pools\"\n",[3300,6087,6088,6098],{"__ignoreMap":3298},[3303,6089,6090,6092,6094,6096],{"class":3305,"line":3306},[3303,6091,3317],{"class":3316},[3303,6093,3704],{"class":3320},[3303,6095,4231],{"class":3320},[3303,6097,3710],{"class":3320},[3303,6099,6100,6102,6104,6106,6108,6111,6114],{"class":3305,"line":3313},[3303,6101,3662],{"class":3316},[3303,6103,5843],{"class":3320},[3303,6105,3528],{"class":3527},[3303,6107,5848],{"class":3316},[3303,6109,6110],{"class":3350}," -A",[3303,6112,6113],{"class":3395}," 5",[3303,6115,6116],{"class":3320}," \"Default Address Pools\"\n",[3114,6118,6119],{},[3125,6120,5878],{},[3157,6122,6123,6130],{},[3160,6124,6125,6126,6129],{},"Що робить параметр ",[3300,6127,6128],{},"default-address-pools","?",[3160,6131,6132],{},"Як перевірити, що налаштування логування працює?",[3140,6134,6136],{"id":6135},"завдання-4-порівняння-платформ","Завдання 4: Порівняння платформ",[3114,6138,6139],{},"Якщо у вас є доступ до кількох платформ, порівняйте:",[6141,6142,6143,6163],"table",{},[6144,6145,6146],"thead",{},[6147,6148,6149,6154,6157,6160],"tr",{},[6150,6151,6153],"th",{"align":6152},"left","Характеристика",[6150,6155,6156],{"align":6152},"Linux",[6150,6158,6159],{"align":6152},"macOS",[6150,6161,6162],{"align":6152},"Windows",[6164,6165,6166,6178,6188,6199],"tbody",{},[6147,6167,6168,6172,6174,6176],{},[6169,6170,6171],"td",{"align":6152},"Спосіб встановлення",[6169,6173,6129],{"align":6152},[6169,6175,6129],{"align":6152},[6169,6177,6129],{"align":6152},[6147,6179,6180,6182,6184,6186],{},[6169,6181,3154],{"align":6152},[6169,6183,6129],{"align":6152},[6169,6185,6129],{"align":6152},[6169,6187,6129],{"align":6152},[6147,6189,6190,6193,6195,6197],{},[6169,6191,6192],{"align":6152},"Розмір встановлення",[6169,6194,6129],{"align":6152},[6169,6196,6129],{"align":6152},[6169,6198,6129],{"align":6152},[6147,6200,6201,6204,6206,6208],{},[6169,6202,6203],{"align":6152},"Час запуску демона",[6169,6205,6129],{"align":6152},[6169,6207,6129],{"align":6152},[6169,6209,6129],{"align":6152},[3121,6211,6212],{},"Ці завдання допоможуть вам краще зрозуміти, як Docker працює на вашій платформі, та підготують до наступних статей, де ми почнемо активно працювати з контейнерами.",[6214,6215,6216],"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 .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}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 pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sLwNe, html code.shiki .sLwNe{--shiki-light:#0451A5;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}",{"title":3298,"searchDepth":3313,"depth":3313,"links":6218},[6219,6220,6226,6233,6238,6244,6250,6255,6260,6267,6268],{"id":3111,"depth":3313,"text":3112},{"id":3134,"depth":3313,"text":3135,"children":6221},[6222,6223,6224,6225],{"id":3142,"depth":3327,"text":3143},{"id":3180,"depth":3327,"text":3181},{"id":3219,"depth":3327,"text":3220},{"id":3252,"depth":3327,"text":3253},{"id":3280,"depth":3313,"text":3281,"children":6227},[6228,6229,6230,6231,6232],{"id":3287,"depth":3327,"text":3288},{"id":3369,"depth":3327,"text":3370},{"id":3562,"depth":3327,"text":3563},{"id":3683,"depth":3327,"text":3684},{"id":3871,"depth":3327,"text":3872},{"id":3920,"depth":3313,"text":3921,"children":6234},[6235,6236,6237],{"id":3927,"depth":3327,"text":3928},{"id":4049,"depth":3327,"text":4050},{"id":4115,"depth":3327,"text":4116},{"id":4245,"depth":3313,"text":4246,"children":6239},[6240,6241,6242,6243],{"id":4252,"depth":3327,"text":4253},{"id":4283,"depth":3327,"text":4284},{"id":4343,"depth":3327,"text":3684},{"id":4415,"depth":3327,"text":4416},{"id":4446,"depth":3313,"text":4447,"children":6245},[6246,6247,6248,6249],{"id":4456,"depth":3327,"text":4457},{"id":4578,"depth":3327,"text":4579},{"id":4620,"depth":3327,"text":3684},{"id":4673,"depth":3327,"text":4674},{"id":4721,"depth":3313,"text":4722,"children":6251},[6252,6253,6254],{"id":4728,"depth":3327,"text":4729},{"id":4797,"depth":3327,"text":4798},{"id":4880,"depth":3327,"text":4881},{"id":4947,"depth":3313,"text":4948,"children":6256},[6257,6258,6259],{"id":4954,"depth":3327,"text":4955},{"id":5093,"depth":3327,"text":5094},{"id":5154,"depth":3327,"text":5155},{"id":5313,"depth":3313,"text":5314,"children":6261},[6262,6263,6264,6265,6266],{"id":5320,"depth":3327,"text":5321},{"id":5399,"depth":3327,"text":5400},{"id":5491,"depth":3327,"text":5492},{"id":5568,"depth":3327,"text":5569},{"id":5638,"depth":3327,"text":5639},{"id":5727,"depth":3313,"text":5728},{"id":5788,"depth":3313,"text":5789,"children":6269},[6270,6271,6272,6273],{"id":5792,"depth":3327,"text":5793},{"id":5892,"depth":3327,"text":5893},{"id":5973,"depth":3327,"text":5974},{"id":6135,"depth":3327,"text":6136},"Покрокова інструкція встановлення Docker Engine на Linux, macOS та Windows з налаштуванням та перевіркою","md",null,{},{"title":2679,"description":6274},"YLlxLyHIh05rUVCeFlkrKeItTK7ata2yNF7WNYmp0E4",[6281,6283],{"title":2675,"path":2676,"stem":2677,"description":6282,"children":-1},"Детальний розбір внутрішньої архітектури Docker — клієнт-серверна модель, Docker Daemon, containerd, runc та OCI стандарти",{"title":2683,"path":2684,"stem":2685,"description":6284,"children":-1},"Практичне знайомство з запуском контейнерів, детальний розбір команди docker run та основні операції з контейнерами",1778489425637]