[{"data":1,"prerenderedAt":7073},["ShallowReactive",2],{"navigation_docs":3,"-tools-docker-first-container":3099,"-tools-docker-first-container-surround":7068},[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":2683,"body":3101,"description":7062,"extension":7063,"links":7064,"meta":7065,"navigation":3376,"path":2684,"seo":7066,"stem":2685,"__hash__":7067},"docs/07.tools/01.docker/05.first-container.md",{"type":3102,"value":3103,"toc":7006},"minimark",[3104,3108,3113,3117,3125,3131,3138,3141,3145,3152,3157,3182,3185,3189,3199,3206,3214,3217,3221,3229,3232,3238,3241,3282,3288,3292,3295,3309,3312,3316,3319,3325,3328,3332,3335,3344,3545,3549,3552,3558,3564,3567,3605,3611,3623,3625,3629,3635,3639,3654,3657,3663,3669,3699,3705,3711,3715,3721,3726,3729,3746,3752,3759,3763,3766,3780,3783,3803,3806,3810,3821,3842,3845,3869,3873,3876,3892,3895,3899,3902,3923,3929,3936,3940,3943,3974,3984,3988,3991,4010,4013,4015,4019,4022,4026,4042,4045,4060,4063,4069,4076,4080,4083,4216,4219,4234,4243,4249,4255,4259,4262,4268,4277,4286,4293,4297,4300,4318,4321,4344,4355,4358,4360,4364,4367,4371,4394,4397,4421,4424,4428,4434,4440,4443,4454,4461,4567,4571,4583,4586,4592,4595,4601,4606,4611,4617,4623,4633,4643,4647,4650,4663,4666,4672,4679,4766,4772,4774,4778,4781,4785,4854,4858,4871,4873,4884,4887,4910,4914,4927,4934,4938,4952,4963,4967,4981,4986,4990,5071,5078,5082,5085,5266,5268,5272,5275,5279,5282,5304,5306,5325,5327,5333,5336,5340,5347,5366,5369,5441,5444,5582,5588,5592,5595,5638,5641,5662,5664,5771,5773,5779,5782,5789,5791,5795,5800,5804,5807,5883,5886,5890,5893,5978,5982,5985,6057,6061,6064,6129,6133,6136,6210,6220,6222,6226,6232,6237,6289,6296,6348,6351,6354,6356,6360,6364,6367,6472,6477,6488,6492,6495,6605,6611,6616,6627,6631,6634,6793,6797,6814,6818,6821,6978,6982,6999,7002],[3105,3106,2683],"h1",{"id":3107},"перший-контейнер-docker-run",[3109,3110,3112],"h2",{"id":3111},"від-теорії-до-практики","Від теорії до практики",[3114,3115,3116],"p",{},"У попередніх статтях ми побудували міцний теоретичний фундамент: зрозуміли концепцію контейнеризації, вивчили архітектуру Docker та встановили його на нашу систему. Тепер настав час найцікавішого — запустити перший контейнер та побачити Docker у дії.",[3114,3118,3119,3120,3124],{},"Команда ",[3121,3122,3123],"code",{},"docker run"," — це ваш головний інструмент для роботи з контейнерами. Вона здається простою на перший погляд, але за цією простотою ховається величезна гнучкість та потужність. Одна команда може запустити простий скрипт, веб-сервер, базу даних або складний розподілений застосунок.",[3114,3126,3127,3128,3130],{},"У цій статті ми детально розберемо ",[3121,3129,3123],{},", почнемо з найпростіших прикладів та поступово перейдемо до складніших сценаріїв. Ви навчитеся запускати контейнери в інтерактивному та фоновому режимах, керувати їхнім життєвим циклом, переглядати логи та розуміти, що відбувається під капотом при кожному запуску.",[3132,3133,3134,3135,3137],"note",{},"Ця стаття фокусується на практичному використанні ",[3121,3136,3123],{},". Ми не будемо створювати власні образи (це тема наступних статей) — замість цього використаємо готові образи з Docker Hub.",[3139,3140],"hr",{},[3109,3142,3144],{"id":3143},"docker-run-hello-world-розбір-по-кроках","docker run hello-world: розбір по кроках",[3114,3146,3147,3148,3151],{},"Почнемо з найпростішого можливого контейнера — ",[3121,3149,3150],{},"hello-world",". Ми вже запускали його для перевірки встановлення, але тепер розглянемо детально, що відбувається на кожному кроці.",[3153,3154,3156],"h3",{"id":3155},"виконання-команди","Виконання команди",[3158,3159,3164],"pre",{"className":3160,"code":3161,"language":3162,"meta":3163,"style":3163},"language-bash shiki shiki-themes light-plus dark-plus dark-plus","docker run hello-world\n","bash","",[3121,3165,3166],{"__ignoreMap":3163},[3167,3168,3171,3175,3179],"span",{"class":3169,"line":3170},"line",1,[3167,3172,3174],{"class":3173},"s8Opu","docker",[3167,3176,3178],{"class":3177},"sbdoH"," run",[3167,3180,3181],{"class":3177}," hello-world\n",[3114,3183,3184],{},"Ця команда виглядає обманливо простою — лише два слова. Але за лаштунками відбувається складна послідовність операцій.",[3153,3186,3188],{"id":3187},"крок-1-пошук-образу-локально","Крок 1: Пошук образу локально",[3114,3190,3191,3192,3195,3196,3198],{},"Коли ви виконуєте ",[3121,3193,3194],{},"docker run hello-world",", Docker CLI відправляє запит до Docker Daemon: \"Запусти контейнер з образу ",[3121,3197,3150],{},"\".",[3114,3200,3201,3202,3205],{},"Демон спочатку перевіряє, чи є цей образ у локальному сховищі (зазвичай ",[3121,3203,3204],{},"/var/lib/docker/","). Якщо це ваш перший запуск, образу там немає, і ви побачите повідомлення:",[3158,3207,3212],{"className":3208,"code":3210,"language":3211},[3209],"language-text","Unable to find image 'hello-world:latest' locally\n","text",[3121,3213,3210],{"__ignoreMap":3163},[3114,3215,3216],{},"Це не помилка — це нормальна поведінка. Docker повідомляє, що образ потрібно завантажити.",[3153,3218,3220],{"id":3219},"крок-2-завантаження-образу-з-docker-hub","Крок 2: Завантаження образу з Docker Hub",[3114,3222,3223,3224,3228],{},"Оскільки образу немає локально, демон звертається до ",[3225,3226,3227],"strong",{},"Docker Hub"," — публічного реєстру образів. Docker Hub містить мільйони образів, включно з офіційними образами для популярних технологій.",[3114,3230,3231],{},"Ви побачите процес завантаження:",[3158,3233,3236],{"className":3234,"code":3235,"language":3211},[3209],"latest: Pulling from library/hello-world\nc1ec31eb5944: Pull complete\nDigest: sha256:4bd78111b6914a99dbc560e6a20eab57ff6655aea4a80c50b0c5491968cbc2e6\nStatus: Downloaded newer image for hello-world:latest\n",[3121,3237,3235],{"__ignoreMap":3163},[3114,3239,3240],{},"Що тут відбувається:",[3242,3243,3244,3254,3264,3270,3276],"ul",{},[3245,3246,3247,3250,3251,3253],"li",{},[3225,3248,3249],{},"latest"," — це тег образу. Якщо ви не вказуєте тег явно, Docker використовує ",[3121,3252,3249],{}," за замовчуванням",[3245,3255,3256,3259,3260,3263],{},[3225,3257,3258],{},"library/hello-world"," — повна назва образу. ",[3121,3261,3262],{},"library/"," — це офіційний namespace Docker",[3245,3265,3266,3269],{},[3225,3267,3268],{},"c1ec31eb5944"," — ID шару образу. Образи складаються з шарів, і кожен шар завантажується окремо",[3245,3271,3272,3275],{},[3225,3273,3274],{},"Digest"," — SHA256 хеш образу, який гарантує його цілісність",[3245,3277,3278,3281],{},[3225,3279,3280],{},"Pull complete"," — шар успішно завантажено",[3114,3283,3284,3285,3287],{},"Образ ",[3121,3286,3150],{}," надзвичайно малий — близько 13 КБ, тому завантаження займає частки секунди.",[3153,3289,3291],{"id":3290},"крок-3-створення-контейнера","Крок 3: Створення контейнера",[3114,3293,3294],{},"Після завантаження образу демон створює контейнер. Це включає:",[3242,3296,3297,3300,3303,3306],{},[3245,3298,3299],{},"Створення ізольованих namespaces (PID, NET, MNT, UTS, IPC)",[3245,3301,3302],{},"Налаштування cgroups для обмеження ресурсів",[3245,3304,3305],{},"Підготовку файлової системи через overlayfs",[3245,3307,3308],{},"Налаштування мережевого інтерфейсу",[3114,3310,3311],{},"Все це відбувається за мілісекунди завдяки оптимізованій архітектурі Docker.",[3153,3313,3315],{"id":3314},"крок-4-запуск-процесу","Крок 4: Запуск процесу",[3114,3317,3318],{},"Демон запускає головний процес контейнера — в даному випадку це маленька програма, яка виводить повідомлення:",[3158,3320,3323],{"className":3321,"code":3322,"language":3211},[3209],"Hello 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\nTo try something more ambitious, you can run an Ubuntu container with:\n $ docker run -it ubuntu bash\n\nShare images, automate workflows, and more with a free Docker ID:\n https://hub.docker.com/\n\nFor more examples and ideas, visit:\n https://docs.docker.com/get-started/\n",[3121,3324,3322],{"__ignoreMap":3163},[3114,3326,3327],{},"Це повідомлення пояснює саме ті кроки, які ми щойно розглянули!",[3153,3329,3331],{"id":3330},"крок-5-завершення-контейнера","Крок 5: Завершення контейнера",[3114,3333,3334],{},"Після виведення повідомлення процес контейнера завершується з кодом виходу 0 (успіх). Docker Daemon автоматично зупиняє контейнер, але не видаляє його — контейнер залишається у стані \"Exited\" і може бути перезапущений або видалений.",[3114,3336,3337],{},[3338,3339],"img",{"alt":3340,"className":3341,"src":3343},"docker run hello-world command execution sequence flow chart",[3342],"diagram-img","/images/tools/docker/first-container/01.png",[3345,3346,3347],"plant-uml",{},[3158,3348,3352],{"className":3349,"code":3350,"language":3351,"meta":3163,"style":3163},"language-plantuml shiki shiki-themes light-plus dark-plus dark-plus","@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\n\nactor \"Користувач\" as User\nparticipant \"Docker CLI\" as CLI #eff6ff\nparticipant \"Docker Daemon\" as Daemon #fef3c7\ndatabase \"Docker Hub\" as Hub #ecfdf5\ncollections \"Контейнер\" as Container #f5f5f5\n\nUser -> CLI: docker run hello-world\nactivate CLI\nCLI -> Daemon: POST /containers/create\nactivate Daemon\nDaemon -> Daemon: Пошук образу локально\nnote over Daemon: Образ \"hello-world:latest\"\\nне знайдено\nDaemon -> Hub: Pull hello-world:latest\nactivate Hub\nHub --> Daemon: Завантаження шарів (13 KB)\ndeactivate Hub\nDaemon -> Daemon: Створення контейнера\\n(namespaces, cgroups, FS)\nDaemon -> Container: Запуск процесу (PID 1)\nactivate Container\nContainer -> Container: Вивід \"Hello from Docker!\"\nContainer --> Daemon: Завершення (Exit code 0)\ndeactivate Container\nDaemon --> CLI: Потік виводу контейнера\ndeactivate Daemon\nCLI --> User: Відображення у терміналі\ndeactivate CLI\nnote over Container: Контейнер зупинено\\n(статус Exited), але не видалено\n@enduml\n","plantuml",[3121,3353,3354,3359,3365,3371,3378,3384,3390,3396,3402,3408,3413,3419,3425,3431,3437,3443,3449,3455,3461,3467,3473,3479,3485,3491,3497,3503,3509,3515,3521,3527,3533,3539],{"__ignoreMap":3163},[3167,3355,3356],{"class":3169,"line":3170},[3167,3357,3358],{},"@startuml\n",[3167,3360,3362],{"class":3169,"line":3361},2,[3167,3363,3364],{},"skinparam style plain\n",[3167,3366,3368],{"class":3169,"line":3367},3,[3167,3369,3370],{},"skinparam backgroundColor #ffffff\n",[3167,3372,3374],{"class":3169,"line":3373},4,[3167,3375,3377],{"emptyLinePlaceholder":3376},true,"\n",[3167,3379,3381],{"class":3169,"line":3380},5,[3167,3382,3383],{},"actor \"Користувач\" as User\n",[3167,3385,3387],{"class":3169,"line":3386},6,[3167,3388,3389],{},"participant \"Docker CLI\" as CLI #eff6ff\n",[3167,3391,3393],{"class":3169,"line":3392},7,[3167,3394,3395],{},"participant \"Docker Daemon\" as Daemon #fef3c7\n",[3167,3397,3399],{"class":3169,"line":3398},8,[3167,3400,3401],{},"database \"Docker Hub\" as Hub #ecfdf5\n",[3167,3403,3405],{"class":3169,"line":3404},9,[3167,3406,3407],{},"collections \"Контейнер\" as Container #f5f5f5\n",[3167,3409,3411],{"class":3169,"line":3410},10,[3167,3412,3377],{"emptyLinePlaceholder":3376},[3167,3414,3416],{"class":3169,"line":3415},11,[3167,3417,3418],{},"User -> CLI: docker run hello-world\n",[3167,3420,3422],{"class":3169,"line":3421},12,[3167,3423,3424],{},"activate CLI\n",[3167,3426,3428],{"class":3169,"line":3427},13,[3167,3429,3430],{},"CLI -> Daemon: POST /containers/create\n",[3167,3432,3434],{"class":3169,"line":3433},14,[3167,3435,3436],{},"activate Daemon\n",[3167,3438,3440],{"class":3169,"line":3439},15,[3167,3441,3442],{},"Daemon -> Daemon: Пошук образу локально\n",[3167,3444,3446],{"class":3169,"line":3445},16,[3167,3447,3448],{},"note over Daemon: Образ \"hello-world:latest\"\\nне знайдено\n",[3167,3450,3452],{"class":3169,"line":3451},17,[3167,3453,3454],{},"Daemon -> Hub: Pull hello-world:latest\n",[3167,3456,3458],{"class":3169,"line":3457},18,[3167,3459,3460],{},"activate Hub\n",[3167,3462,3464],{"class":3169,"line":3463},19,[3167,3465,3466],{},"Hub --> Daemon: Завантаження шарів (13 KB)\n",[3167,3468,3470],{"class":3169,"line":3469},20,[3167,3471,3472],{},"deactivate Hub\n",[3167,3474,3476],{"class":3169,"line":3475},21,[3167,3477,3478],{},"Daemon -> Daemon: Створення контейнера\\n(namespaces, cgroups, FS)\n",[3167,3480,3482],{"class":3169,"line":3481},22,[3167,3483,3484],{},"Daemon -> Container: Запуск процесу (PID 1)\n",[3167,3486,3488],{"class":3169,"line":3487},23,[3167,3489,3490],{},"activate Container\n",[3167,3492,3494],{"class":3169,"line":3493},24,[3167,3495,3496],{},"Container -> Container: Вивід \"Hello from Docker!\"\n",[3167,3498,3500],{"class":3169,"line":3499},25,[3167,3501,3502],{},"Container --> Daemon: Завершення (Exit code 0)\n",[3167,3504,3506],{"class":3169,"line":3505},26,[3167,3507,3508],{},"deactivate Container\n",[3167,3510,3512],{"class":3169,"line":3511},27,[3167,3513,3514],{},"Daemon --> CLI: Потік виводу контейнера\n",[3167,3516,3518],{"class":3169,"line":3517},28,[3167,3519,3520],{},"deactivate Daemon\n",[3167,3522,3524],{"class":3169,"line":3523},29,[3167,3525,3526],{},"CLI --> User: Відображення у терміналі\n",[3167,3528,3530],{"class":3169,"line":3529},30,[3167,3531,3532],{},"deactivate CLI\n",[3167,3534,3536],{"class":3169,"line":3535},31,[3167,3537,3538],{},"note over Container: Контейнер зупинено\\n(статус Exited), але не видалено\n",[3167,3540,3542],{"class":3169,"line":3541},32,[3167,3543,3544],{},"@enduml\n",[3153,3546,3548],{"id":3547},"що-залишилося-після-запуску","Що залишилося після запуску?",[3114,3550,3551],{},"Після завершення контейнера у вашій системі залишилося дві речі:",[3114,3553,3554,3557],{},[3225,3555,3556],{},"Образ hello-world"," — збережений локально, тому наступний запуск буде миттєвим (не потрібно завантажувати знову)",[3114,3559,3560,3563],{},[3225,3561,3562],{},"Зупинений контейнер"," — займає мінімум місця, але залишається в системі",[3114,3565,3566],{},"Перевіримо:",[3158,3568,3570],{"className":3160,"code":3569,"language":3162,"meta":3163,"style":3163},"# Перегляд локальних образів\ndocker images\n\n# Перегляд всіх контейнерів (включно зі зупиненими)\ndocker ps -a\n",[3121,3571,3572,3578,3585,3589,3594],{"__ignoreMap":3163},[3167,3573,3574],{"class":3169,"line":3170},[3167,3575,3577],{"class":3576},"spJ8K","# Перегляд локальних образів\n",[3167,3579,3580,3582],{"class":3169,"line":3361},[3167,3581,3174],{"class":3173},[3167,3583,3584],{"class":3177}," images\n",[3167,3586,3587],{"class":3169,"line":3367},[3167,3588,3377],{"emptyLinePlaceholder":3376},[3167,3590,3591],{"class":3169,"line":3373},[3167,3592,3593],{"class":3576},"# Перегляд всіх контейнерів (включно зі зупиненими)\n",[3167,3595,3596,3598,3601],{"class":3169,"line":3380},[3167,3597,3174],{"class":3173},[3167,3599,3600],{"class":3177}," ps",[3167,3602,3604],{"class":3603},"su1O8"," -a\n",[3114,3606,3607,3608,3610],{},"Ви побачите образ ",[3121,3609,3150],{}," та контейнер зі статусом \"Exited\".",[3612,3613,3614,3615,3618,3619,3622],"tip",{},"Якщо ви хочете, щоб контейнер автоматично видалявся після завершення, використовуйте прапорець ",[3121,3616,3617],{},"--rm",": ",[3121,3620,3621],{},"docker run --rm hello-world",". Це корисно для одноразових задач, щоб не засмічувати систему зупиненими контейнерами.",[3139,3624],{},[3109,3626,3628],{"id":3627},"анатомія-команди-docker-run","Анатомія команди docker run",[3114,3630,3631,3632,3634],{},"Тепер, коли ми розуміємо базовий процес, розглянемо повний синтаксис команди ",[3121,3633,3123],{}," та її ключові опції.",[3153,3636,3638],{"id":3637},"загальний-синтаксис","Загальний синтаксис",[3158,3640,3642],{"className":3160,"code":3641,"language":3162,"meta":3163,"style":3163},"docker run [OPTIONS] IMAGE[:TAG|@DIGEST] [COMMAND] [ARG...]\n",[3121,3643,3644],{"__ignoreMap":3163},[3167,3645,3646,3648,3650],{"class":3169,"line":3170},[3167,3647,3174],{"class":3173},[3167,3649,3178],{"class":3177},[3167,3651,3653],{"class":3652},"sHH4Y"," [OPTIONS] IMAGE[:TAG|@DIGEST] [COMMAND] [ARG...]\n",[3114,3655,3656],{},"Розберемо кожну частину:",[3114,3658,3659,3662],{},[3225,3660,3661],{},"OPTIONS"," — прапорці, які змінюють поведінку контейнера (режим запуску, мережа, томи, ліміти ресурсів тощо)",[3114,3664,3665,3668],{},[3225,3666,3667],{},"IMAGE"," — назва образу для запуску. Може бути у форматі:",[3242,3670,3671,3681,3687,3693],{},[3245,3672,3673,3676,3677,3680],{},[3121,3674,3675],{},"nginx"," — скорочена форма (еквівалентно ",[3121,3678,3679],{},"docker.io/library/nginx:latest",")",[3245,3682,3683,3686],{},[3121,3684,3685],{},"nginx:1.25"," — з явним тегом",[3245,3688,3689,3692],{},[3121,3690,3691],{},"nginx@sha256:abc123..."," — з digest для гарантованої версії",[3245,3694,3695,3698],{},[3121,3696,3697],{},"myregistry.com/myapp:v1.0"," — з приватного реєстру",[3114,3700,3701,3704],{},[3225,3702,3703],{},"COMMAND"," — команда, яку виконати всередині контейнера (перевизначає CMD з Dockerfile)",[3114,3706,3707,3710],{},[3225,3708,3709],{},"ARG"," — аргументи для команди",[3153,3712,3714],{"id":3713},"ключові-прапорці","Ключові прапорці",[3114,3716,3717,3718,3720],{},"Розглянемо найважливіші опції ",[3121,3719,3123],{},", які ви будете використовувати постійно:",[3722,3723,3725],"h4",{"id":3724},"d-detach-фоновий-режим","-d, --detach: фоновий режим",[3114,3727,3728],{},"Запускає контейнер у фоновому режимі (detached mode). Контейнер працює у фоні, а CLI повертає контроль одразу після запуску.",[3158,3730,3732],{"className":3160,"code":3731,"language":3162,"meta":3163,"style":3163},"docker run -d nginx\n",[3121,3733,3734],{"__ignoreMap":3163},[3167,3735,3736,3738,3740,3743],{"class":3169,"line":3170},[3167,3737,3174],{"class":3173},[3167,3739,3178],{"class":3177},[3167,3741,3742],{"class":3603}," -d",[3167,3744,3745],{"class":3177}," nginx\n",[3114,3747,3748,3749,3680],{},"Вивід: ID контейнера (наприклад, ",[3121,3750,3751],{},"a3f5c8d9e2b1...",[3114,3753,3754,3755,3758],{},"Без ",[3121,3756,3757],{},"-d"," контейнер працює у foreground mode — CLI \"прикріплений\" до контейнера і показує його вивід у реальному часі.",[3722,3760,3762],{"id":3761},"it-інтерактивний-режим","-it: інтерактивний режим",[3114,3764,3765],{},"Комбінація двох прапорців:",[3242,3767,3768,3774],{},[3245,3769,3770,3773],{},[3121,3771,3772],{},"-i"," (--interactive) — тримає STDIN відкритим, дозволяючи вводити дані",[3245,3775,3776,3779],{},[3121,3777,3778],{},"-t"," (--tty) — виділяє псевдо-термінал (TTY)",[3114,3781,3782],{},"Разом вони дозволяють інтерактивно працювати з контейнером:",[3158,3784,3786],{"className":3160,"code":3785,"language":3162,"meta":3163,"style":3163},"docker run -it ubuntu bash\n",[3121,3787,3788],{"__ignoreMap":3163},[3167,3789,3790,3792,3794,3797,3800],{"class":3169,"line":3170},[3167,3791,3174],{"class":3173},[3167,3793,3178],{"class":3177},[3167,3795,3796],{"class":3603}," -it",[3167,3798,3799],{"class":3177}," ubuntu",[3167,3801,3802],{"class":3177}," bash\n",[3114,3804,3805],{},"Це запустить Ubuntu контейнер та відкриє bash shell, де ви можете виконувати команди як у звичайній Linux-системі.",[3722,3807,3809],{"id":3808},"name-іменування-контейнера","--name: іменування контейнера",[3114,3811,3812,3813,3816,3817,3820],{},"За замовчуванням Docker генерує випадкові імена для контейнерів (наприклад, ",[3121,3814,3815],{},"pedantic_liskov",", ",[3121,3818,3819],{},"angry_tesla","). Ви можете задати власне ім'я:",[3158,3822,3824],{"className":3160,"code":3823,"language":3162,"meta":3163,"style":3163},"docker run --name my-nginx -d nginx\n",[3121,3825,3826],{"__ignoreMap":3163},[3167,3827,3828,3830,3832,3835,3838,3840],{"class":3169,"line":3170},[3167,3829,3174],{"class":3173},[3167,3831,3178],{"class":3177},[3167,3833,3834],{"class":3603}," --name",[3167,3836,3837],{"class":3177}," my-nginx",[3167,3839,3742],{"class":3603},[3167,3841,3745],{"class":3177},[3114,3843,3844],{},"Тепер ви можете посилатися на контейнер за іменем замість ID:",[3158,3846,3848],{"className":3160,"code":3847,"language":3162,"meta":3163,"style":3163},"docker stop my-nginx\ndocker logs my-nginx\n",[3121,3849,3850,3860],{"__ignoreMap":3163},[3167,3851,3852,3854,3857],{"class":3169,"line":3170},[3167,3853,3174],{"class":3173},[3167,3855,3856],{"class":3177}," stop",[3167,3858,3859],{"class":3177}," my-nginx\n",[3167,3861,3862,3864,3867],{"class":3169,"line":3361},[3167,3863,3174],{"class":3173},[3167,3865,3866],{"class":3177}," logs",[3167,3868,3859],{"class":3177},[3722,3870,3872],{"id":3871},"rm-автоматичне-видалення","--rm: автоматичне видалення",[3114,3874,3875],{},"Автоматично видаляє контейнер після його зупинки:",[3158,3877,3879],{"className":3160,"code":3878,"language":3162,"meta":3163,"style":3163},"docker run --rm hello-world\n",[3121,3880,3881],{"__ignoreMap":3163},[3167,3882,3883,3885,3887,3890],{"class":3169,"line":3170},[3167,3884,3174],{"class":3173},[3167,3886,3178],{"class":3177},[3167,3888,3889],{"class":3603}," --rm",[3167,3891,3181],{"class":3177},[3114,3893,3894],{},"Корисно для одноразових задач, щоб не накопичувати зупинені контейнери.",[3722,3896,3898],{"id":3897},"p-publish-проброс-портів","-p, --publish: проброс портів",[3114,3900,3901],{},"Пробросити порт з хоста в контейнер:",[3158,3903,3905],{"className":3160,"code":3904,"language":3162,"meta":3163,"style":3163},"docker run -d -p 8080:80 nginx\n",[3121,3906,3907],{"__ignoreMap":3163},[3167,3908,3909,3911,3913,3915,3918,3921],{"class":3169,"line":3170},[3167,3910,3174],{"class":3173},[3167,3912,3178],{"class":3177},[3167,3914,3742],{"class":3603},[3167,3916,3917],{"class":3603}," -p",[3167,3919,3920],{"class":3177}," 8080:80",[3167,3922,3745],{"class":3177},[3114,3924,3925,3926],{},"Формат: ",[3121,3927,3928],{},"-p HOST_PORT:CONTAINER_PORT",[3114,3930,3931,3932,3935],{},"Тепер Nginx всередині контейнера (порт 80) доступний на хості за адресою ",[3121,3933,3934],{},"http://localhost:8080",".",[3722,3937,3939],{"id":3938},"e-env-змінні-оточення","-e, --env: змінні оточення",[3114,3941,3942],{},"Передати змінні оточення в контейнер:",[3158,3944,3946],{"className":3160,"code":3945,"language":3162,"meta":3163,"style":3163},"docker run -e MY_VAR=value -e ANOTHER_VAR=123 ubuntu env\n",[3121,3947,3948],{"__ignoreMap":3163},[3167,3949,3950,3952,3954,3957,3960,3962,3965,3969,3971],{"class":3169,"line":3170},[3167,3951,3174],{"class":3173},[3167,3953,3178],{"class":3177},[3167,3955,3956],{"class":3603}," -e",[3167,3958,3959],{"class":3177}," MY_VAR=value",[3167,3961,3956],{"class":3603},[3167,3963,3964],{"class":3177}," ANOTHER_VAR=",[3167,3966,3968],{"class":3967},"sJj4R","123",[3167,3970,3799],{"class":3177},[3167,3972,3973],{"class":3177}," env\n",[3114,3975,3976,3977,3980,3981,3935],{},"Це виведе всі змінні оточення, включно з ",[3121,3978,3979],{},"MY_VAR"," та ",[3121,3982,3983],{},"ANOTHER_VAR",[3722,3985,3987],{"id":3986},"v-volume-монтування-томів","-v, --volume: монтування томів",[3114,3989,3990],{},"Монтувати директорію хоста або Docker volume у контейнер:",[3158,3992,3994],{"className":3160,"code":3993,"language":3162,"meta":3163,"style":3163},"docker run -v /host/path:/container/path nginx\n",[3121,3995,3996],{"__ignoreMap":3163},[3167,3997,3998,4000,4002,4005,4008],{"class":3169,"line":3170},[3167,3999,3174],{"class":3173},[3167,4001,3178],{"class":3177},[3167,4003,4004],{"class":3603}," -v",[3167,4006,4007],{"class":3177}," /host/path:/container/path",[3167,4009,3745],{"class":3177},[3114,4011,4012],{},"Детальніше про томи ми поговоримо в окремій статті.",[3139,4014],{},[3109,4016,4018],{"id":4017},"інтерактивний-режим-експерименти-з-ubuntu","Інтерактивний режим: експерименти з Ubuntu",[3114,4020,4021],{},"Тепер, коли ми розуміємо основні прапорці, запустимо контейнер в інтерактивному режимі та поекспериментуємо з ним.",[3153,4023,4025],{"id":4024},"запуск-bash-в-ubuntu-контейнері","Запуск bash в Ubuntu контейнері",[3158,4027,4028],{"className":3160,"code":3785,"language":3162,"meta":3163,"style":3163},[3121,4029,4030],{"__ignoreMap":3163},[3167,4031,4032,4034,4036,4038,4040],{"class":3169,"line":3170},[3167,4033,3174],{"class":3173},[3167,4035,3178],{"class":3177},[3167,4037,3796],{"class":3603},[3167,4039,3799],{"class":3177},[3167,4041,3802],{"class":3177},[3114,4043,4044],{},"Що відбувається:",[4046,4047,4048,4051,4054,4057],"ol",{},[3245,4049,4050],{},"Docker завантажує образ Ubuntu (якщо його немає локально) — близько 77 МБ",[3245,4052,4053],{},"Створює контейнер з мінімальною Ubuntu-системою",[3245,4055,4056],{},"Запускає bash shell всередині контейнера",[3245,4058,4059],{},"Прикріплює ваш термінал до цього shell",[3114,4061,4062],{},"Ви побачите prompt, схожий на:",[3158,4064,4067],{"className":4065,"code":4066,"language":3211},[3209],"root@a3f5c8d9e2b1:/#\n",[3121,4068,4066],{"__ignoreMap":3163},[3114,4070,4071,4072,4075],{},"Де ",[3121,4073,4074],{},"a3f5c8d9e2b1"," — це ID контейнера (перші 12 символів). Ви зараз всередині контейнера як root-користувач!",[3153,4077,4079],{"id":4078},"експерименти-всередині-контейнера","Експерименти всередині контейнера",[3114,4081,4082],{},"Спробуймо кілька команд:",[3158,4084,4086],{"className":3160,"code":4085,"language":3162,"meta":3163,"style":3163},"# Перевірка версії Ubuntu\ncat /etc/os-release\n\n# Перегляд процесів\nps aux\n\n# Встановлення пакету\napt update && apt install -y curl\n\n# Перевірка мережі\ncurl https://example.com\n\n# Створення файлу\necho \"Hello from container\" > /tmp/test.txt\ncat /tmp/test.txt\n\n# Перегляд файлової системи\nls -la /\n",[3121,4087,4088,4093,4101,4105,4110,4118,4122,4127,4149,4153,4158,4166,4170,4175,4189,4196,4200,4205],{"__ignoreMap":3163},[3167,4089,4090],{"class":3169,"line":3170},[3167,4091,4092],{"class":3576},"# Перевірка версії Ubuntu\n",[3167,4094,4095,4098],{"class":3169,"line":3361},[3167,4096,4097],{"class":3173},"cat",[3167,4099,4100],{"class":3177}," /etc/os-release\n",[3167,4102,4103],{"class":3169,"line":3367},[3167,4104,3377],{"emptyLinePlaceholder":3376},[3167,4106,4107],{"class":3169,"line":3373},[3167,4108,4109],{"class":3576},"# Перегляд процесів\n",[3167,4111,4112,4115],{"class":3169,"line":3380},[3167,4113,4114],{"class":3173},"ps",[3167,4116,4117],{"class":3177}," aux\n",[3167,4119,4120],{"class":3169,"line":3386},[3167,4121,3377],{"emptyLinePlaceholder":3376},[3167,4123,4124],{"class":3169,"line":3392},[3167,4125,4126],{"class":3576},"# Встановлення пакету\n",[3167,4128,4129,4132,4135,4138,4140,4143,4146],{"class":3169,"line":3398},[3167,4130,4131],{"class":3173},"apt",[3167,4133,4134],{"class":3177}," update",[3167,4136,4137],{"class":3652}," && ",[3167,4139,4131],{"class":3173},[3167,4141,4142],{"class":3177}," install",[3167,4144,4145],{"class":3603}," -y",[3167,4147,4148],{"class":3177}," curl\n",[3167,4150,4151],{"class":3169,"line":3404},[3167,4152,3377],{"emptyLinePlaceholder":3376},[3167,4154,4155],{"class":3169,"line":3410},[3167,4156,4157],{"class":3576},"# Перевірка мережі\n",[3167,4159,4160,4163],{"class":3169,"line":3415},[3167,4161,4162],{"class":3173},"curl",[3167,4164,4165],{"class":3177}," https://example.com\n",[3167,4167,4168],{"class":3169,"line":3421},[3167,4169,3377],{"emptyLinePlaceholder":3376},[3167,4171,4172],{"class":3169,"line":3427},[3167,4173,4174],{"class":3576},"# Створення файлу\n",[3167,4176,4177,4180,4183,4186],{"class":3169,"line":3433},[3167,4178,4179],{"class":3173},"echo",[3167,4181,4182],{"class":3177}," \"Hello from container\"",[3167,4184,4185],{"class":3652}," > ",[3167,4187,4188],{"class":3177},"/tmp/test.txt\n",[3167,4190,4191,4193],{"class":3169,"line":3439},[3167,4192,4097],{"class":3173},[3167,4194,4195],{"class":3177}," /tmp/test.txt\n",[3167,4197,4198],{"class":3169,"line":3445},[3167,4199,3377],{"emptyLinePlaceholder":3376},[3167,4201,4202],{"class":3169,"line":3451},[3167,4203,4204],{"class":3576},"# Перегляд файлової системи\n",[3167,4206,4207,4210,4213],{"class":3169,"line":3457},[3167,4208,4209],{"class":3173},"ls",[3167,4211,4212],{"class":3603}," -la",[3167,4214,4215],{"class":3177}," /\n",[3114,4217,4218],{},"Кілька цікавих спостережень:",[3114,4220,4221,4224,4225,3816,4227,3816,4230,4233],{},[3225,4222,4223],{},"Мінімальна система",": Ubuntu контейнер містить лише базові утиліти. Багато звичних команд (наприклад, ",[3121,4226,4162],{},[3121,4228,4229],{},"vim",[3121,4231,4232],{},"ping",") відсутні за замовчуванням.",[3114,4235,4236,3618,4239,4242],{},[3225,4237,4238],{},"Ізольовані процеси",[3121,4240,4241],{},"ps aux"," показує лише процеси всередині контейнера. Bash має PID 1 — він є головним процесом контейнера.",[3114,4244,4245,4248],{},[3225,4246,4247],{},"Ізольована файлова система",": Всі зміни (встановлення пакетів, створення файлів) відбуваються у контейнері та не впливають на хост-систему.",[3114,4250,4251,4254],{},[3225,4252,4253],{},"Мережевий доступ",": Контейнер має доступ до інтернету через мережевий стек хоста.",[3153,4256,4258],{"id":4257},"вихід-з-контейнера","Вихід з контейнера",[3114,4260,4261],{},"Щоб вийти з інтерактивного контейнера, є два способи:",[3114,4263,4264,4267],{},[3225,4265,4266],{},"exit або Ctrl+D"," — завершує bash процес, що призводить до зупинки контейнера (оскільки bash — це PID 1):",[3158,4269,4271],{"className":3160,"code":4270,"language":3162,"meta":3163,"style":3163},"exit\n",[3121,4272,4273],{"__ignoreMap":3163},[3167,4274,4275],{"class":3169,"line":3170},[3167,4276,4270],{"class":3173},[3114,4278,4279,4282,4283,3935],{},[3225,4280,4281],{},"Ctrl+P, потім Ctrl+Q"," — \"відчіплює\" термінал від контейнера, залишаючи його працювати у фоні. Це працює лише якщо контейнер запущено з ",[3121,4284,4285],{},"-it",[3132,4287,4288,4289,4292],{},"Коли головний процес контейнера (PID 1) завершується, контейнер автоматично зупиняється. У нашому випадку bash є PID 1, тому ",[3121,4290,4291],{},"exit"," зупиняє контейнер. Це фундаментальна концепція Docker — контейнер живе, поки живе його головний процес.",[3153,4294,4296],{"id":4295},"що-сталося-з-нашими-змінами","Що сталося з нашими змінами?",[3114,4298,4299],{},"Після виходу з контейнера всі зміни (встановлені пакети, створені файли) залишаються у контейнері, але контейнер зупинений. Перевіримо:",[3158,4301,4303],{"className":3160,"code":4302,"language":3162,"meta":3163,"style":3163},"# Перегляд зупинених контейнерів\ndocker ps -a\n",[3121,4304,4305,4310],{"__ignoreMap":3163},[3167,4306,4307],{"class":3169,"line":3170},[3167,4308,4309],{"class":3576},"# Перегляд зупинених контейнерів\n",[3167,4311,4312,4314,4316],{"class":3169,"line":3361},[3167,4313,3174],{"class":3173},[3167,4315,3600],{"class":3177},[3167,4317,3604],{"class":3603},[3114,4319,4320],{},"Ви побачите контейнер зі статусом \"Exited\". Можна перезапустити його:",[3158,4322,4324],{"className":3160,"code":4323,"language":3162,"meta":3163,"style":3163},"# Перезапуск контейнера (замініть CONTAINER_ID на ваш)\ndocker start -ai CONTAINER_ID\n",[3121,4325,4326,4331],{"__ignoreMap":3163},[3167,4327,4328],{"class":3169,"line":3170},[3167,4329,4330],{"class":3576},"# Перезапуск контейнера (замініть CONTAINER_ID на ваш)\n",[3167,4332,4333,4335,4338,4341],{"class":3169,"line":3361},[3167,4334,3174],{"class":3173},[3167,4336,4337],{"class":3177}," start",[3167,4339,4340],{"class":3603}," -ai",[3167,4342,4343],{"class":3177}," CONTAINER_ID\n",[3114,4345,4346,4347,4350,4351,4354],{},"Прапорці ",[3121,4348,4349],{},"-ai"," означають \"attach\" та \"interactive\" — прикріпити термінал до контейнера. Ви знову опинитеся в bash, і файл ",[3121,4352,4353],{},"/tmp/test.txt"," все ще буде там!",[3114,4356,4357],{},"Але якщо ви видалите контейнер та створите новий з того ж образу, всі зміни зникнуть — кожен новий контейнер починає з чистого стану образу.",[3139,4359],{},[3109,4361,4363],{"id":4362},"фоновий-режим-запуск-веб-сервера","Фоновий режим: запуск веб-сервера",[3114,4365,4366],{},"Інтерактивний режим корисний для експериментів, але більшість застосунків (веб-сервери, бази даних, API) працюють у фоновому режимі. Розглянемо типовий сценарій — запуск Nginx.",[3153,4368,4370],{"id":4369},"запуск-nginx-у-фоновому-режимі","Запуск Nginx у фоновому режимі",[3158,4372,4374],{"className":3160,"code":4373,"language":3162,"meta":3163,"style":3163},"docker run -d -p 8080:80 --name my-nginx nginx\n",[3121,4375,4376],{"__ignoreMap":3163},[3167,4377,4378,4380,4382,4384,4386,4388,4390,4392],{"class":3169,"line":3170},[3167,4379,3174],{"class":3173},[3167,4381,3178],{"class":3177},[3167,4383,3742],{"class":3603},[3167,4385,3917],{"class":3603},[3167,4387,3920],{"class":3177},[3167,4389,3834],{"class":3603},[3167,4391,3837],{"class":3177},[3167,4393,3745],{"class":3177},[3114,4395,4396],{},"Розберемо команду:",[3242,4398,4399,4404,4410,4416],{},[3245,4400,4401,4403],{},[3121,4402,3757],{}," — detached mode (фоновий режим)",[3245,4405,4406,4409],{},[3121,4407,4408],{},"-p 8080:80"," — пробросити порт 80 контейнера на порт 8080 хоста",[3245,4411,4412,4415],{},[3121,4413,4414],{},"--name my-nginx"," — назвати контейнер \"my-nginx\"",[3245,4417,4418,4420],{},[3121,4419,3675],{}," — образ для запуску",[3114,4422,4423],{},"Docker поверне ID контейнера та одразу поверне контроль терміналу. Контейнер працює у фоні.",[3153,4425,4427],{"id":4426},"перевірка-роботи","Перевірка роботи",[3114,4429,4430,4431,4433],{},"Відкрийте браузер та перейдіть на ",[3121,4432,3934],{},". Ви побачите стандартну сторінку привітання Nginx:",[3158,4435,4438],{"className":4436,"code":4437,"language":3211},[3209],"Welcome to nginx!\nIf you see this page, the nginx web server is successfully installed and working.\n",[3121,4439,4437],{"__ignoreMap":3163},[3114,4441,4442],{},"Це означає, що:",[4046,4444,4445,4448,4451],{},[3245,4446,4447],{},"Nginx працює всередині контейнера на порту 80",[3245,4449,4450],{},"Docker пробросив порт 80 контейнера на порт 8080 хоста",[3245,4452,4453],{},"Ваш браузер підключився до хоста на порті 8080, а Docker перенаправив запит у контейнер",[3114,4455,4456],{},[3338,4457],{"alt":4458,"className":4459,"src":4460},"docker port mapping port forwarding host to container diagram",[3342],"/images/tools/docker/first-container/02.png",[3345,4462,4463],{},[3158,4464,4466],{"className":3349,"code":4465,"language":3351,"meta":3163,"style":3163},"@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\nskinparam ArrowColor #2563eb\n\npackage \"Хост-система (Host OS)\" #eff6ff {\n  component \"Браузер\\n(Browser)\" as Browser #ffffff\n  node \"Порт 8080\\n(Host Port 8080)\" as HostPort #fef3c7\n  \n  package \"Мережа Docker (docker0)\" #f3f4f6 {\n    package \"Контейнер Nginx\\n(Container)\" as Container #ecfdf5 {\n      node \"Порт 80\\n(Container Port 80)\" as ContPort #ffffff\n      component \"Nginx Web Server\" as Nginx #ffffff\n    }\n  }\n}\n\nBrowser --> HostPort : \"http://localhost:8080\"\nHostPort --> ContPort : \"Port Forwarding\\n(NAT / iptables)\"\nContPort --> Nginx : \"Internal routing\"\n@enduml\n",[3121,4467,4468,4472,4476,4480,4485,4489,4494,4499,4504,4509,4514,4519,4524,4529,4534,4539,4544,4548,4553,4558,4563],{"__ignoreMap":3163},[3167,4469,4470],{"class":3169,"line":3170},[3167,4471,3358],{},[3167,4473,4474],{"class":3169,"line":3361},[3167,4475,3364],{},[3167,4477,4478],{"class":3169,"line":3367},[3167,4479,3370],{},[3167,4481,4482],{"class":3169,"line":3373},[3167,4483,4484],{},"skinparam ArrowColor #2563eb\n",[3167,4486,4487],{"class":3169,"line":3380},[3167,4488,3377],{"emptyLinePlaceholder":3376},[3167,4490,4491],{"class":3169,"line":3386},[3167,4492,4493],{},"package \"Хост-система (Host OS)\" #eff6ff {\n",[3167,4495,4496],{"class":3169,"line":3392},[3167,4497,4498],{},"  component \"Браузер\\n(Browser)\" as Browser #ffffff\n",[3167,4500,4501],{"class":3169,"line":3398},[3167,4502,4503],{},"  node \"Порт 8080\\n(Host Port 8080)\" as HostPort #fef3c7\n",[3167,4505,4506],{"class":3169,"line":3404},[3167,4507,4508],{},"  \n",[3167,4510,4511],{"class":3169,"line":3410},[3167,4512,4513],{},"  package \"Мережа Docker (docker0)\" #f3f4f6 {\n",[3167,4515,4516],{"class":3169,"line":3415},[3167,4517,4518],{},"    package \"Контейнер Nginx\\n(Container)\" as Container #ecfdf5 {\n",[3167,4520,4521],{"class":3169,"line":3421},[3167,4522,4523],{},"      node \"Порт 80\\n(Container Port 80)\" as ContPort #ffffff\n",[3167,4525,4526],{"class":3169,"line":3427},[3167,4527,4528],{},"      component \"Nginx Web Server\" as Nginx #ffffff\n",[3167,4530,4531],{"class":3169,"line":3433},[3167,4532,4533],{},"    }\n",[3167,4535,4536],{"class":3169,"line":3439},[3167,4537,4538],{},"  }\n",[3167,4540,4541],{"class":3169,"line":3445},[3167,4542,4543],{},"}\n",[3167,4545,4546],{"class":3169,"line":3451},[3167,4547,3377],{"emptyLinePlaceholder":3376},[3167,4549,4550],{"class":3169,"line":3457},[3167,4551,4552],{},"Browser --> HostPort : \"http://localhost:8080\"\n",[3167,4554,4555],{"class":3169,"line":3463},[3167,4556,4557],{},"HostPort --> ContPort : \"Port Forwarding\\n(NAT / iptables)\"\n",[3167,4559,4560],{"class":3169,"line":3469},[3167,4561,4562],{},"ContPort --> Nginx : \"Internal routing\"\n",[3167,4564,4565],{"class":3169,"line":3475},[3167,4566,3544],{},[3153,4568,4570],{"id":4569},"перегляд-запущених-контейнерів","Перегляд запущених контейнерів",[3158,4572,4574],{"className":3160,"code":4573,"language":3162,"meta":3163,"style":3163},"docker ps\n",[3121,4575,4576],{"__ignoreMap":3163},[3167,4577,4578,4580],{"class":3169,"line":3170},[3167,4579,3174],{"class":3173},[3167,4581,4582],{"class":3177}," ps\n",[3114,4584,4585],{},"Вивід:",[3158,4587,4590],{"className":4588,"code":4589,"language":3211},[3209],"CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS          PORTS                  NAMES\na3f5c8d9e2b1   nginx     \"/docker-entrypoint.…\"   2 minutes ago    Up 2 minutes    0.0.0.0:8080->80/tcp   my-nginx\n",[3121,4591,4589],{"__ignoreMap":3163},[3114,4593,4594],{},"Розберемо колонки:",[3114,4596,4597,4600],{},[3225,4598,4599],{},"CONTAINER ID"," — унікальний ідентифікатор контейнера (скорочена версія)",[3114,4602,4603,4605],{},[3225,4604,3667],{}," — образ, з якого створено контейнер",[3114,4607,4608,4610],{},[3225,4609,3703],{}," — команда, яка виконується всередині контейнера (головний процес)",[3114,4612,4613,4616],{},[3225,4614,4615],{},"CREATED"," — коли контейнер було створено",[3114,4618,4619,4622],{},[3225,4620,4621],{},"STATUS"," — поточний стан (Up = працює, Exited = зупинено)",[3114,4624,4625,4628,4629,4632],{},[3225,4626,4627],{},"PORTS"," — проброшені порти. ",[3121,4630,4631],{},"0.0.0.0:8080->80/tcp"," означає \"порт 8080 на всіх інтерфейсах хоста пробросити на порт 80 контейнера через TCP\"",[3114,4634,4635,4638,4639,4642],{},[3225,4636,4637],{},"NAMES"," — ім'я контейнера (задане через ",[3121,4640,4641],{},"--name"," або згенероване автоматично)",[3153,4644,4646],{"id":4645},"перегляд-логів-контейнера","Перегляд логів контейнера",[3114,4648,4649],{},"Nginx записує логи доступу та помилок. Подивимося на них:",[3158,4651,4653],{"className":3160,"code":4652,"language":3162,"meta":3163,"style":3163},"docker logs my-nginx\n",[3121,4654,4655],{"__ignoreMap":3163},[3167,4656,4657,4659,4661],{"class":3169,"line":3170},[3167,4658,3174],{"class":3173},[3167,4660,3866],{"class":3177},[3167,4662,3859],{"class":3177},[3114,4664,4665],{},"Ви побачите логи запуску Nginx та записи про HTTP-запити:",[3158,4667,4670],{"className":4668,"code":4669,"language":3211},[3209],"/docker-entrypoint.sh: /docker-entrypoint.d/ is not empty, will attempt to perform configuration\n/docker-entrypoint.sh: Looking for shell scripts in /docker-entrypoint.d/\n...\n2026/04/14 08:15:23 [notice] 1#1: start worker processes\n2026/04/14 08:15:23 [notice] 1#1: start worker process 29\n172.17.0.1 - - [14/Apr/2026:08:16:45 +0000] \"GET / HTTP/1.1\" 200 615 \"-\" \"Mozilla/5.0...\"\n",[3121,4671,4669],{"__ignoreMap":3163},[3114,4673,4674,4675,4678],{},"Корисні опції для ",[3121,4676,4677],{},"docker logs",":",[3158,4680,4682],{"className":3160,"code":4681,"language":3162,"meta":3163,"style":3163},"# Останні 10 рядків\ndocker logs --tail 10 my-nginx\n\n# Слідкувати за логами в реальному часі (як tail -f)\ndocker logs -f my-nginx\n\n# Логи з часовими мітками\ndocker logs -t my-nginx\n\n# Логи за останню годину\ndocker logs --since 1h my-nginx\n",[3121,4683,4684,4689,4703,4707,4712,4723,4727,4732,4743,4747,4752],{"__ignoreMap":3163},[3167,4685,4686],{"class":3169,"line":3170},[3167,4687,4688],{"class":3576},"# Останні 10 рядків\n",[3167,4690,4691,4693,4695,4698,4701],{"class":3169,"line":3361},[3167,4692,3174],{"class":3173},[3167,4694,3866],{"class":3177},[3167,4696,4697],{"class":3603}," --tail",[3167,4699,4700],{"class":3967}," 10",[3167,4702,3859],{"class":3177},[3167,4704,4705],{"class":3169,"line":3367},[3167,4706,3377],{"emptyLinePlaceholder":3376},[3167,4708,4709],{"class":3169,"line":3373},[3167,4710,4711],{"class":3576},"# Слідкувати за логами в реальному часі (як tail -f)\n",[3167,4713,4714,4716,4718,4721],{"class":3169,"line":3380},[3167,4715,3174],{"class":3173},[3167,4717,3866],{"class":3177},[3167,4719,4720],{"class":3603}," -f",[3167,4722,3859],{"class":3177},[3167,4724,4725],{"class":3169,"line":3386},[3167,4726,3377],{"emptyLinePlaceholder":3376},[3167,4728,4729],{"class":3169,"line":3392},[3167,4730,4731],{"class":3576},"# Логи з часовими мітками\n",[3167,4733,4734,4736,4738,4741],{"class":3169,"line":3398},[3167,4735,3174],{"class":3173},[3167,4737,3866],{"class":3177},[3167,4739,4740],{"class":3603}," -t",[3167,4742,3859],{"class":3177},[3167,4744,4745],{"class":3169,"line":3404},[3167,4746,3377],{"emptyLinePlaceholder":3376},[3167,4748,4749],{"class":3169,"line":3410},[3167,4750,4751],{"class":3576},"# Логи за останню годину\n",[3167,4753,4754,4756,4758,4761,4764],{"class":3169,"line":3415},[3167,4755,3174],{"class":3173},[3167,4757,3866],{"class":3177},[3167,4759,4760],{"class":3603}," --since",[3167,4762,4763],{"class":3177}," 1h",[3167,4765,3859],{"class":3177},[3612,4767,4768,4771],{},[3121,4769,4770],{},"docker logs -f"," — це ваш найкращий друг при налагодженні контейнерів. Він показує логи в реальному часі, дозволяючи бачити, що відбувається всередині контейнера без необхідності заходити в нього.",[3139,4773],{},[3109,4775,4777],{"id":4776},"управління-життєвим-циклом-контейнера","Управління життєвим циклом контейнера",[3114,4779,4780],{},"Контейнер має простий життєвий цикл: створення → запуск → зупинка → видалення. Розглянемо команди для управління цим циклом.",[3153,4782,4784],{"id":4783},"docker-ps-перегляд-контейнерів","docker ps: перегляд контейнерів",[3158,4786,4788],{"className":3160,"code":4787,"language":3162,"meta":3163,"style":3163},"# Запущені контейнери\ndocker ps\n\n# Всі контейнери (включно зі зупиненими)\ndocker ps -a\n\n# Тільки ID контейнерів\ndocker ps -q\n\n# Останній створений контейнер\ndocker ps -l\n",[3121,4789,4790,4795,4801,4805,4810,4818,4822,4827,4836,4840,4845],{"__ignoreMap":3163},[3167,4791,4792],{"class":3169,"line":3170},[3167,4793,4794],{"class":3576},"# Запущені контейнери\n",[3167,4796,4797,4799],{"class":3169,"line":3361},[3167,4798,3174],{"class":3173},[3167,4800,4582],{"class":3177},[3167,4802,4803],{"class":3169,"line":3367},[3167,4804,3377],{"emptyLinePlaceholder":3376},[3167,4806,4807],{"class":3169,"line":3373},[3167,4808,4809],{"class":3576},"# Всі контейнери (включно зі зупиненими)\n",[3167,4811,4812,4814,4816],{"class":3169,"line":3380},[3167,4813,3174],{"class":3173},[3167,4815,3600],{"class":3177},[3167,4817,3604],{"class":3603},[3167,4819,4820],{"class":3169,"line":3386},[3167,4821,3377],{"emptyLinePlaceholder":3376},[3167,4823,4824],{"class":3169,"line":3392},[3167,4825,4826],{"class":3576},"# Тільки ID контейнерів\n",[3167,4828,4829,4831,4833],{"class":3169,"line":3398},[3167,4830,3174],{"class":3173},[3167,4832,3600],{"class":3177},[3167,4834,4835],{"class":3603}," -q\n",[3167,4837,4838],{"class":3169,"line":3404},[3167,4839,3377],{"emptyLinePlaceholder":3376},[3167,4841,4842],{"class":3169,"line":3410},[3167,4843,4844],{"class":3576},"# Останній створений контейнер\n",[3167,4846,4847,4849,4851],{"class":3169,"line":3415},[3167,4848,3174],{"class":3173},[3167,4850,3600],{"class":3177},[3167,4852,4853],{"class":3603}," -l\n",[3153,4855,4857],{"id":4856},"docker-stop-зупинка-контейнера","docker stop: зупинка контейнера",[3158,4859,4861],{"className":3160,"code":4860,"language":3162,"meta":3163,"style":3163},"docker stop my-nginx\n",[3121,4862,4863],{"__ignoreMap":3163},[3167,4864,4865,4867,4869],{"class":3169,"line":3170},[3167,4866,3174],{"class":3173},[3167,4868,3856],{"class":3177},[3167,4870,3859],{"class":3177},[3114,4872,4044],{},[4046,4874,4875,4878,4881],{},[3245,4876,4877],{},"Docker відправляє сигнал SIGTERM головному процесу контейнера (PID 1)",[3245,4879,4880],{},"Процес має 10 секунд (за замовчуванням) для graceful shutdown",[3245,4882,4883],{},"Якщо процес не завершився за цей час, Docker відправляє SIGKILL (примусове завершення)",[3114,4885,4886],{},"Ви можете змінити таймаут:",[3158,4888,4890],{"className":3160,"code":4889,"language":3162,"meta":3163,"style":3163},"# Дати 30 секунд на graceful shutdown\ndocker stop -t 30 my-nginx\n",[3121,4891,4892,4897],{"__ignoreMap":3163},[3167,4893,4894],{"class":3169,"line":3170},[3167,4895,4896],{"class":3576},"# Дати 30 секунд на graceful shutdown\n",[3167,4898,4899,4901,4903,4905,4908],{"class":3169,"line":3361},[3167,4900,3174],{"class":3173},[3167,4902,3856],{"class":3177},[3167,4904,4740],{"class":3603},[3167,4906,4907],{"class":3967}," 30",[3167,4909,3859],{"class":3177},[3153,4911,4913],{"id":4912},"docker-start-перезапуск-зупиненого-контейнера","docker start: перезапуск зупиненого контейнера",[3158,4915,4917],{"className":3160,"code":4916,"language":3162,"meta":3163,"style":3163},"docker start my-nginx\n",[3121,4918,4919],{"__ignoreMap":3163},[3167,4920,4921,4923,4925],{"class":3169,"line":3170},[3167,4922,3174],{"class":3173},[3167,4924,4337],{"class":3177},[3167,4926,3859],{"class":3177},[3114,4928,4929,4930,4933],{},"Це перезапускає існуючий контейнер зі збереженням всіх його даних та конфігурації. Це ",[3225,4931,4932],{},"не"," створює новий контейнер — це той самий контейнер, який ви зупинили.",[3153,4935,4937],{"id":4936},"docker-restart-перезапуск-контейнера","docker restart: перезапуск контейнера",[3158,4939,4941],{"className":3160,"code":4940,"language":3162,"meta":3163,"style":3163},"docker restart my-nginx\n",[3121,4942,4943],{"__ignoreMap":3163},[3167,4944,4945,4947,4950],{"class":3169,"line":3170},[3167,4946,3174],{"class":3173},[3167,4948,4949],{"class":3177}," restart",[3167,4951,3859],{"class":3177},[3114,4953,4954,4955,4958,4959,4962],{},"Еквівалентно ",[3121,4956,4957],{},"docker stop"," + ",[3121,4960,4961],{},"docker start",", але в одній команді.",[3153,4964,4966],{"id":4965},"docker-kill-примусове-завершення","docker kill: примусове завершення",[3158,4968,4970],{"className":3160,"code":4969,"language":3162,"meta":3163,"style":3163},"docker kill my-nginx\n",[3121,4971,4972],{"__ignoreMap":3163},[3167,4973,4974,4976,4979],{"class":3169,"line":3170},[3167,4975,3174],{"class":3173},[3167,4977,4978],{"class":3177}," kill",[3167,4980,3859],{"class":3177},[3114,4982,4983,4984,3935],{},"Відправляє SIGKILL одразу, без graceful shutdown. Використовуйте лише якщо контейнер \"завис\" і не реагує на ",[3121,4985,4957],{},[3153,4987,4989],{"id":4988},"docker-rm-видалення-контейнера","docker rm: видалення контейнера",[3158,4991,4993],{"className":3160,"code":4992,"language":3162,"meta":3163,"style":3163},"# Видалити зупинений контейнер\ndocker rm my-nginx\n\n# Примусово видалити запущений контейнер\ndocker rm -f my-nginx\n\n# Видалити кілька контейнерів\ndocker rm container1 container2 container3\n\n# Видалити всі зупинені контейнери\ndocker container prune\n",[3121,4994,4995,5000,5009,5013,5018,5028,5032,5037,5052,5056,5061],{"__ignoreMap":3163},[3167,4996,4997],{"class":3169,"line":3170},[3167,4998,4999],{"class":3576},"# Видалити зупинений контейнер\n",[3167,5001,5002,5004,5007],{"class":3169,"line":3361},[3167,5003,3174],{"class":3173},[3167,5005,5006],{"class":3177}," rm",[3167,5008,3859],{"class":3177},[3167,5010,5011],{"class":3169,"line":3367},[3167,5012,3377],{"emptyLinePlaceholder":3376},[3167,5014,5015],{"class":3169,"line":3373},[3167,5016,5017],{"class":3576},"# Примусово видалити запущений контейнер\n",[3167,5019,5020,5022,5024,5026],{"class":3169,"line":3380},[3167,5021,3174],{"class":3173},[3167,5023,5006],{"class":3177},[3167,5025,4720],{"class":3603},[3167,5027,3859],{"class":3177},[3167,5029,5030],{"class":3169,"line":3386},[3167,5031,3377],{"emptyLinePlaceholder":3376},[3167,5033,5034],{"class":3169,"line":3392},[3167,5035,5036],{"class":3576},"# Видалити кілька контейнерів\n",[3167,5038,5039,5041,5043,5046,5049],{"class":3169,"line":3398},[3167,5040,3174],{"class":3173},[3167,5042,5006],{"class":3177},[3167,5044,5045],{"class":3177}," container1",[3167,5047,5048],{"class":3177}," container2",[3167,5050,5051],{"class":3177}," container3\n",[3167,5053,5054],{"class":3169,"line":3404},[3167,5055,3377],{"emptyLinePlaceholder":3376},[3167,5057,5058],{"class":3169,"line":3410},[3167,5059,5060],{"class":3576},"# Видалити всі зупинені контейнери\n",[3167,5062,5063,5065,5068],{"class":3169,"line":3415},[3167,5064,3174],{"class":3173},[3167,5066,5067],{"class":3177}," container",[3167,5069,5070],{"class":3177}," prune\n",[5072,5073,5074,5077],"warning",{},[3121,5075,5076],{},"docker rm"," видаляє контейнер назавжди, включно з усіма даними всередині нього (якщо вони не збережені у томах). Переконайтеся, що ви зберегли важливі дані перед видаленням контейнера.",[3153,5079,5081],{"id":5080},"практичний-приклад-повний-цикл","Практичний приклад: повний цикл",[3114,5083,5084],{},"Давайте пройдемо повний життєвий цикл контейнера:",[3158,5086,5088],{"className":3160,"code":5087,"language":3162,"meta":3163,"style":3163},"# 1. Створення та запуск\ndocker run -d -p 8080:80 --name web nginx\n\n# 2. Перевірка статусу\ndocker ps\n\n# 3. Перегляд логів\ndocker logs web\n\n# 4. Зупинка\ndocker stop web\n\n# 5. Перевірка (контейнер зупинено, але існує)\ndocker ps -a\n\n# 6. Перезапуск\ndocker start web\n\n# 7. Перезавантаження\ndocker restart web\n\n# 8. Остаточна зупинка\ndocker stop web\n\n# 9. Видалення\ndocker rm web\n\n# 10. Перевірка (контейнера більше немає)\ndocker ps -a\n",[3121,5089,5090,5095,5114,5118,5123,5129,5133,5138,5147,5151,5156,5164,5168,5173,5181,5185,5190,5198,5202,5207,5215,5219,5224,5232,5236,5241,5249,5253,5258],{"__ignoreMap":3163},[3167,5091,5092],{"class":3169,"line":3170},[3167,5093,5094],{"class":3576},"# 1. Створення та запуск\n",[3167,5096,5097,5099,5101,5103,5105,5107,5109,5112],{"class":3169,"line":3361},[3167,5098,3174],{"class":3173},[3167,5100,3178],{"class":3177},[3167,5102,3742],{"class":3603},[3167,5104,3917],{"class":3603},[3167,5106,3920],{"class":3177},[3167,5108,3834],{"class":3603},[3167,5110,5111],{"class":3177}," web",[3167,5113,3745],{"class":3177},[3167,5115,5116],{"class":3169,"line":3367},[3167,5117,3377],{"emptyLinePlaceholder":3376},[3167,5119,5120],{"class":3169,"line":3373},[3167,5121,5122],{"class":3576},"# 2. Перевірка статусу\n",[3167,5124,5125,5127],{"class":3169,"line":3380},[3167,5126,3174],{"class":3173},[3167,5128,4582],{"class":3177},[3167,5130,5131],{"class":3169,"line":3386},[3167,5132,3377],{"emptyLinePlaceholder":3376},[3167,5134,5135],{"class":3169,"line":3392},[3167,5136,5137],{"class":3576},"# 3. Перегляд логів\n",[3167,5139,5140,5142,5144],{"class":3169,"line":3398},[3167,5141,3174],{"class":3173},[3167,5143,3866],{"class":3177},[3167,5145,5146],{"class":3177}," web\n",[3167,5148,5149],{"class":3169,"line":3404},[3167,5150,3377],{"emptyLinePlaceholder":3376},[3167,5152,5153],{"class":3169,"line":3410},[3167,5154,5155],{"class":3576},"# 4. Зупинка\n",[3167,5157,5158,5160,5162],{"class":3169,"line":3415},[3167,5159,3174],{"class":3173},[3167,5161,3856],{"class":3177},[3167,5163,5146],{"class":3177},[3167,5165,5166],{"class":3169,"line":3421},[3167,5167,3377],{"emptyLinePlaceholder":3376},[3167,5169,5170],{"class":3169,"line":3427},[3167,5171,5172],{"class":3576},"# 5. Перевірка (контейнер зупинено, але існує)\n",[3167,5174,5175,5177,5179],{"class":3169,"line":3433},[3167,5176,3174],{"class":3173},[3167,5178,3600],{"class":3177},[3167,5180,3604],{"class":3603},[3167,5182,5183],{"class":3169,"line":3439},[3167,5184,3377],{"emptyLinePlaceholder":3376},[3167,5186,5187],{"class":3169,"line":3445},[3167,5188,5189],{"class":3576},"# 6. Перезапуск\n",[3167,5191,5192,5194,5196],{"class":3169,"line":3451},[3167,5193,3174],{"class":3173},[3167,5195,4337],{"class":3177},[3167,5197,5146],{"class":3177},[3167,5199,5200],{"class":3169,"line":3457},[3167,5201,3377],{"emptyLinePlaceholder":3376},[3167,5203,5204],{"class":3169,"line":3463},[3167,5205,5206],{"class":3576},"# 7. Перезавантаження\n",[3167,5208,5209,5211,5213],{"class":3169,"line":3469},[3167,5210,3174],{"class":3173},[3167,5212,4949],{"class":3177},[3167,5214,5146],{"class":3177},[3167,5216,5217],{"class":3169,"line":3475},[3167,5218,3377],{"emptyLinePlaceholder":3376},[3167,5220,5221],{"class":3169,"line":3481},[3167,5222,5223],{"class":3576},"# 8. Остаточна зупинка\n",[3167,5225,5226,5228,5230],{"class":3169,"line":3487},[3167,5227,3174],{"class":3173},[3167,5229,3856],{"class":3177},[3167,5231,5146],{"class":3177},[3167,5233,5234],{"class":3169,"line":3493},[3167,5235,3377],{"emptyLinePlaceholder":3376},[3167,5237,5238],{"class":3169,"line":3499},[3167,5239,5240],{"class":3576},"# 9. Видалення\n",[3167,5242,5243,5245,5247],{"class":3169,"line":3505},[3167,5244,3174],{"class":3173},[3167,5246,5006],{"class":3177},[3167,5248,5146],{"class":3177},[3167,5250,5251],{"class":3169,"line":3511},[3167,5252,3377],{"emptyLinePlaceholder":3376},[3167,5254,5255],{"class":3169,"line":3517},[3167,5256,5257],{"class":3576},"# 10. Перевірка (контейнера більше немає)\n",[3167,5259,5260,5262,5264],{"class":3169,"line":3523},[3167,5261,3174],{"class":3173},[3167,5263,3600],{"class":3177},[3167,5265,3604],{"class":3603},[3139,5267],{},[3109,5269,5271],{"id":5270},"запуск-net-застосунку-в-контейнері","Запуск .NET застосунку в контейнері",[3114,5273,5274],{},"Тепер, коли ми освоїли базові операції з контейнерами, запустимо щось більш релевантне для C# розробників — .NET застосунок.",[3153,5276,5278],{"id":5277},"перевірка-версії-net-sdk","Перевірка версії .NET SDK",[3114,5280,5281],{},"Спочатку перевіримо, яка версія .NET доступна в офіційному образі:",[3158,5283,5285],{"className":3160,"code":5284,"language":3162,"meta":3163,"style":3163},"docker run --rm mcr.microsoft.com/dotnet/sdk:8.0 dotnet --version\n",[3121,5286,5287],{"__ignoreMap":3163},[3167,5288,5289,5291,5293,5295,5298,5301],{"class":3169,"line":3170},[3167,5290,3174],{"class":3173},[3167,5292,3178],{"class":3177},[3167,5294,3889],{"class":3603},[3167,5296,5297],{"class":3177}," mcr.microsoft.com/dotnet/sdk:8.0",[3167,5299,5300],{"class":3177}," dotnet",[3167,5302,5303],{"class":3603}," --version\n",[3114,5305,4396],{},[3242,5307,5308,5313,5319],{},[3245,5309,5310,5312],{},[3121,5311,3617],{}," — автоматично видалити контейнер після завершення",[3245,5314,5315,5318],{},[3121,5316,5317],{},"mcr.microsoft.com/dotnet/sdk:8.0"," — офіційний образ .NET SDK версії 8.0 з Microsoft Container Registry",[3245,5320,5321,5324],{},[3121,5322,5323],{},"dotnet --version"," — команда для виконання всередині контейнера",[3114,5326,4585],{},[3158,5328,5331],{"className":5329,"code":5330,"language":3211},[3209],"8.0.204\n",[3121,5332,5330],{"__ignoreMap":3163},[3114,5334,5335],{},"Це показує точну версію .NET SDK всередині контейнера. Зверніть увагу: ми не встановлювали .NET на нашу машину — він працює виключно всередині контейнера!",[3153,5337,5339],{"id":5338},"запуск-інтерактивного-net-repl","Запуск інтерактивного .NET REPL",[3114,5341,5342,5343,5346],{},".NET має інтерактивний REPL (Read-Eval-Print Loop) через ",[3121,5344,5345],{},"dotnet-script",". Запустимо його:",[3158,5348,5350],{"className":3160,"code":5349,"language":3162,"meta":3163,"style":3163},"docker run -it --rm mcr.microsoft.com/dotnet/sdk:8.0 bash\n",[3121,5351,5352],{"__ignoreMap":3163},[3167,5353,5354,5356,5358,5360,5362,5364],{"class":3169,"line":3170},[3167,5355,3174],{"class":3173},[3167,5357,3178],{"class":3177},[3167,5359,3796],{"class":3603},[3167,5361,3889],{"class":3603},[3167,5363,5297],{"class":3177},[3167,5365,3802],{"class":3177},[3114,5367,5368],{},"Всередині контейнера:",[3158,5370,5372],{"className":3160,"code":5371,"language":3162,"meta":3163,"style":3163},"# Встановлення dotnet-script\ndotnet tool install -g dotnet-script\n\n# Додавання до PATH\nexport PATH=\"$PATH:/root/.dotnet/tools\"\n\n# Запуск REPL\ndotnet script\n",[3121,5373,5374,5379,5395,5399,5404,5425,5429,5434],{"__ignoreMap":3163},[3167,5375,5376],{"class":3169,"line":3170},[3167,5377,5378],{"class":3576},"# Встановлення dotnet-script\n",[3167,5380,5381,5384,5387,5389,5392],{"class":3169,"line":3361},[3167,5382,5383],{"class":3173},"dotnet",[3167,5385,5386],{"class":3177}," tool",[3167,5388,4142],{"class":3177},[3167,5390,5391],{"class":3603}," -g",[3167,5393,5394],{"class":3177}," dotnet-script\n",[3167,5396,5397],{"class":3169,"line":3367},[3167,5398,3377],{"emptyLinePlaceholder":3376},[3167,5400,5401],{"class":3169,"line":3373},[3167,5402,5403],{"class":3576},"# Додавання до PATH\n",[3167,5405,5406,5409,5413,5416,5419,5422],{"class":3169,"line":3380},[3167,5407,5408],{"class":3603},"export",[3167,5410,5412],{"class":5411},"siwwj"," PATH",[3167,5414,5415],{"class":3652},"=",[3167,5417,5418],{"class":3177},"\"",[3167,5420,5421],{"class":5411},"$PATH",[3167,5423,5424],{"class":3177},":/root/.dotnet/tools\"\n",[3167,5426,5427],{"class":3169,"line":3386},[3167,5428,3377],{"emptyLinePlaceholder":3376},[3167,5430,5431],{"class":3169,"line":3392},[3167,5432,5433],{"class":3576},"# Запуск REPL\n",[3167,5435,5436,5438],{"class":3169,"line":3398},[3167,5437,5383],{"class":3173},[3167,5439,5440],{"class":3177}," script\n",[3114,5442,5443],{},"Тепер ви можете виконувати C# код інтерактивно:",[3158,5445,5449],{"className":5446,"code":5447,"language":5448,"meta":3163,"style":3163},"language-csharp shiki shiki-themes light-plus dark-plus dark-plus","> var message = \"Hello from Docker!\";\n> Console.WriteLine(message);\nHello from Docker!\n\n> var numbers = Enumerable.Range(1, 10);\n> numbers.Sum()\n55\n\n> DateTime.Now\n[14.04.2026 08:20:59]\n","csharp",[3121,5450,5451,5471,5492,5506,5510,5541,5556,5561,5565,5577],{"__ignoreMap":3163},[3167,5452,5453,5456,5459,5462,5465,5468],{"class":3169,"line":3170},[3167,5454,5455],{"class":3652},"> ",[3167,5457,5458],{"class":3603},"var",[3167,5460,5461],{"class":5411}," message",[3167,5463,5464],{"class":3652}," = ",[3167,5466,5467],{"class":3177},"\"Hello from Docker!\"",[3167,5469,5470],{"class":3652},";\n",[3167,5472,5473,5475,5478,5480,5483,5486,5489],{"class":3169,"line":3361},[3167,5474,5455],{"class":3652},[3167,5476,5477],{"class":5411},"Console",[3167,5479,3935],{"class":3652},[3167,5481,5482],{"class":3173},"WriteLine",[3167,5484,5485],{"class":3652},"(",[3167,5487,5488],{"class":5411},"message",[3167,5490,5491],{"class":3652},");\n",[3167,5493,5494,5497,5500,5503],{"class":3169,"line":3367},[3167,5495,5496],{"class":5411},"Hello",[3167,5498,5499],{"class":5411}," from",[3167,5501,5502],{"class":5411}," Docker",[3167,5504,5505],{"class":3652},"!\n",[3167,5507,5508],{"class":3169,"line":3373},[3167,5509,3377],{"emptyLinePlaceholder":3376},[3167,5511,5512,5514,5516,5519,5521,5524,5526,5529,5531,5534,5536,5539],{"class":3169,"line":3380},[3167,5513,5455],{"class":3652},[3167,5515,5458],{"class":3603},[3167,5517,5518],{"class":5411}," numbers",[3167,5520,5464],{"class":3652},[3167,5522,5523],{"class":5411},"Enumerable",[3167,5525,3935],{"class":3652},[3167,5527,5528],{"class":3173},"Range",[3167,5530,5485],{"class":3652},[3167,5532,5533],{"class":3967},"1",[3167,5535,3816],{"class":3652},[3167,5537,5538],{"class":3967},"10",[3167,5540,5491],{"class":3652},[3167,5542,5543,5545,5548,5550,5553],{"class":3169,"line":3386},[3167,5544,5455],{"class":3652},[3167,5546,5547],{"class":5411},"numbers",[3167,5549,3935],{"class":3652},[3167,5551,5552],{"class":3173},"Sum",[3167,5554,5555],{"class":3652},"()\n",[3167,5557,5558],{"class":3169,"line":3392},[3167,5559,5560],{"class":3967},"55\n",[3167,5562,5563],{"class":3169,"line":3398},[3167,5564,3377],{"emptyLinePlaceholder":3376},[3167,5566,5567,5569,5572,5574],{"class":3169,"line":3404},[3167,5568,5455],{"class":3652},[3167,5570,5571],{"class":5411},"DateTime",[3167,5573,3935],{"class":3652},[3167,5575,5576],{"class":5411},"Now\n",[3167,5578,5579],{"class":3169,"line":3410},[3167,5580,5581],{"class":3652},"[14.04.2026 08:20:59]\n",[3114,5583,5584,5585,3935],{},"Це демонструє потужність Docker — ви можете експериментувати з різними версіями .NET, не встановлюючи їх на свою систему. Потрібен .NET 6? Просто використайте образ ",[3121,5586,5587],{},"mcr.microsoft.com/dotnet/sdk:6.0",[3153,5589,5591],{"id":5590},"компіляція-та-запуск-простого-c-застосунку","Компіляція та запуск простого C# застосунку",[3114,5593,5594],{},"Створимо простий консольний застосунок прямо в контейнері:",[3158,5596,5598],{"className":3160,"code":5597,"language":3162,"meta":3163,"style":3163},"# Запуск контейнера з монтуванням поточної директорії\ndocker run -it --rm -v $(pwd):/app -w /app mcr.microsoft.com/dotnet/sdk:8.0 bash\n",[3121,5599,5600,5605],{"__ignoreMap":3163},[3167,5601,5602],{"class":3169,"line":3170},[3167,5603,5604],{"class":3576},"# Запуск контейнера з монтуванням поточної директорії\n",[3167,5606,5607,5609,5611,5613,5615,5617,5620,5623,5625,5628,5631,5634,5636],{"class":3169,"line":3361},[3167,5608,3174],{"class":3173},[3167,5610,3178],{"class":3177},[3167,5612,3796],{"class":3603},[3167,5614,3889],{"class":3603},[3167,5616,4004],{"class":3603},[3167,5618,5619],{"class":3652}," $(",[3167,5621,5622],{"class":3173},"pwd",[3167,5624,3680],{"class":3652},[3167,5626,5627],{"class":3177},":/app",[3167,5629,5630],{"class":3603}," -w",[3167,5632,5633],{"class":3177}," /app",[3167,5635,5297],{"class":3177},[3167,5637,3802],{"class":3177},[3114,5639,5640],{},"Прапорці:",[3242,5642,5643,5653],{},[3245,5644,5645,5648,5649,5652],{},[3121,5646,5647],{},"-v $(pwd):/app"," — монтує поточну директорію хоста в ",[3121,5650,5651],{},"/app"," контейнера",[3245,5654,5655,5658,5659,5661],{},[3121,5656,5657],{},"-w /app"," — встановлює ",[3121,5660,5651],{}," як робочу директорію",[3114,5663,5368],{},[3158,5665,5667],{"className":3160,"code":5666,"language":3162,"meta":3163,"style":3163},"# Створення нового консольного проєкту\ndotnet new console -n HelloDocker\n\n# Перехід у директорію проєкту\ncd HelloDocker\n\n# Редагування Program.cs (використаємо echo для простоти)\ncat > Program.cs \u003C\u003C 'EOF'\nConsole.WriteLine(\"Hello from .NET in Docker!\");\nConsole.WriteLine($\"Current time: {DateTime.Now}\");\nConsole.WriteLine($\"OS: {Environment.OSVersion}\");\nConsole.WriteLine($\"Runtime: {Environment.Version}\");\nEOF\n\n# Запуск застосунку\ndotnet run\n",[3121,5668,5669,5674,5690,5694,5699,5706,5710,5715,5730,5735,5740,5745,5750,5755,5759,5764],{"__ignoreMap":3163},[3167,5670,5671],{"class":3169,"line":3170},[3167,5672,5673],{"class":3576},"# Створення нового консольного проєкту\n",[3167,5675,5676,5678,5681,5684,5687],{"class":3169,"line":3361},[3167,5677,5383],{"class":3173},[3167,5679,5680],{"class":3177}," new",[3167,5682,5683],{"class":3177}," console",[3167,5685,5686],{"class":3603}," -n",[3167,5688,5689],{"class":3177}," HelloDocker\n",[3167,5691,5692],{"class":3169,"line":3367},[3167,5693,3377],{"emptyLinePlaceholder":3376},[3167,5695,5696],{"class":3169,"line":3373},[3167,5697,5698],{"class":3576},"# Перехід у директорію проєкту\n",[3167,5700,5701,5704],{"class":3169,"line":3380},[3167,5702,5703],{"class":3173},"cd",[3167,5705,5689],{"class":3177},[3167,5707,5708],{"class":3169,"line":3386},[3167,5709,3377],{"emptyLinePlaceholder":3376},[3167,5711,5712],{"class":3169,"line":3392},[3167,5713,5714],{"class":3576},"# Редагування Program.cs (використаємо echo для простоти)\n",[3167,5716,5717,5719,5721,5724,5727],{"class":3169,"line":3398},[3167,5718,4097],{"class":3173},[3167,5720,4185],{"class":3652},[3167,5722,5723],{"class":3177},"Program.cs",[3167,5725,5726],{"class":3652}," \u003C\u003C ",[3167,5728,5729],{"class":3652},"'EOF'\n",[3167,5731,5732],{"class":3169,"line":3404},[3167,5733,5734],{"class":3177},"Console.WriteLine(\"Hello from .NET in Docker!\");\n",[3167,5736,5737],{"class":3169,"line":3410},[3167,5738,5739],{"class":3177},"Console.WriteLine($\"Current time: {DateTime.Now}\");\n",[3167,5741,5742],{"class":3169,"line":3415},[3167,5743,5744],{"class":3177},"Console.WriteLine($\"OS: {Environment.OSVersion}\");\n",[3167,5746,5747],{"class":3169,"line":3421},[3167,5748,5749],{"class":3177},"Console.WriteLine($\"Runtime: {Environment.Version}\");\n",[3167,5751,5752],{"class":3169,"line":3427},[3167,5753,5754],{"class":3652},"EOF\n",[3167,5756,5757],{"class":3169,"line":3433},[3167,5758,3377],{"emptyLinePlaceholder":3376},[3167,5760,5761],{"class":3169,"line":3439},[3167,5762,5763],{"class":3576},"# Запуск застосунку\n",[3167,5765,5766,5768],{"class":3169,"line":3445},[3167,5767,5383],{"class":3173},[3167,5769,5770],{"class":3177}," run\n",[3114,5772,4585],{},[3158,5774,5777],{"className":5775,"code":5776,"language":3211},[3209],"Hello from .NET in Docker!\nCurrent time: 14.04.2026 08:20:59\nOS: Unix 5.15.0.102\nRuntime: 8.0.4\n",[3121,5778,5776],{"__ignoreMap":3163},[3114,5780,5781],{},"Цікаво: застосунок працює на Linux (всередині контейнера), навіть якщо ваш хост — Windows або macOS. Це демонструє кросплатформність .NET та портативність Docker.",[3612,5783,5784,5785,5788],{},"Монтування директорії хоста (",[3121,5786,5787],{},"-v",") дозволяє зберігати файли між запусками контейнерів. Коли ви виходите з контейнера, файли проєкту залишаються на вашому хості, і ви можете відкрити їх у IDE.",[3139,5790],{},[3109,5792,5794],{"id":5793},"корисні-патерни-та-best-practices","Корисні патерни та best practices",[3114,5796,5797,5798,3935],{},"На завершення розглянемо кілька корисних патернів роботи з ",[3121,5799,3123],{},[3153,5801,5803],{"id":5802},"іменування-контейнерів","Іменування контейнерів",[3114,5805,5806],{},"Завжди давайте контейнерам осмислені імена:",[3158,5808,5810],{"className":3160,"code":5809,"language":3162,"meta":3163,"style":3163},"# Погано: випадкове ім'я\ndocker run -d nginx\n\n# Добре: описове ім'я\ndocker run -d --name frontend-nginx nginx\ndocker run -d --name api-server myapp:latest\ndocker run -d --name postgres-dev postgres:15\n",[3121,5811,5812,5817,5827,5831,5836,5851,5867],{"__ignoreMap":3163},[3167,5813,5814],{"class":3169,"line":3170},[3167,5815,5816],{"class":3576},"# Погано: випадкове ім'я\n",[3167,5818,5819,5821,5823,5825],{"class":3169,"line":3361},[3167,5820,3174],{"class":3173},[3167,5822,3178],{"class":3177},[3167,5824,3742],{"class":3603},[3167,5826,3745],{"class":3177},[3167,5828,5829],{"class":3169,"line":3367},[3167,5830,3377],{"emptyLinePlaceholder":3376},[3167,5832,5833],{"class":3169,"line":3373},[3167,5834,5835],{"class":3576},"# Добре: описове ім'я\n",[3167,5837,5838,5840,5842,5844,5846,5849],{"class":3169,"line":3380},[3167,5839,3174],{"class":3173},[3167,5841,3178],{"class":3177},[3167,5843,3742],{"class":3603},[3167,5845,3834],{"class":3603},[3167,5847,5848],{"class":3177}," frontend-nginx",[3167,5850,3745],{"class":3177},[3167,5852,5853,5855,5857,5859,5861,5864],{"class":3169,"line":3386},[3167,5854,3174],{"class":3173},[3167,5856,3178],{"class":3177},[3167,5858,3742],{"class":3603},[3167,5860,3834],{"class":3603},[3167,5862,5863],{"class":3177}," api-server",[3167,5865,5866],{"class":3177}," myapp:latest\n",[3167,5868,5869,5871,5873,5875,5877,5880],{"class":3169,"line":3392},[3167,5870,3174],{"class":3173},[3167,5872,3178],{"class":3177},[3167,5874,3742],{"class":3603},[3167,5876,3834],{"class":3603},[3167,5878,5879],{"class":3177}," postgres-dev",[3167,5881,5882],{"class":3177}," postgres:15\n",[3114,5884,5885],{},"Це спрощує управління, особливо коли у вас багато контейнерів.",[3153,5887,5889],{"id":5888},"обмеження-ресурсів","Обмеження ресурсів",[3114,5891,5892],{},"Обмежуйте ресурси контейнерів, щоб один контейнер не міг \"з'їсти\" всю систему:",[3158,5894,5896],{"className":3160,"code":5895,"language":3162,"meta":3163,"style":3163},"# Обмеження пам'яті до 512 МБ\ndocker run -d --memory=\"512m\" nginx\n\n# Обмеження CPU до 50% одного ядра\ndocker run -d --cpus=\"0.5\" nginx\n\n# Комбінація обмежень\ndocker run -d --memory=\"1g\" --cpus=\"1.0\" --name limited-nginx nginx\n",[3121,5897,5898,5903,5919,5923,5928,5944,5948,5953],{"__ignoreMap":3163},[3167,5899,5900],{"class":3169,"line":3170},[3167,5901,5902],{"class":3576},"# Обмеження пам'яті до 512 МБ\n",[3167,5904,5905,5907,5909,5911,5914,5917],{"class":3169,"line":3361},[3167,5906,3174],{"class":3173},[3167,5908,3178],{"class":3177},[3167,5910,3742],{"class":3603},[3167,5912,5913],{"class":3603}," --memory=",[3167,5915,5916],{"class":3177},"\"512m\"",[3167,5918,3745],{"class":3177},[3167,5920,5921],{"class":3169,"line":3367},[3167,5922,3377],{"emptyLinePlaceholder":3376},[3167,5924,5925],{"class":3169,"line":3373},[3167,5926,5927],{"class":3576},"# Обмеження CPU до 50% одного ядра\n",[3167,5929,5930,5932,5934,5936,5939,5942],{"class":3169,"line":3380},[3167,5931,3174],{"class":3173},[3167,5933,3178],{"class":3177},[3167,5935,3742],{"class":3603},[3167,5937,5938],{"class":3603}," --cpus=",[3167,5940,5941],{"class":3177},"\"0.5\"",[3167,5943,3745],{"class":3177},[3167,5945,5946],{"class":3169,"line":3386},[3167,5947,3377],{"emptyLinePlaceholder":3376},[3167,5949,5950],{"class":3169,"line":3392},[3167,5951,5952],{"class":3576},"# Комбінація обмежень\n",[3167,5954,5955,5957,5959,5961,5963,5966,5968,5971,5973,5976],{"class":3169,"line":3398},[3167,5956,3174],{"class":3173},[3167,5958,3178],{"class":3177},[3167,5960,3742],{"class":3603},[3167,5962,5913],{"class":3603},[3167,5964,5965],{"class":3177},"\"1g\"",[3167,5967,5938],{"class":3603},[3167,5969,5970],{"class":3177},"\"1.0\"",[3167,5972,3834],{"class":3603},[3167,5974,5975],{"class":3177}," limited-nginx",[3167,5977,3745],{"class":3177},[3153,5979,5981],{"id":5980},"автоматичний-перезапуск","Автоматичний перезапуск",[3114,5983,5984],{},"Налаштуйте політику перезапуску для production-контейнерів:",[3158,5986,5988],{"className":3160,"code":5987,"language":3162,"meta":3163,"style":3163},"# Завжди перезапускати (навіть після перезавантаження хоста)\ndocker run -d --restart=always --name persistent-nginx nginx\n\n# Перезапускати лише при падінні (не при ручній зупинці)\ndocker run -d --restart=unless-stopped nginx\n\n# Перезапускати максимум 3 рази при падінні\ndocker run -d --restart=on-failure:3 nginx\n",[3121,5989,5990,5995,6013,6017,6022,6035,6039,6044],{"__ignoreMap":3163},[3167,5991,5992],{"class":3169,"line":3170},[3167,5993,5994],{"class":3576},"# Завжди перезапускати (навіть після перезавантаження хоста)\n",[3167,5996,5997,5999,6001,6003,6006,6008,6011],{"class":3169,"line":3361},[3167,5998,3174],{"class":3173},[3167,6000,3178],{"class":3177},[3167,6002,3742],{"class":3603},[3167,6004,6005],{"class":3603}," --restart=always",[3167,6007,3834],{"class":3603},[3167,6009,6010],{"class":3177}," persistent-nginx",[3167,6012,3745],{"class":3177},[3167,6014,6015],{"class":3169,"line":3367},[3167,6016,3377],{"emptyLinePlaceholder":3376},[3167,6018,6019],{"class":3169,"line":3373},[3167,6020,6021],{"class":3576},"# Перезапускати лише при падінні (не при ручній зупинці)\n",[3167,6023,6024,6026,6028,6030,6033],{"class":3169,"line":3380},[3167,6025,3174],{"class":3173},[3167,6027,3178],{"class":3177},[3167,6029,3742],{"class":3603},[3167,6031,6032],{"class":3603}," --restart=unless-stopped",[3167,6034,3745],{"class":3177},[3167,6036,6037],{"class":3169,"line":3386},[3167,6038,3377],{"emptyLinePlaceholder":3376},[3167,6040,6041],{"class":3169,"line":3392},[3167,6042,6043],{"class":3576},"# Перезапускати максимум 3 рази при падінні\n",[3167,6045,6046,6048,6050,6052,6055],{"class":3169,"line":3398},[3167,6047,3174],{"class":3173},[3167,6049,3178],{"class":3177},[3167,6051,3742],{"class":3603},[3167,6053,6054],{"class":3603}," --restart=on-failure:3",[3167,6056,3745],{"class":3177},[3153,6058,6060],{"id":6059},"змінні-оточення-з-файлу","Змінні оточення з файлу",[3114,6062,6063],{},"Замість передачі кожної змінної окремо, використовуйте файл:",[3158,6065,6067],{"className":3160,"code":6066,"language":3162,"meta":3163,"style":3163},"# Створення .env файлу\ncat > app.env \u003C\u003C EOF\nDATABASE_URL=postgresql://localhost/mydb\nAPI_KEY=secret123\nDEBUG=true\nEOF\n\n# Запуск з файлом змінних\ndocker run --env-file app.env myapp:latest\n",[3121,6068,6069,6074,6087,6092,6097,6102,6106,6110,6115],{"__ignoreMap":3163},[3167,6070,6071],{"class":3169,"line":3170},[3167,6072,6073],{"class":3576},"# Створення .env файлу\n",[3167,6075,6076,6078,6080,6083,6085],{"class":3169,"line":3361},[3167,6077,4097],{"class":3173},[3167,6079,4185],{"class":3652},[3167,6081,6082],{"class":3177},"app.env",[3167,6084,5726],{"class":3652},[3167,6086,5754],{"class":3652},[3167,6088,6089],{"class":3169,"line":3367},[3167,6090,6091],{"class":3177},"DATABASE_URL=postgresql://localhost/mydb\n",[3167,6093,6094],{"class":3169,"line":3373},[3167,6095,6096],{"class":3177},"API_KEY=secret123\n",[3167,6098,6099],{"class":3169,"line":3380},[3167,6100,6101],{"class":3177},"DEBUG=true\n",[3167,6103,6104],{"class":3169,"line":3386},[3167,6105,5754],{"class":3652},[3167,6107,6108],{"class":3169,"line":3392},[3167,6109,3377],{"emptyLinePlaceholder":3376},[3167,6111,6112],{"class":3169,"line":3398},[3167,6113,6114],{"class":3576},"# Запуск з файлом змінних\n",[3167,6116,6117,6119,6121,6124,6127],{"class":3169,"line":3404},[3167,6118,3174],{"class":3173},[3167,6120,3178],{"class":3177},[3167,6122,6123],{"class":3603}," --env-file",[3167,6125,6126],{"class":3177}," app.env",[3167,6128,5866],{"class":3177},[3153,6130,6132],{"id":6131},"очищення-ресурсів","Очищення ресурсів",[3114,6134,6135],{},"Регулярно очищайте непотрібні контейнери та образи:",[3158,6137,6139],{"className":3160,"code":6138,"language":3162,"meta":3163,"style":3163},"# Видалити всі зупинені контейнери\ndocker container prune\n\n# Видалити невикористані образи\ndocker image prune\n\n# Видалити все невикористане (контейнери, образи, мережі, томи)\ndocker system prune -a\n\n# З підтвердженням обсягу звільненого місця\ndocker system df\n",[3121,6140,6141,6145,6153,6157,6162,6171,6175,6180,6192,6196,6201],{"__ignoreMap":3163},[3167,6142,6143],{"class":3169,"line":3170},[3167,6144,5060],{"class":3576},[3167,6146,6147,6149,6151],{"class":3169,"line":3361},[3167,6148,3174],{"class":3173},[3167,6150,5067],{"class":3177},[3167,6152,5070],{"class":3177},[3167,6154,6155],{"class":3169,"line":3367},[3167,6156,3377],{"emptyLinePlaceholder":3376},[3167,6158,6159],{"class":3169,"line":3373},[3167,6160,6161],{"class":3576},"# Видалити невикористані образи\n",[3167,6163,6164,6166,6169],{"class":3169,"line":3380},[3167,6165,3174],{"class":3173},[3167,6167,6168],{"class":3177}," image",[3167,6170,5070],{"class":3177},[3167,6172,6173],{"class":3169,"line":3386},[3167,6174,3377],{"emptyLinePlaceholder":3376},[3167,6176,6177],{"class":3169,"line":3392},[3167,6178,6179],{"class":3576},"# Видалити все невикористане (контейнери, образи, мережі, томи)\n",[3167,6181,6182,6184,6187,6190],{"class":3169,"line":3398},[3167,6183,3174],{"class":3173},[3167,6185,6186],{"class":3177}," system",[3167,6188,6189],{"class":3177}," prune",[3167,6191,3604],{"class":3603},[3167,6193,6194],{"class":3169,"line":3404},[3167,6195,3377],{"emptyLinePlaceholder":3376},[3167,6197,6198],{"class":3169,"line":3410},[3167,6199,6200],{"class":3576},"# З підтвердженням обсягу звільненого місця\n",[3167,6202,6203,6205,6207],{"class":3169,"line":3415},[3167,6204,3174],{"class":3173},[3167,6206,6186],{"class":3177},[3167,6208,6209],{"class":3177}," df\n",[5072,6211,6212,6215,6216,6219],{},[3121,6213,6214],{},"docker system prune -a"," видаляє ",[3225,6217,6218],{},"всі"," невикористані образи, включно з тими, які ви можете захотіти використати пізніше. Використовуйте обережно, особливо якщо у вас повільний інтернет для повторного завантаження образів.",[3139,6221],{},[3109,6223,6225],{"id":6224},"резюме","Резюме",[3114,6227,6228,6229,6231],{},"У цій статті ми зробили перші практичні кроки з Docker, детально розібравши команду ",[3121,6230,3123],{}," та основні операції з контейнерами.",[3114,6233,6234],{},[3225,6235,6236],{},"Ключові концепції:",[3242,6238,6239,6244,6253,6260,6263,6273,6278,6284],{},[3245,6240,6241,6243],{},[3121,6242,3123],{}," створює та запускає новий контейнер з образу",[3245,6245,6246,6247,6249,6250,6252],{},"Контейнери можуть працювати в інтерактивному (",[3121,6248,4285],{},") або фоновому (",[3121,6251,3757],{},") режимах",[3245,6254,6255,6256,6259],{},"Проброс портів (",[3121,6257,6258],{},"-p",") дозволяє отримати доступ до сервісів у контейнері з хоста",[3245,6261,6262],{},"Життєвий цикл контейнера: створення → запуск → зупинка → видалення",[3245,6264,6265,6268,6269,6272],{},[3121,6266,6267],{},"docker ps"," показує запущені контейнери, ",[3121,6270,6271],{},"docker ps -a"," — всі контейнери",[3245,6274,6275,6277],{},[3121,6276,4677],{}," дозволяє переглядати вивід контейнера",[3245,6279,6280,6283],{},[3121,6281,6282],{},"docker stop/start/restart"," керують станом контейнера",[3245,6285,6286,6288],{},[3121,6287,5076],{}," видаляє контейнер назавжди",[3114,6290,6291],{},[3225,6292,6293,6294,4678],{},"Важливі прапорці ",[3121,6295,3123],{},[3242,6297,6298,6302,6307,6312,6317,6322,6328,6333,6342],{},[3245,6299,6300,4403],{},[3121,6301,3757],{},[3245,6303,6304,6306],{},[3121,6305,4285],{}," — interactive + TTY (інтерактивний режим)",[3245,6308,6309,6311],{},[3121,6310,4641],{}," — іменування контейнера",[3245,6313,6314,6316],{},[3121,6315,3617],{}," — автоматичне видалення після зупинки",[3245,6318,6319,6321],{},[3121,6320,6258],{}," — проброс портів",[3245,6323,6324,6327],{},[3121,6325,6326],{},"-e"," — змінні оточення",[3245,6329,6330,6332],{},[3121,6331,5787],{}," — монтування томів",[3245,6334,6335,3816,6338,6341],{},[3121,6336,6337],{},"--memory",[3121,6339,6340],{},"--cpus"," — обмеження ресурсів",[3245,6343,6344,6347],{},[3121,6345,6346],{},"--restart"," — політика перезапуску",[3114,6349,6350],{},"Ми також запустили .NET застосунок у контейнері, продемонструвавши, як Docker дозволяє працювати з різними версіями runtime без встановлення їх на хост-систему.",[3114,6352,6353],{},"У наступній статті ми детально розглянемо життєвий цикл контейнера, стани контейнера, команди для діагностики та моніторингу.",[3139,6355],{},[3109,6357,6359],{"id":6358},"практичні-завдання","Практичні завдання",[3153,6361,6363],{"id":6362},"завдання-1-експерименти-з-різними-образами","Завдання 1: Експерименти з різними образами",[3114,6365,6366],{},"Запустіть контейнери з різних образів та дослідіть їх:",[3158,6368,6370],{"className":3160,"code":6369,"language":3162,"meta":3163,"style":3163},"# Alpine Linux (мінімалістичний дистрибутив)\ndocker run -it --rm alpine sh\n\n# Python REPL\ndocker run -it --rm python:3.12 python\n\n# Node.js REPL\ndocker run -it --rm node:20 node\n\n# PostgreSQL\ndocker run -d --name postgres-test -e POSTGRES_PASSWORD=secret postgres:15\n",[3121,6371,6372,6377,6393,6397,6402,6418,6422,6427,6443,6447,6452],{"__ignoreMap":3163},[3167,6373,6374],{"class":3169,"line":3170},[3167,6375,6376],{"class":3576},"# Alpine Linux (мінімалістичний дистрибутив)\n",[3167,6378,6379,6381,6383,6385,6387,6390],{"class":3169,"line":3361},[3167,6380,3174],{"class":3173},[3167,6382,3178],{"class":3177},[3167,6384,3796],{"class":3603},[3167,6386,3889],{"class":3603},[3167,6388,6389],{"class":3177}," alpine",[3167,6391,6392],{"class":3177}," sh\n",[3167,6394,6395],{"class":3169,"line":3367},[3167,6396,3377],{"emptyLinePlaceholder":3376},[3167,6398,6399],{"class":3169,"line":3373},[3167,6400,6401],{"class":3576},"# Python REPL\n",[3167,6403,6404,6406,6408,6410,6412,6415],{"class":3169,"line":3380},[3167,6405,3174],{"class":3173},[3167,6407,3178],{"class":3177},[3167,6409,3796],{"class":3603},[3167,6411,3889],{"class":3603},[3167,6413,6414],{"class":3177}," python:3.12",[3167,6416,6417],{"class":3177}," python\n",[3167,6419,6420],{"class":3169,"line":3386},[3167,6421,3377],{"emptyLinePlaceholder":3376},[3167,6423,6424],{"class":3169,"line":3392},[3167,6425,6426],{"class":3576},"# Node.js REPL\n",[3167,6428,6429,6431,6433,6435,6437,6440],{"class":3169,"line":3398},[3167,6430,3174],{"class":3173},[3167,6432,3178],{"class":3177},[3167,6434,3796],{"class":3603},[3167,6436,3889],{"class":3603},[3167,6438,6439],{"class":3177}," node:20",[3167,6441,6442],{"class":3177}," node\n",[3167,6444,6445],{"class":3169,"line":3404},[3167,6446,3377],{"emptyLinePlaceholder":3376},[3167,6448,6449],{"class":3169,"line":3410},[3167,6450,6451],{"class":3576},"# PostgreSQL\n",[3167,6453,6454,6456,6458,6460,6462,6465,6467,6470],{"class":3169,"line":3415},[3167,6455,3174],{"class":3173},[3167,6457,3178],{"class":3177},[3167,6459,3742],{"class":3603},[3167,6461,3834],{"class":3603},[3167,6463,6464],{"class":3177}," postgres-test",[3167,6466,3956],{"class":3603},[3167,6468,6469],{"class":3177}," POSTGRES_PASSWORD=secret",[3167,6471,5882],{"class":3177},[3114,6473,6474],{},[3225,6475,6476],{},"Питання:",[3242,6478,6479,6482,6485],{},[3245,6480,6481],{},"Яка різниця в розмірі між образами Ubuntu та Alpine?",[3245,6483,6484],{},"Як підключитися до PostgreSQL з хоста?",[3245,6486,6487],{},"Що станеться з даними PostgreSQL після видалення контейнера?",[3153,6489,6491],{"id":6490},"завдання-2-створення-простого-веб-сервера","Завдання 2: Створення простого веб-сервера",[3114,6493,6494],{},"Створіть HTML-файл та запустіть його через Nginx:",[3158,6496,6498],{"className":3160,"code":6497,"language":3162,"meta":3163,"style":3163},"# Створення HTML-файлу\nmkdir -p ~/docker-test\ncat > ~/docker-test/index.html \u003C\u003C EOF\n\u003C!DOCTYPE html>\n\u003Chtml>\n\u003Chead>\u003Ctitle>My Docker Page\u003C/title>\u003C/head>\n\u003Cbody>\n  \u003Ch1>Hello from Docker!\u003C/h1>\n  \u003Cp>This page is served by Nginx running in a container.\u003C/p>\n\u003C/body>\n\u003C/html>\nEOF\n\n# Запуск Nginx з монтуванням HTML\ndocker run -d -p 8080:80 -v ~/docker-test:/usr/share/nginx/html:ro --name my-web nginx\n",[3121,6499,6500,6505,6515,6528,6533,6538,6543,6548,6553,6558,6563,6568,6572,6576,6581],{"__ignoreMap":3163},[3167,6501,6502],{"class":3169,"line":3170},[3167,6503,6504],{"class":3576},"# Створення HTML-файлу\n",[3167,6506,6507,6510,6512],{"class":3169,"line":3361},[3167,6508,6509],{"class":3173},"mkdir",[3167,6511,3917],{"class":3603},[3167,6513,6514],{"class":3177}," ~/docker-test\n",[3167,6516,6517,6519,6521,6524,6526],{"class":3169,"line":3367},[3167,6518,4097],{"class":3173},[3167,6520,4185],{"class":3652},[3167,6522,6523],{"class":3177},"~/docker-test/index.html",[3167,6525,5726],{"class":3652},[3167,6527,5754],{"class":3652},[3167,6529,6530],{"class":3169,"line":3373},[3167,6531,6532],{"class":3177},"\u003C!DOCTYPE html>\n",[3167,6534,6535],{"class":3169,"line":3380},[3167,6536,6537],{"class":3177},"\u003Chtml>\n",[3167,6539,6540],{"class":3169,"line":3386},[3167,6541,6542],{"class":3177},"\u003Chead>\u003Ctitle>My Docker Page\u003C/title>\u003C/head>\n",[3167,6544,6545],{"class":3169,"line":3392},[3167,6546,6547],{"class":3177},"\u003Cbody>\n",[3167,6549,6550],{"class":3169,"line":3398},[3167,6551,6552],{"class":3177},"  \u003Ch1>Hello from Docker!\u003C/h1>\n",[3167,6554,6555],{"class":3169,"line":3404},[3167,6556,6557],{"class":3177},"  \u003Cp>This page is served by Nginx running in a container.\u003C/p>\n",[3167,6559,6560],{"class":3169,"line":3410},[3167,6561,6562],{"class":3177},"\u003C/body>\n",[3167,6564,6565],{"class":3169,"line":3415},[3167,6566,6567],{"class":3177},"\u003C/html>\n",[3167,6569,6570],{"class":3169,"line":3421},[3167,6571,5754],{"class":3652},[3167,6573,6574],{"class":3169,"line":3427},[3167,6575,3377],{"emptyLinePlaceholder":3376},[3167,6577,6578],{"class":3169,"line":3433},[3167,6579,6580],{"class":3576},"# Запуск Nginx з монтуванням HTML\n",[3167,6582,6583,6585,6587,6589,6591,6593,6595,6598,6600,6603],{"class":3169,"line":3439},[3167,6584,3174],{"class":3173},[3167,6586,3178],{"class":3177},[3167,6588,3742],{"class":3603},[3167,6590,3917],{"class":3603},[3167,6592,3920],{"class":3177},[3167,6594,4004],{"class":3603},[3167,6596,6597],{"class":3177}," ~/docker-test:/usr/share/nginx/html:ro",[3167,6599,3834],{"class":3603},[3167,6601,6602],{"class":3177}," my-web",[3167,6604,3745],{"class":3177},[3114,6606,6607,6608,6610],{},"Відкрийте ",[3121,6609,3934],{}," у браузері.",[3114,6612,6613],{},[3225,6614,6615],{},"Завдання:",[3242,6617,6618,6621,6624],{},[3245,6619,6620],{},"Змініть HTML-файл на хості та оновіть сторінку в браузері",[3245,6622,6623],{},"Додайте CSS-файл та підключіть його до HTML",[3245,6625,6626],{},"Налаштуйте Nginx на інший порт (наприклад, 3000)",[3153,6628,6630],{"id":6629},"завдання-3-дослідження-життєвого-циклу","Завдання 3: Дослідження життєвого циклу",[3114,6632,6633],{},"Виконайте наступну послідовність команд та спостерігайте за змінами:",[3158,6635,6637],{"className":3160,"code":6636,"language":3162,"meta":3163,"style":3163},"# 1. Запуск контейнера\ndocker run -d --name lifecycle-test nginx\n\n# 2. Перевірка статусу\ndocker ps\n\n# 3. Зупинка\ndocker stop lifecycle-test\n\n# 4. Перевірка (контейнер зупинено)\ndocker ps -a\n\n# 5. Інспекція контейнера\ndocker inspect lifecycle-test | grep Status\n\n# 6. Перезапуск\ndocker start lifecycle-test\n\n# 7. Перегляд логів\ndocker logs lifecycle-test\n\n# 8. Видалення (спочатку зупиніть)\ndocker stop lifecycle-test\ndocker rm lifecycle-test\n",[3121,6638,6639,6644,6659,6663,6667,6673,6677,6682,6691,6695,6700,6708,6712,6717,6735,6739,6743,6751,6755,6760,6768,6772,6777,6785],{"__ignoreMap":3163},[3167,6640,6641],{"class":3169,"line":3170},[3167,6642,6643],{"class":3576},"# 1. Запуск контейнера\n",[3167,6645,6646,6648,6650,6652,6654,6657],{"class":3169,"line":3361},[3167,6647,3174],{"class":3173},[3167,6649,3178],{"class":3177},[3167,6651,3742],{"class":3603},[3167,6653,3834],{"class":3603},[3167,6655,6656],{"class":3177}," lifecycle-test",[3167,6658,3745],{"class":3177},[3167,6660,6661],{"class":3169,"line":3367},[3167,6662,3377],{"emptyLinePlaceholder":3376},[3167,6664,6665],{"class":3169,"line":3373},[3167,6666,5122],{"class":3576},[3167,6668,6669,6671],{"class":3169,"line":3380},[3167,6670,3174],{"class":3173},[3167,6672,4582],{"class":3177},[3167,6674,6675],{"class":3169,"line":3386},[3167,6676,3377],{"emptyLinePlaceholder":3376},[3167,6678,6679],{"class":3169,"line":3392},[3167,6680,6681],{"class":3576},"# 3. Зупинка\n",[3167,6683,6684,6686,6688],{"class":3169,"line":3398},[3167,6685,3174],{"class":3173},[3167,6687,3856],{"class":3177},[3167,6689,6690],{"class":3177}," lifecycle-test\n",[3167,6692,6693],{"class":3169,"line":3404},[3167,6694,3377],{"emptyLinePlaceholder":3376},[3167,6696,6697],{"class":3169,"line":3410},[3167,6698,6699],{"class":3576},"# 4. Перевірка (контейнер зупинено)\n",[3167,6701,6702,6704,6706],{"class":3169,"line":3415},[3167,6703,3174],{"class":3173},[3167,6705,3600],{"class":3177},[3167,6707,3604],{"class":3603},[3167,6709,6710],{"class":3169,"line":3421},[3167,6711,3377],{"emptyLinePlaceholder":3376},[3167,6713,6714],{"class":3169,"line":3427},[3167,6715,6716],{"class":3576},"# 5. Інспекція контейнера\n",[3167,6718,6719,6721,6724,6726,6729,6732],{"class":3169,"line":3433},[3167,6720,3174],{"class":3173},[3167,6722,6723],{"class":3177}," inspect",[3167,6725,6656],{"class":3177},[3167,6727,6728],{"class":3652}," | ",[3167,6730,6731],{"class":3173},"grep",[3167,6733,6734],{"class":3177}," Status\n",[3167,6736,6737],{"class":3169,"line":3439},[3167,6738,3377],{"emptyLinePlaceholder":3376},[3167,6740,6741],{"class":3169,"line":3445},[3167,6742,5189],{"class":3576},[3167,6744,6745,6747,6749],{"class":3169,"line":3451},[3167,6746,3174],{"class":3173},[3167,6748,4337],{"class":3177},[3167,6750,6690],{"class":3177},[3167,6752,6753],{"class":3169,"line":3457},[3167,6754,3377],{"emptyLinePlaceholder":3376},[3167,6756,6757],{"class":3169,"line":3463},[3167,6758,6759],{"class":3576},"# 7. Перегляд логів\n",[3167,6761,6762,6764,6766],{"class":3169,"line":3469},[3167,6763,3174],{"class":3173},[3167,6765,3866],{"class":3177},[3167,6767,6690],{"class":3177},[3167,6769,6770],{"class":3169,"line":3475},[3167,6771,3377],{"emptyLinePlaceholder":3376},[3167,6773,6774],{"class":3169,"line":3481},[3167,6775,6776],{"class":3576},"# 8. Видалення (спочатку зупиніть)\n",[3167,6778,6779,6781,6783],{"class":3169,"line":3487},[3167,6780,3174],{"class":3173},[3167,6782,3856],{"class":3177},[3167,6784,6690],{"class":3177},[3167,6786,6787,6789,6791],{"class":3169,"line":3493},[3167,6788,3174],{"class":3173},[3167,6790,5006],{"class":3177},[3167,6792,6690],{"class":3177},[3114,6794,6795],{},[3225,6796,6476],{},[3242,6798,6799,6802,6808],{},[3245,6800,6801],{},"Скільки часу займає зупинка контейнера?",[3245,6803,6804,6805,6807],{},"Чи змінюється ID контейнера після ",[3121,6806,4961],{},"?",[3245,6809,6810,6811,6807],{},"Що показує ",[3121,6812,6813],{},"docker inspect",[3153,6815,6817],{"id":6816},"завдання-4-net-застосунок-з-аргументами","Завдання 4: .NET застосунок з аргументами",[3114,6819,6820],{},"Створіть C# застосунок, який приймає аргументи командного рядка:",[3158,6822,6824],{"className":3160,"code":6823,"language":3162,"meta":3163,"style":3163},"# Створення проєкту\nmkdir -p ~/dotnet-docker-test\ncd ~/dotnet-docker-test\n\n# Створення Program.cs\ncat > Program.cs \u003C\u003C 'EOF'\nif (args.Length == 0)\n{\n    Console.WriteLine(\"No arguments provided!\");\n    return;\n}\n\nConsole.WriteLine($\"Received {args.Length} arguments:\");\nfor (int i = 0; i \u003C args.Length; i++)\n{\n    Console.WriteLine($\"  [{i}]: {args[i]}\");\n}\nEOF\n\n# Запуск у контейнері з аргументами\ndocker run --rm -v $(pwd):/app -w /app mcr.microsoft.com/dotnet/sdk:8.0 \\\n  dotnet run -- arg1 arg2 \"argument with spaces\"\n",[3121,6825,6826,6831,6840,6846,6850,6855,6867,6872,6877,6882,6887,6891,6895,6900,6905,6909,6914,6918,6922,6926,6931,6959],{"__ignoreMap":3163},[3167,6827,6828],{"class":3169,"line":3170},[3167,6829,6830],{"class":3576},"# Створення проєкту\n",[3167,6832,6833,6835,6837],{"class":3169,"line":3361},[3167,6834,6509],{"class":3173},[3167,6836,3917],{"class":3603},[3167,6838,6839],{"class":3177}," ~/dotnet-docker-test\n",[3167,6841,6842,6844],{"class":3169,"line":3367},[3167,6843,5703],{"class":3173},[3167,6845,6839],{"class":3177},[3167,6847,6848],{"class":3169,"line":3373},[3167,6849,3377],{"emptyLinePlaceholder":3376},[3167,6851,6852],{"class":3169,"line":3380},[3167,6853,6854],{"class":3576},"# Створення Program.cs\n",[3167,6856,6857,6859,6861,6863,6865],{"class":3169,"line":3386},[3167,6858,4097],{"class":3173},[3167,6860,4185],{"class":3652},[3167,6862,5723],{"class":3177},[3167,6864,5726],{"class":3652},[3167,6866,5729],{"class":3652},[3167,6868,6869],{"class":3169,"line":3392},[3167,6870,6871],{"class":3177},"if (args.Length == 0)\n",[3167,6873,6874],{"class":3169,"line":3398},[3167,6875,6876],{"class":3177},"{\n",[3167,6878,6879],{"class":3169,"line":3404},[3167,6880,6881],{"class":3177},"    Console.WriteLine(\"No arguments provided!\");\n",[3167,6883,6884],{"class":3169,"line":3410},[3167,6885,6886],{"class":3177},"    return;\n",[3167,6888,6889],{"class":3169,"line":3415},[3167,6890,4543],{"class":3177},[3167,6892,6893],{"class":3169,"line":3421},[3167,6894,3377],{"emptyLinePlaceholder":3376},[3167,6896,6897],{"class":3169,"line":3427},[3167,6898,6899],{"class":3177},"Console.WriteLine($\"Received {args.Length} arguments:\");\n",[3167,6901,6902],{"class":3169,"line":3433},[3167,6903,6904],{"class":3177},"for (int i = 0; i \u003C args.Length; i++)\n",[3167,6906,6907],{"class":3169,"line":3439},[3167,6908,6876],{"class":3177},[3167,6910,6911],{"class":3169,"line":3445},[3167,6912,6913],{"class":3177},"    Console.WriteLine($\"  [{i}]: {args[i]}\");\n",[3167,6915,6916],{"class":3169,"line":3451},[3167,6917,4543],{"class":3177},[3167,6919,6920],{"class":3169,"line":3457},[3167,6921,5754],{"class":3652},[3167,6923,6924],{"class":3169,"line":3463},[3167,6925,3377],{"emptyLinePlaceholder":3376},[3167,6927,6928],{"class":3169,"line":3469},[3167,6929,6930],{"class":3576},"# Запуск у контейнері з аргументами\n",[3167,6932,6933,6935,6937,6939,6941,6943,6945,6947,6949,6951,6953,6955],{"class":3169,"line":3475},[3167,6934,3174],{"class":3173},[3167,6936,3178],{"class":3177},[3167,6938,3889],{"class":3603},[3167,6940,4004],{"class":3603},[3167,6942,5619],{"class":3652},[3167,6944,5622],{"class":3173},[3167,6946,3680],{"class":3652},[3167,6948,5627],{"class":3177},[3167,6950,5630],{"class":3603},[3167,6952,5633],{"class":3177},[3167,6954,5297],{"class":3177},[3167,6956,6958],{"class":6957},"sjcCO"," \\\n",[3167,6960,6961,6964,6966,6969,6972,6975],{"class":3169,"line":3481},[3167,6962,6963],{"class":3177},"  dotnet",[3167,6965,3178],{"class":3177},[3167,6967,6968],{"class":3603}," --",[3167,6970,6971],{"class":3177}," arg1",[3167,6973,6974],{"class":3177}," arg2",[3167,6976,6977],{"class":3177}," \"argument with spaces\"\n",[3114,6979,6980],{},[3225,6981,6615],{},[3242,6983,6984,6987,6993],{},[3245,6985,6986],{},"Передайте різні аргументи та перевірте вивід",[3245,6988,6989,6990,3680],{},"Додайте обробку прапорців (наприклад, ",[3121,6991,6992],{},"--verbose",[3245,6994,6995,6996],{},"Зчитайте змінні оточення через ",[3121,6997,6998],{},"Environment.GetEnvironmentVariable()",[3132,7000,7001],{},"Ці завдання допоможуть вам освоїти базові операції з контейнерами та підготують до більш складних сценаріїв у наступних статтях.",[7003,7004,7005],"style",{},"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 .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 .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .sjcCO, html code.shiki .sjcCO{--shiki-light:#EE0000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}",{"title":3163,"searchDepth":3361,"depth":3361,"links":7007},[7008,7009,7018,7022,7028,7034,7043,7048,7055,7056],{"id":3111,"depth":3361,"text":3112},{"id":3143,"depth":3361,"text":3144,"children":7010},[7011,7012,7013,7014,7015,7016,7017],{"id":3155,"depth":3367,"text":3156},{"id":3187,"depth":3367,"text":3188},{"id":3219,"depth":3367,"text":3220},{"id":3290,"depth":3367,"text":3291},{"id":3314,"depth":3367,"text":3315},{"id":3330,"depth":3367,"text":3331},{"id":3547,"depth":3367,"text":3548},{"id":3627,"depth":3361,"text":3628,"children":7019},[7020,7021],{"id":3637,"depth":3367,"text":3638},{"id":3713,"depth":3367,"text":3714},{"id":4017,"depth":3361,"text":4018,"children":7023},[7024,7025,7026,7027],{"id":4024,"depth":3367,"text":4025},{"id":4078,"depth":3367,"text":4079},{"id":4257,"depth":3367,"text":4258},{"id":4295,"depth":3367,"text":4296},{"id":4362,"depth":3361,"text":4363,"children":7029},[7030,7031,7032,7033],{"id":4369,"depth":3367,"text":4370},{"id":4426,"depth":3367,"text":4427},{"id":4569,"depth":3367,"text":4570},{"id":4645,"depth":3367,"text":4646},{"id":4776,"depth":3361,"text":4777,"children":7035},[7036,7037,7038,7039,7040,7041,7042],{"id":4783,"depth":3367,"text":4784},{"id":4856,"depth":3367,"text":4857},{"id":4912,"depth":3367,"text":4913},{"id":4936,"depth":3367,"text":4937},{"id":4965,"depth":3367,"text":4966},{"id":4988,"depth":3367,"text":4989},{"id":5080,"depth":3367,"text":5081},{"id":5270,"depth":3361,"text":5271,"children":7044},[7045,7046,7047],{"id":5277,"depth":3367,"text":5278},{"id":5338,"depth":3367,"text":5339},{"id":5590,"depth":3367,"text":5591},{"id":5793,"depth":3361,"text":5794,"children":7049},[7050,7051,7052,7053,7054],{"id":5802,"depth":3367,"text":5803},{"id":5888,"depth":3367,"text":5889},{"id":5980,"depth":3367,"text":5981},{"id":6059,"depth":3367,"text":6060},{"id":6131,"depth":3367,"text":6132},{"id":6224,"depth":3361,"text":6225},{"id":6358,"depth":3361,"text":6359,"children":7057},[7058,7059,7060,7061],{"id":6362,"depth":3367,"text":6363},{"id":6490,"depth":3367,"text":6491},{"id":6629,"depth":3367,"text":6630},{"id":6816,"depth":3367,"text":6817},"Практичне знайомство з запуском контейнерів, детальний розбір команди docker run та основні операції з контейнерами","md",null,{},{"title":2683,"description":7062},"tbOZC5kQ2XeuNOPymet1WiRo2cmEFxfioJdFNU5_2so",[7069,7071],{"title":2679,"path":2680,"stem":2681,"description":7070,"children":-1},"Покрокова інструкція встановлення Docker Engine на Linux, macOS та Windows з налаштуванням та перевіркою",{"title":2687,"path":2688,"stem":2689,"description":7072,"children":-1},"Глибоке розуміння станів контейнера, процесів всередині, діагностичних команд та управління життєвим циклом",1778489427520]