[{"data":1,"prerenderedAt":9614},["ShallowReactive",2],{"navigation_docs":3,"-tools-docker-volumes-and-data":3099,"-tools-docker-volumes-and-data-surround":9609},[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":2715,"body":3101,"description":9603,"extension":9604,"links":9605,"meta":9606,"navigation":3406,"path":2716,"seo":9607,"stem":2717,"__hash__":9608},"docs/07.tools/01.docker/13.volumes-and-data.md",{"type":3102,"value":3103,"toc":9553},"minimark",[3104,3108,3113,3122,3129,3148,3152,3155,3159,3164,3175,3300,3305,3327,3337,3341,3346,3494,3499,3604,3610,3614,3619,3628,3633,3644,3651,3653,3657,3660,3664,3669,3674,3698,3703,3717,3722,3794,3798,3803,3807,3827,3831,3845,3849,3901,3905,3910,3914,3934,3938,3952,3956,3999,4003,4125,4277,4305,4307,4311,4315,4320,4336,4341,4484,4488,4555,4564,4667,4672,4692,4696,4701,4710,4730,4734,4855,4863,4882,4886,5008,5035,5039,5044,5059,5064,5126,5131,5311,5316,5338,5343,5395,5400,5458,5464,5468,5471,5476,5588,5593,5611,5617,5621,5680,5686,5723,5727,5732,5818,5823,5855,5860,5944,5948,5951,5956,5959,5980,5985,5988,6040,6045,6048,6095,6100,6120,6127,6131,6136,6154,6168,6173,6191,6205,6211,6213,6217,6221,6227,6231,6276,6280,6285,6380,6385,6481,6486,6533,6537,6540,6545,6649,6654,6718,6723,6741,6746,6754,6758,6763,6839,6845,6850,6950,6955,7028,7033,7091,7095,7207,7231,7233,7237,7241,7246,7250,7266,7270,7315,7318,7323,7363,7368,7412,7417,7461,7466,7502,7506,7511,7576,7581,7634,7639,7650,7654,7659,7708,7713,7737,7739,7743,7747,7752,7931,7936,8043,8047,8065,8069,8080,8084,8089,8095,8100,8223,8228,8476,8480,8500,8504,8529,8533,8539,8543,8547,9048,9053,9089,9091,9095,9099,9105,9110,9133,9139,9143,9148,9152,9175,9180,9184,9189,9193,9213,9218,9222,9227,9231,9248,9253,9255,9259,9262,9267,9278,9283,9318,9323,9344,9349,9366,9371,9415,9420,9450,9455,9521,9549],[3105,3106,2715],"h1",{"id":3107},"томи-та-збереження-даних",[3109,3110,3112],"h2",{"id":3111},"проблема-зникаючих-даних","Проблема зникаючих даних",[3114,3115,3116,3117,3121],"p",{},"Уявіть ситуацію: ви запустили контейнер з PostgreSQL, створили базу даних, додали таблиці, заповнили їх даними. Все працює ідеально. Але потім ви зупиняєте контейнер для оновлення або перезапуску сервера, і... ",[3118,3119,3120],"strong",{},"всі дані зникли",". База даних порожня, таблиці відсутні, роботу потрібно починати спочатку.",[3114,3123,3124,3125,3128],{},"Це не баг — це фундаментальна особливість Docker. Контейнери за своєю природою ",[3118,3126,3127],{},"ефемерні"," (ephemeral) — тимчасові та одноразові. Коли контейнер видаляється, всі зміни, зроблені всередині нього, теж видаляються. Це чудово для stateless додатків (Web API без локального стану), але катастрофічно для stateful додатків (бази даних, файлові сховища, черги повідомлень).",[3114,3130,3131,3132,3135,3136,3139,3140,3143,3144,3147],{},"Саме для вирішення цієї проблеми Docker надає механізми ",[3118,3133,3134],{},"persistent storage"," — збереження даних поза життєвим циклом контейнера. У цій статті ми детально розглянемо три типи storage в Docker: ",[3118,3137,3138],{},"Volumes"," (керовані Docker томи), ",[3118,3141,3142],{},"Bind Mounts"," (монтування директорій хоста) та ",[3118,3145,3146],{},"tmpfs"," (тимчасове сховище в пам'яті). Ви навчитеся зберігати дані PostgreSQL, організовувати hot-reload для .NET додатків під час розробки, та застосовувати найкращі практики роботи з даними в контейнерах.",[3149,3150,3151],"note",{},"Ця стаття передбачає розуміння базових концепцій Docker (образи, контейнери, шари) з попередніх статей. Тут ми зосередимося на збереженні даних та управлінні storage.",[3153,3154],"hr",{},[3109,3156,3158],{"id":3157},"проблема-ефемерності-контейнерів","Проблема ефемерності контейнерів",[3160,3161,3163],"h3",{"id":3162},"архітектура-шарів-read-only-vs-read-write","Архітектура шарів: read-only vs read-write",[3114,3165,3166,3167,3170,3171,3174],{},"Пригадаємо архітектуру Docker-образу з попередніх статей. Образ складається з ",[3118,3168,3169],{},"незмінних (immutable) read-only шарів",". Коли ви запускаєте контейнер, Docker додає зверху ",[3118,3172,3173],{},"тонкий writable шар"," (container layer), куди записуються всі зміни.",[3176,3177,3178],"mermaid",{},[3179,3180,3184],"pre",{"className":3181,"code":3182,"language":3176,"meta":3183,"style":3183},"language-mermaid shiki shiki-themes light-plus dark-plus dark-plus","graph TB\n    subgraph Container\n        CL[Container Layer - Read/Write\u003Cbr/>Зміни файлів, нові файли, логи]\n    end\n    \n    subgraph Image\n        L3[Layer 3 - Read Only\u003Cbr/>Додаток]\n        L2[Layer 2 - Read Only\u003Cbr/>Залежності]\n        L1[Layer 1 - Read Only\u003Cbr/>Базовий образ]\n    end\n    \n    CL --> L3\n    L3 --> L2\n    L2 --> L1\n    \n    style CL fill:#f59e0b,stroke:#b45309,color:#ffffff\n    style L3 fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n    style L2 fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n    style L1 fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n","",[3185,3186,3187,3195,3201,3207,3213,3219,3225,3231,3237,3243,3248,3253,3259,3265,3271,3276,3282,3288,3294],"code",{"__ignoreMap":3183},[3188,3189,3192],"span",{"class":3190,"line":3191},"line",1,[3188,3193,3194],{},"graph TB\n",[3188,3196,3198],{"class":3190,"line":3197},2,[3188,3199,3200],{},"    subgraph Container\n",[3188,3202,3204],{"class":3190,"line":3203},3,[3188,3205,3206],{},"        CL[Container Layer - Read/Write\u003Cbr/>Зміни файлів, нові файли, логи]\n",[3188,3208,3210],{"class":3190,"line":3209},4,[3188,3211,3212],{},"    end\n",[3188,3214,3216],{"class":3190,"line":3215},5,[3188,3217,3218],{},"    \n",[3188,3220,3222],{"class":3190,"line":3221},6,[3188,3223,3224],{},"    subgraph Image\n",[3188,3226,3228],{"class":3190,"line":3227},7,[3188,3229,3230],{},"        L3[Layer 3 - Read Only\u003Cbr/>Додаток]\n",[3188,3232,3234],{"class":3190,"line":3233},8,[3188,3235,3236],{},"        L2[Layer 2 - Read Only\u003Cbr/>Залежності]\n",[3188,3238,3240],{"class":3190,"line":3239},9,[3188,3241,3242],{},"        L1[Layer 1 - Read Only\u003Cbr/>Базовий образ]\n",[3188,3244,3246],{"class":3190,"line":3245},10,[3188,3247,3212],{},[3188,3249,3251],{"class":3190,"line":3250},11,[3188,3252,3218],{},[3188,3254,3256],{"class":3190,"line":3255},12,[3188,3257,3258],{},"    CL --> L3\n",[3188,3260,3262],{"class":3190,"line":3261},13,[3188,3263,3264],{},"    L3 --> L2\n",[3188,3266,3268],{"class":3190,"line":3267},14,[3188,3269,3270],{},"    L2 --> L1\n",[3188,3272,3274],{"class":3190,"line":3273},15,[3188,3275,3218],{},[3188,3277,3279],{"class":3190,"line":3278},16,[3188,3280,3281],{},"    style CL fill:#f59e0b,stroke:#b45309,color:#ffffff\n",[3188,3283,3285],{"class":3190,"line":3284},17,[3188,3286,3287],{},"    style L3 fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n",[3188,3289,3291],{"class":3190,"line":3290},18,[3188,3292,3293],{},"    style L2 fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n",[3188,3295,3297],{"class":3190,"line":3296},19,[3188,3298,3299],{},"    style L1 fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n",[3114,3301,3302],{},[3118,3303,3304],{},"Що відбувається з даними:",[3306,3307,3308,3315,3321],"ol",{},[3309,3310,3311,3314],"li",{},[3118,3312,3313],{},"Створення файлу:"," Файл записується у container layer",[3309,3316,3317,3320],{},[3118,3318,3319],{},"Зміна файлу з образу:"," Docker копіює файл з read-only шару в container layer (Copy-on-Write), змінює копію",[3309,3322,3323,3326],{},[3118,3324,3325],{},"Видалення файлу з образу:"," Docker позначає файл як видалений у container layer (whiteout file)",[3114,3328,3329,3332,3333,3336],{},[3118,3330,3331],{},"Проблема:"," Container layer існує лише поки існує контейнер. При видаленні контейнера (",[3185,3334,3335],{},"docker rm",") цей шар теж видаляється.",[3160,3338,3340],{"id":3339},"демонстрація-проблеми","Демонстрація проблеми",[3114,3342,3343],{},[3118,3344,3345],{},"Приклад: PostgreSQL без persistent storage",[3179,3347,3351],{"className":3348,"code":3349,"language":3350,"meta":3183,"style":3183},"language-bash shiki shiki-themes light-plus dark-plus dark-plus","# Запустити PostgreSQL\ndocker run -d \\\n  --name postgres-temp \\\n  -e POSTGRES_PASSWORD=mysecret \\\n  postgres:16\n\n# Дочекатися запуску (5-10 секунд)\ndocker logs postgres-temp\n\n# Підключитися та створити базу даних\ndocker exec -it postgres-temp psql -U postgres -c \"CREATE DATABASE myapp;\"\ndocker exec -it postgres-temp psql -U postgres -c \"\\l\"\n\n# Вивід:\n#   myapp    | postgres | UTF8 | ...\n","bash",[3185,3352,3353,3359,3377,3387,3397,3402,3408,3413,3423,3427,3432,3459,3480,3484,3489],{"__ignoreMap":3183},[3188,3354,3355],{"class":3190,"line":3191},[3188,3356,3358],{"class":3357},"spJ8K","# Запустити PostgreSQL\n",[3188,3360,3361,3365,3369,3373],{"class":3190,"line":3197},[3188,3362,3364],{"class":3363},"s8Opu","docker",[3188,3366,3368],{"class":3367},"sbdoH"," run",[3188,3370,3372],{"class":3371},"su1O8"," -d",[3188,3374,3376],{"class":3375},"sjcCO"," \\\n",[3188,3378,3379,3382,3385],{"class":3190,"line":3203},[3188,3380,3381],{"class":3371},"  --name",[3188,3383,3384],{"class":3367}," postgres-temp",[3188,3386,3376],{"class":3375},[3188,3388,3389,3392,3395],{"class":3190,"line":3209},[3188,3390,3391],{"class":3371},"  -e",[3188,3393,3394],{"class":3367}," POSTGRES_PASSWORD=mysecret",[3188,3396,3376],{"class":3375},[3188,3398,3399],{"class":3190,"line":3215},[3188,3400,3401],{"class":3367},"  postgres:16\n",[3188,3403,3404],{"class":3190,"line":3221},[3188,3405,3407],{"emptyLinePlaceholder":3406},true,"\n",[3188,3409,3410],{"class":3190,"line":3227},[3188,3411,3412],{"class":3357},"# Дочекатися запуску (5-10 секунд)\n",[3188,3414,3415,3417,3420],{"class":3190,"line":3233},[3188,3416,3364],{"class":3363},[3188,3418,3419],{"class":3367}," logs",[3188,3421,3422],{"class":3367}," postgres-temp\n",[3188,3424,3425],{"class":3190,"line":3239},[3188,3426,3407],{"emptyLinePlaceholder":3406},[3188,3428,3429],{"class":3190,"line":3245},[3188,3430,3431],{"class":3357},"# Підключитися та створити базу даних\n",[3188,3433,3434,3436,3439,3442,3444,3447,3450,3453,3456],{"class":3190,"line":3250},[3188,3435,3364],{"class":3363},[3188,3437,3438],{"class":3367}," exec",[3188,3440,3441],{"class":3371}," -it",[3188,3443,3384],{"class":3367},[3188,3445,3446],{"class":3367}," psql",[3188,3448,3449],{"class":3371}," -U",[3188,3451,3452],{"class":3367}," postgres",[3188,3454,3455],{"class":3371}," -c",[3188,3457,3458],{"class":3367}," \"CREATE DATABASE myapp;\"\n",[3188,3460,3461,3463,3465,3467,3469,3471,3473,3475,3477],{"class":3190,"line":3255},[3188,3462,3364],{"class":3363},[3188,3464,3438],{"class":3367},[3188,3466,3441],{"class":3371},[3188,3468,3384],{"class":3367},[3188,3470,3446],{"class":3367},[3188,3472,3449],{"class":3371},[3188,3474,3452],{"class":3367},[3188,3476,3455],{"class":3371},[3188,3478,3479],{"class":3367}," \"\\l\"\n",[3188,3481,3482],{"class":3190,"line":3261},[3188,3483,3407],{"emptyLinePlaceholder":3406},[3188,3485,3486],{"class":3190,"line":3267},[3188,3487,3488],{"class":3357},"# Вивід:\n",[3188,3490,3491],{"class":3190,"line":3273},[3188,3492,3493],{"class":3357},"#   myapp    | postgres | UTF8 | ...\n",[3114,3495,3496],{},[3118,3497,3498],{},"Тепер видалимо контейнер:",[3179,3500,3502],{"className":3348,"code":3501,"language":3350,"meta":3183,"style":3183},"# Зупинити та видалити контейнер\ndocker stop postgres-temp\ndocker rm postgres-temp\n\n# Запустити знову\ndocker run -d \\\n  --name postgres-temp \\\n  -e POSTGRES_PASSWORD=mysecret \\\n  postgres:16\n\n# Перевірити бази даних\ndocker exec -it postgres-temp psql -U postgres -c \"\\l\"\n\n# Вивід: база даних myapp відсутня!\n",[3185,3503,3504,3509,3518,3527,3531,3536,3546,3554,3562,3566,3570,3575,3595,3599],{"__ignoreMap":3183},[3188,3505,3506],{"class":3190,"line":3191},[3188,3507,3508],{"class":3357},"# Зупинити та видалити контейнер\n",[3188,3510,3511,3513,3516],{"class":3190,"line":3197},[3188,3512,3364],{"class":3363},[3188,3514,3515],{"class":3367}," stop",[3188,3517,3422],{"class":3367},[3188,3519,3520,3522,3525],{"class":3190,"line":3203},[3188,3521,3364],{"class":3363},[3188,3523,3524],{"class":3367}," rm",[3188,3526,3422],{"class":3367},[3188,3528,3529],{"class":3190,"line":3209},[3188,3530,3407],{"emptyLinePlaceholder":3406},[3188,3532,3533],{"class":3190,"line":3215},[3188,3534,3535],{"class":3357},"# Запустити знову\n",[3188,3537,3538,3540,3542,3544],{"class":3190,"line":3221},[3188,3539,3364],{"class":3363},[3188,3541,3368],{"class":3367},[3188,3543,3372],{"class":3371},[3188,3545,3376],{"class":3375},[3188,3547,3548,3550,3552],{"class":3190,"line":3227},[3188,3549,3381],{"class":3371},[3188,3551,3384],{"class":3367},[3188,3553,3376],{"class":3375},[3188,3555,3556,3558,3560],{"class":3190,"line":3233},[3188,3557,3391],{"class":3371},[3188,3559,3394],{"class":3367},[3188,3561,3376],{"class":3375},[3188,3563,3564],{"class":3190,"line":3239},[3188,3565,3401],{"class":3367},[3188,3567,3568],{"class":3190,"line":3245},[3188,3569,3407],{"emptyLinePlaceholder":3406},[3188,3571,3572],{"class":3190,"line":3250},[3188,3573,3574],{"class":3357},"# Перевірити бази даних\n",[3188,3576,3577,3579,3581,3583,3585,3587,3589,3591,3593],{"class":3190,"line":3255},[3188,3578,3364],{"class":3363},[3188,3580,3438],{"class":3367},[3188,3582,3441],{"class":3371},[3188,3584,3384],{"class":3367},[3188,3586,3446],{"class":3367},[3188,3588,3449],{"class":3371},[3188,3590,3452],{"class":3367},[3188,3592,3455],{"class":3371},[3188,3594,3479],{"class":3367},[3188,3596,3597],{"class":3190,"line":3261},[3188,3598,3407],{"emptyLinePlaceholder":3406},[3188,3600,3601],{"class":3190,"line":3267},[3188,3602,3603],{"class":3357},"# Вивід: база даних myapp відсутня!\n",[3114,3605,3606,3609],{},[3118,3607,3608],{},"База даних зникла",", бо вона зберігалася у container layer, який був видалений разом з контейнером.",[3160,3611,3613],{"id":3612},"наслідки-ефемерності","Наслідки ефемерності",[3114,3615,3616],{},[3118,3617,3618],{},"Для stateless додатків (Web API):",[3620,3621,3622,3625],"ul",{},[3309,3623,3624],{},"✅ Ефемерність — це перевага (легко масштабувати, замінювати)",[3309,3626,3627],{},"✅ Немає проблем з даними (стан зберігається в БД або зовнішньому сховищі)",[3114,3629,3630],{},[3118,3631,3632],{},"Для stateful додатків (БД, файлові сховища):",[3620,3634,3635,3638,3641],{},[3309,3636,3637],{},"❌ Втрата даних при видаленні контейнера",[3309,3639,3640],{},"❌ Неможливість оновлення без downtime",[3309,3642,3643],{},"❌ Складність backup та відновлення",[3645,3646,3647,3650],"warning",{},[3118,3648,3649],{},"Ніколи не зберігайте критичні дані всередині контейнера без persistent storage!"," Контейнери можуть бути видалені випадково, через помилку, або автоматично (наприклад, Kubernetes перезапускає pods). Завжди використовуйте volumes для stateful додатків.",[3153,3652],{},[3109,3654,3656],{"id":3655},"три-типи-storage-в-docker","Три типи storage в Docker",[3114,3658,3659],{},"Docker надає три механізми для збереження даних поза контейнером:",[3160,3661,3663],{"id":3662},"_1-volumes-томи","1. Volumes (Томи)",[3114,3665,3666,3668],{},[3118,3667,3138],{}," — це керовані Docker сховища даних, які існують незалежно від життєвого циклу контейнера.",[3114,3670,3671],{},[3118,3672,3673],{},"Характеристики:",[3620,3675,3676,3679,3686,3689,3692,3695],{},[3309,3677,3678],{},"✅ Керуються Docker (створення, видалення, backup)",[3309,3680,3681,3682,3685],{},"✅ Зберігаються на хості в спеціальній директорії (",[3185,3683,3684],{},"/var/lib/docker/volumes/",")",[3309,3687,3688],{},"✅ Можуть бути спільними для кількох контейнерів",[3309,3690,3691],{},"✅ Працюють на всіх платформах (Linux, macOS, Windows)",[3309,3693,3694],{},"✅ Підтримують volume drivers (local, NFS, cloud storage)",[3309,3696,3697],{},"✅ Ізольовані від хост-системи (безпека)",[3114,3699,3700],{},[3118,3701,3702],{},"Коли використовувати:",[3620,3704,3705,3708,3711,3714],{},[3309,3706,3707],{},"Бази даних (PostgreSQL, MySQL, MongoDB)",[3309,3709,3710],{},"Persistent storage для додатків",[3309,3712,3713],{},"Спільні дані між контейнерами",[3309,3715,3716],{},"Production середовище",[3114,3718,3719],{},[3118,3720,3721],{},"Приклад:",[3179,3723,3725],{"className":3348,"code":3724,"language":3350,"meta":3183,"style":3183},"# Створити volume\ndocker volume create postgres-data\n\n# Запустити контейнер з volume\ndocker run -d \\\n  --name postgres \\\n  -v postgres-data:/var/lib/postgresql/data \\\n  -e POSTGRES_PASSWORD=mysecret \\\n  postgres:16\n",[3185,3726,3727,3732,3745,3749,3754,3764,3772,3782,3790],{"__ignoreMap":3183},[3188,3728,3729],{"class":3190,"line":3191},[3188,3730,3731],{"class":3357},"# Створити volume\n",[3188,3733,3734,3736,3739,3742],{"class":3190,"line":3197},[3188,3735,3364],{"class":3363},[3188,3737,3738],{"class":3367}," volume",[3188,3740,3741],{"class":3367}," create",[3188,3743,3744],{"class":3367}," postgres-data\n",[3188,3746,3747],{"class":3190,"line":3203},[3188,3748,3407],{"emptyLinePlaceholder":3406},[3188,3750,3751],{"class":3190,"line":3209},[3188,3752,3753],{"class":3357},"# Запустити контейнер з volume\n",[3188,3755,3756,3758,3760,3762],{"class":3190,"line":3215},[3188,3757,3364],{"class":3363},[3188,3759,3368],{"class":3367},[3188,3761,3372],{"class":3371},[3188,3763,3376],{"class":3375},[3188,3765,3766,3768,3770],{"class":3190,"line":3221},[3188,3767,3381],{"class":3371},[3188,3769,3452],{"class":3367},[3188,3771,3376],{"class":3375},[3188,3773,3774,3777,3780],{"class":3190,"line":3227},[3188,3775,3776],{"class":3371},"  -v",[3188,3778,3779],{"class":3367}," postgres-data:/var/lib/postgresql/data",[3188,3781,3376],{"class":3375},[3188,3783,3784,3786,3788],{"class":3190,"line":3233},[3188,3785,3391],{"class":3371},[3188,3787,3394],{"class":3367},[3188,3789,3376],{"class":3375},[3188,3791,3792],{"class":3190,"line":3239},[3188,3793,3401],{"class":3367},[3160,3795,3797],{"id":3796},"_2-bind-mounts-монтування-директорій-хоста","2. Bind Mounts (Монтування директорій хоста)",[3114,3799,3800,3802],{},[3118,3801,3142],{}," — це пряме монтування директорії або файлу з хост-системи в контейнер.",[3114,3804,3805],{},[3118,3806,3673],{},[3620,3808,3809,3812,3815,3818,3821,3824],{},[3309,3810,3811],{},"✅ Прямий доступ до файлів хоста",[3309,3813,3814],{},"✅ Зміни видимі одразу (hot-reload)",[3309,3816,3817],{},"✅ Повний контроль над розташуванням файлів",[3309,3819,3820],{},"⚠️ Залежність від структури хост-системи",[3309,3822,3823],{},"⚠️ Потенційні проблеми з правами доступу",[3309,3825,3826],{},"⚠️ Менша ізоляція (безпека)",[3114,3828,3829],{},[3118,3830,3702],{},[3620,3832,3833,3836,3839,3842],{},[3309,3834,3835],{},"Розробка (hot-reload коду)",[3309,3837,3838],{},"Конфігураційні файли",[3309,3840,3841],{},"Логи для аналізу на хості",[3309,3843,3844],{},"Спільні файли між хостом та контейнером",[3114,3846,3847],{},[3118,3848,3721],{},[3179,3850,3852],{"className":3348,"code":3851,"language":3350,"meta":3183,"style":3183},"# Монтувати поточну директорію в контейнер\ndocker run -d \\\n  --name myapp-dev \\\n  -v $(pwd):/app \\\n  myapp:latest\n",[3185,3853,3854,3859,3869,3878,3896],{"__ignoreMap":3183},[3188,3855,3856],{"class":3190,"line":3191},[3188,3857,3858],{"class":3357},"# Монтувати поточну директорію в контейнер\n",[3188,3860,3861,3863,3865,3867],{"class":3190,"line":3197},[3188,3862,3364],{"class":3363},[3188,3864,3368],{"class":3367},[3188,3866,3372],{"class":3371},[3188,3868,3376],{"class":3375},[3188,3870,3871,3873,3876],{"class":3190,"line":3203},[3188,3872,3381],{"class":3371},[3188,3874,3875],{"class":3367}," myapp-dev",[3188,3877,3376],{"class":3375},[3188,3879,3880,3882,3886,3889,3891,3894],{"class":3190,"line":3209},[3188,3881,3776],{"class":3371},[3188,3883,3885],{"class":3884},"sHH4Y"," $(",[3188,3887,3888],{"class":3363},"pwd",[3188,3890,3685],{"class":3884},[3188,3892,3893],{"class":3367},":/app",[3188,3895,3376],{"class":3375},[3188,3897,3898],{"class":3190,"line":3215},[3188,3899,3900],{"class":3367},"  myapp:latest\n",[3160,3902,3904],{"id":3903},"_3-tmpfs-mounts-тимчасове-сховище-в-памяті","3. tmpfs Mounts (Тимчасове сховище в пам'яті)",[3114,3906,3907,3909],{},[3118,3908,3146],{}," — це тимчасове сховище в оперативній пам'яті, яке не зберігається на диску.",[3114,3911,3912],{},[3118,3913,3673],{},[3620,3915,3916,3919,3922,3925,3928,3931],{},[3309,3917,3918],{},"✅ Дуже швидке (RAM швидше за диск)",[3309,3920,3921],{},"✅ Автоматично очищається при зупинці контейнера",[3309,3923,3924],{},"✅ Не залишає слідів на диску (безпека)",[3309,3926,3927],{},"⚠️ Обмежене розміром RAM",[3309,3929,3930],{},"⚠️ Дані втрачаються при перезапуску",[3309,3932,3933],{},"⚠️ Доступно лише на Linux",[3114,3935,3936],{},[3118,3937,3702],{},[3620,3939,3940,3943,3946,3949],{},[3309,3941,3942],{},"Тимчасові файли (кеш, сесії)",[3309,3944,3945],{},"Секрети (паролі, токени) — не зберігаються на диску",[3309,3947,3948],{},"Високошвидкісний кеш",[3309,3950,3951],{},"Проміжні дані обробки",[3114,3953,3954],{},[3118,3955,3721],{},[3179,3957,3959],{"className":3348,"code":3958,"language":3350,"meta":3183,"style":3183},"# Монтувати tmpfs для тимчасових файлів\ndocker run -d \\\n  --name myapp \\\n  --tmpfs /tmp:rw,size=100m \\\n  myapp:latest\n",[3185,3960,3961,3966,3976,3985,3995],{"__ignoreMap":3183},[3188,3962,3963],{"class":3190,"line":3191},[3188,3964,3965],{"class":3357},"# Монтувати tmpfs для тимчасових файлів\n",[3188,3967,3968,3970,3972,3974],{"class":3190,"line":3197},[3188,3969,3364],{"class":3363},[3188,3971,3368],{"class":3367},[3188,3973,3372],{"class":3371},[3188,3975,3376],{"class":3375},[3188,3977,3978,3980,3983],{"class":3190,"line":3203},[3188,3979,3381],{"class":3371},[3188,3981,3982],{"class":3367}," myapp",[3188,3984,3376],{"class":3375},[3188,3986,3987,3990,3993],{"class":3190,"line":3209},[3188,3988,3989],{"class":3371},"  --tmpfs",[3188,3991,3992],{"class":3367}," /tmp:rw,size=100m",[3188,3994,3376],{"class":3375},[3188,3996,3997],{"class":3190,"line":3215},[3188,3998,3900],{"class":3367},[3160,4000,4002],{"id":4001},"порівняльна-таблиця","Порівняльна таблиця",[4004,4005,4006,4024],"table",{},[4007,4008,4009],"thead",{},[4010,4011,4012,4017,4020,4022],"tr",{},[4013,4014,4016],"th",{"align":4015},"left","Характеристика",[4013,4018,3138],{"align":4019},"center",[4013,4021,3142],{"align":4019},[4013,4023,3146],{"align":4019},[4025,4026,4027,4041,4052,4065,4078,4091,4102,4114],"tbody",{},[4010,4028,4029,4033,4036,4039],{},[4030,4031,4032],"td",{"align":4015},"Керування Docker",[4030,4034,4035],{"align":4019},"✅",[4030,4037,4038],{"align":4019},"❌",[4030,4040,4035],{"align":4019},[4010,4042,4043,4046,4048,4050],{},[4030,4044,4045],{"align":4015},"Persistent storage",[4030,4047,4035],{"align":4019},[4030,4049,4035],{"align":4019},[4030,4051,4038],{"align":4019},[4010,4053,4054,4057,4060,4062],{},[4030,4055,4056],{"align":4015},"Швидкість",[4030,4058,4059],{"align":4019},"Середня",[4030,4061,4059],{"align":4019},[4030,4063,4064],{"align":4019},"Дуже висока",[4010,4066,4067,4070,4073,4076],{},[4030,4068,4069],{"align":4015},"Ізоляція",[4030,4071,4072],{"align":4019},"Висока",[4030,4074,4075],{"align":4019},"Низька",[4030,4077,4072],{"align":4019},[4010,4079,4080,4083,4085,4088],{},[4030,4081,4082],{"align":4015},"Кросплатформність",[4030,4084,4035],{"align":4019},[4030,4086,4087],{"align":4019},"⚠️",[4030,4089,4090],{"align":4019},"❌ (Linux)",[4010,4092,4093,4096,4098,4100],{},[4030,4094,4095],{"align":4015},"Hot-reload",[4030,4097,4038],{"align":4019},[4030,4099,4035],{"align":4019},[4030,4101,4038],{"align":4019},[4010,4103,4104,4107,4109,4111],{},[4030,4105,4106],{"align":4015},"Production",[4030,4108,4035],{"align":4019},[4030,4110,4087],{"align":4019},[4030,4112,4113],{"align":4019},"✅ (для кешу)",[4010,4115,4116,4119,4121,4123],{},[4030,4117,4118],{"align":4015},"Development",[4030,4120,4035],{"align":4019},[4030,4122,4035],{"align":4019},[4030,4124,4087],{"align":4019},[3176,4126,4127],{},[3179,4128,4130],{"className":3181,"code":4129,"language":3176,"meta":3183,"style":3183},"graph TB\n    subgraph Host\n        HD[Host Disk]\n        HM[Host Memory - RAM]\n        HDir[Host Directory\u003Cbr/>/home/user/myapp]\n    end\n    \n    subgraph Docker\n        DV[Docker Volumes\u003Cbr/>/var/lib/docker/volumes/]\n    end\n    \n    subgraph Container\n        CV[Volume Mount\u003Cbr/>/var/lib/postgresql/data]\n        CBM[Bind Mount\u003Cbr/>/app]\n        CT[tmpfs Mount\u003Cbr/>/tmp]\n    end\n    \n    DV -->|Managed by Docker| CV\n    HDir -->|Direct mount| CBM\n    HM -->|In-memory| CT\n    \n    DV -.->|Stored on| HD\n    \n    style DV fill:#10b981,stroke:#059669,color:#ffffff\n    style HDir fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n    style HM fill:#f59e0b,stroke:#b45309,color:#ffffff\n    style CV fill:#10b981,stroke:#059669,color:#ffffff\n    style CBM fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n    style CT fill:#f59e0b,stroke:#b45309,color:#ffffff\n",[3185,4131,4132,4136,4141,4146,4151,4156,4160,4164,4169,4174,4178,4182,4186,4191,4196,4201,4205,4209,4214,4219,4225,4230,4236,4241,4247,4253,4259,4265,4271],{"__ignoreMap":3183},[3188,4133,4134],{"class":3190,"line":3191},[3188,4135,3194],{},[3188,4137,4138],{"class":3190,"line":3197},[3188,4139,4140],{},"    subgraph Host\n",[3188,4142,4143],{"class":3190,"line":3203},[3188,4144,4145],{},"        HD[Host Disk]\n",[3188,4147,4148],{"class":3190,"line":3209},[3188,4149,4150],{},"        HM[Host Memory - RAM]\n",[3188,4152,4153],{"class":3190,"line":3215},[3188,4154,4155],{},"        HDir[Host Directory\u003Cbr/>/home/user/myapp]\n",[3188,4157,4158],{"class":3190,"line":3221},[3188,4159,3212],{},[3188,4161,4162],{"class":3190,"line":3227},[3188,4163,3218],{},[3188,4165,4166],{"class":3190,"line":3233},[3188,4167,4168],{},"    subgraph Docker\n",[3188,4170,4171],{"class":3190,"line":3239},[3188,4172,4173],{},"        DV[Docker Volumes\u003Cbr/>/var/lib/docker/volumes/]\n",[3188,4175,4176],{"class":3190,"line":3245},[3188,4177,3212],{},[3188,4179,4180],{"class":3190,"line":3250},[3188,4181,3218],{},[3188,4183,4184],{"class":3190,"line":3255},[3188,4185,3200],{},[3188,4187,4188],{"class":3190,"line":3261},[3188,4189,4190],{},"        CV[Volume Mount\u003Cbr/>/var/lib/postgresql/data]\n",[3188,4192,4193],{"class":3190,"line":3267},[3188,4194,4195],{},"        CBM[Bind Mount\u003Cbr/>/app]\n",[3188,4197,4198],{"class":3190,"line":3273},[3188,4199,4200],{},"        CT[tmpfs Mount\u003Cbr/>/tmp]\n",[3188,4202,4203],{"class":3190,"line":3278},[3188,4204,3212],{},[3188,4206,4207],{"class":3190,"line":3284},[3188,4208,3218],{},[3188,4210,4211],{"class":3190,"line":3290},[3188,4212,4213],{},"    DV -->|Managed by Docker| CV\n",[3188,4215,4216],{"class":3190,"line":3296},[3188,4217,4218],{},"    HDir -->|Direct mount| CBM\n",[3188,4220,4222],{"class":3190,"line":4221},20,[3188,4223,4224],{},"    HM -->|In-memory| CT\n",[3188,4226,4228],{"class":3190,"line":4227},21,[3188,4229,3218],{},[3188,4231,4233],{"class":3190,"line":4232},22,[3188,4234,4235],{},"    DV -.->|Stored on| HD\n",[3188,4237,4239],{"class":3190,"line":4238},23,[3188,4240,3218],{},[3188,4242,4244],{"class":3190,"line":4243},24,[3188,4245,4246],{},"    style DV fill:#10b981,stroke:#059669,color:#ffffff\n",[3188,4248,4250],{"class":3190,"line":4249},25,[3188,4251,4252],{},"    style HDir fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n",[3188,4254,4256],{"class":3190,"line":4255},26,[3188,4257,4258],{},"    style HM fill:#f59e0b,stroke:#b45309,color:#ffffff\n",[3188,4260,4262],{"class":3190,"line":4261},27,[3188,4263,4264],{},"    style CV fill:#10b981,stroke:#059669,color:#ffffff\n",[3188,4266,4268],{"class":3190,"line":4267},28,[3188,4269,4270],{},"    style CBM fill:#3b82f6,stroke:#1d4ed8,color:#ffffff\n",[3188,4272,4274],{"class":3190,"line":4273},29,[3188,4275,4276],{},"    style CT fill:#f59e0b,stroke:#b45309,color:#ffffff\n",[4278,4279,4280,4285],"tip",{},[3114,4281,4282],{},[3118,4283,4284],{},"Правило вибору storage:",[3620,4286,4287,4293,4299],{},[3309,4288,4289,4292],{},[3118,4290,4291],{},"Production БД:"," Volumes (керовані, надійні, backup-friendly)",[3309,4294,4295,4298],{},[3118,4296,4297],{},"Development hot-reload:"," Bind Mounts (зміни коду одразу видимі)",[3309,4300,4301,4304],{},[3118,4302,4303],{},"Секрети та кеш:"," tmpfs (швидко, не залишає слідів)",[3153,4306],{},[3109,4308,4310],{"id":4309},"docker-volumes-керовані-томи","Docker Volumes: керовані томи",[3160,4312,4314],{"id":4313},"створення-volumes","Створення volumes",[3114,4316,4317],{},[3118,4318,4319],{},"Синтаксис:",[3179,4321,4323],{"className":3348,"code":4322,"language":3350,"meta":3183,"style":3183},"docker volume create [OPTIONS] [VOLUME_NAME]\n",[3185,4324,4325],{"__ignoreMap":3183},[3188,4326,4327,4329,4331,4333],{"class":3190,"line":3191},[3188,4328,3364],{"class":3363},[3188,4330,3738],{"class":3367},[3188,4332,3741],{"class":3367},[3188,4334,4335],{"class":3884}," [OPTIONS] [VOLUME_NAME]\n",[3114,4337,4338],{},[3118,4339,4340],{},"Приклади:",[3179,4342,4344],{"className":3348,"code":4343,"language":3350,"meta":3183,"style":3183},"# Створити volume з автоматичною назвою\ndocker volume create\n\n# Створити volume з конкретною назвою\ndocker volume create postgres-data\n\n# Створити volume з мітками (labels)\ndocker volume create \\\n  --label environment=production \\\n  --label app=myapp \\\n  myapp-data\n\n# Створити volume з конкретним driver\ndocker volume create \\\n  --driver local \\\n  --opt type=nfs \\\n  --opt o=addr=192.168.1.100,rw \\\n  --opt device=:/path/to/dir \\\n  nfs-volume\n",[3185,4345,4346,4351,4360,4364,4369,4379,4383,4388,4398,4408,4417,4422,4426,4431,4441,4451,4461,4470,4479],{"__ignoreMap":3183},[3188,4347,4348],{"class":3190,"line":3191},[3188,4349,4350],{"class":3357},"# Створити volume з автоматичною назвою\n",[3188,4352,4353,4355,4357],{"class":3190,"line":3197},[3188,4354,3364],{"class":3363},[3188,4356,3738],{"class":3367},[3188,4358,4359],{"class":3367}," create\n",[3188,4361,4362],{"class":3190,"line":3203},[3188,4363,3407],{"emptyLinePlaceholder":3406},[3188,4365,4366],{"class":3190,"line":3209},[3188,4367,4368],{"class":3357},"# Створити volume з конкретною назвою\n",[3188,4370,4371,4373,4375,4377],{"class":3190,"line":3215},[3188,4372,3364],{"class":3363},[3188,4374,3738],{"class":3367},[3188,4376,3741],{"class":3367},[3188,4378,3744],{"class":3367},[3188,4380,4381],{"class":3190,"line":3221},[3188,4382,3407],{"emptyLinePlaceholder":3406},[3188,4384,4385],{"class":3190,"line":3227},[3188,4386,4387],{"class":3357},"# Створити volume з мітками (labels)\n",[3188,4389,4390,4392,4394,4396],{"class":3190,"line":3233},[3188,4391,3364],{"class":3363},[3188,4393,3738],{"class":3367},[3188,4395,3741],{"class":3367},[3188,4397,3376],{"class":3375},[3188,4399,4400,4403,4406],{"class":3190,"line":3239},[3188,4401,4402],{"class":3371},"  --label",[3188,4404,4405],{"class":3367}," environment=production",[3188,4407,3376],{"class":3375},[3188,4409,4410,4412,4415],{"class":3190,"line":3245},[3188,4411,4402],{"class":3371},[3188,4413,4414],{"class":3367}," app=myapp",[3188,4416,3376],{"class":3375},[3188,4418,4419],{"class":3190,"line":3250},[3188,4420,4421],{"class":3367},"  myapp-data\n",[3188,4423,4424],{"class":3190,"line":3255},[3188,4425,3407],{"emptyLinePlaceholder":3406},[3188,4427,4428],{"class":3190,"line":3261},[3188,4429,4430],{"class":3357},"# Створити volume з конкретним driver\n",[3188,4432,4433,4435,4437,4439],{"class":3190,"line":3267},[3188,4434,3364],{"class":3363},[3188,4436,3738],{"class":3367},[3188,4438,3741],{"class":3367},[3188,4440,3376],{"class":3375},[3188,4442,4443,4446,4449],{"class":3190,"line":3273},[3188,4444,4445],{"class":3371},"  --driver",[3188,4447,4448],{"class":3367}," local",[3188,4450,3376],{"class":3375},[3188,4452,4453,4456,4459],{"class":3190,"line":3278},[3188,4454,4455],{"class":3371},"  --opt",[3188,4457,4458],{"class":3367}," type=nfs",[3188,4460,3376],{"class":3375},[3188,4462,4463,4465,4468],{"class":3190,"line":3284},[3188,4464,4455],{"class":3371},[3188,4466,4467],{"class":3367}," o=addr=192.168.1.100,rw",[3188,4469,3376],{"class":3375},[3188,4471,4472,4474,4477],{"class":3190,"line":3290},[3188,4473,4455],{"class":3371},[3188,4475,4476],{"class":3367}," device=:/path/to/dir",[3188,4478,3376],{"class":3375},[3188,4480,4481],{"class":3190,"line":3296},[3188,4482,4483],{"class":3367},"  nfs-volume\n",[3160,4485,4487],{"id":4486},"перегляд-volumes","Перегляд volumes",[3179,4489,4491],{"className":3348,"code":4490,"language":3350,"meta":3183,"style":3183},"# Список всіх volumes\ndocker volume ls\n\n# Вивід:\n# DRIVER    VOLUME NAME\n# local     postgres-data\n# local     myapp-data\n# local     abc123def456  (анонімний volume)\n\n# Детальна інформація про volume\ndocker volume inspect postgres-data\n",[3185,4492,4493,4498,4507,4511,4515,4520,4525,4530,4535,4539,4544],{"__ignoreMap":3183},[3188,4494,4495],{"class":3190,"line":3191},[3188,4496,4497],{"class":3357},"# Список всіх volumes\n",[3188,4499,4500,4502,4504],{"class":3190,"line":3197},[3188,4501,3364],{"class":3363},[3188,4503,3738],{"class":3367},[3188,4505,4506],{"class":3367}," ls\n",[3188,4508,4509],{"class":3190,"line":3203},[3188,4510,3407],{"emptyLinePlaceholder":3406},[3188,4512,4513],{"class":3190,"line":3209},[3188,4514,3488],{"class":3357},[3188,4516,4517],{"class":3190,"line":3215},[3188,4518,4519],{"class":3357},"# DRIVER    VOLUME NAME\n",[3188,4521,4522],{"class":3190,"line":3221},[3188,4523,4524],{"class":3357},"# local     postgres-data\n",[3188,4526,4527],{"class":3190,"line":3227},[3188,4528,4529],{"class":3357},"# local     myapp-data\n",[3188,4531,4532],{"class":3190,"line":3233},[3188,4533,4534],{"class":3357},"# local     abc123def456  (анонімний volume)\n",[3188,4536,4537],{"class":3190,"line":3239},[3188,4538,3407],{"emptyLinePlaceholder":3406},[3188,4540,4541],{"class":3190,"line":3245},[3188,4542,4543],{"class":3357},"# Детальна інформація про volume\n",[3188,4545,4546,4548,4550,4553],{"class":3190,"line":3250},[3188,4547,3364],{"class":3363},[3188,4549,3738],{"class":3367},[3188,4551,4552],{"class":3367}," inspect",[3188,4554,3744],{"class":3367},[3114,4556,4557],{},[3118,4558,4559,4560,4563],{},"Вивід ",[3185,4561,4562],{},"docker volume inspect",":",[3179,4565,4569],{"className":4566,"code":4567,"language":4568,"meta":3183,"style":3183},"language-json shiki shiki-themes light-plus dark-plus dark-plus","[\n    {\n        \"CreatedAt\": \"2026-04-14T11:20:30Z\",\n        \"Driver\": \"local\",\n        \"Labels\": {},\n        \"Mountpoint\": \"/var/lib/docker/volumes/postgres-data/_data\",\n        \"Name\": \"postgres-data\",\n        \"Options\": {},\n        \"Scope\": \"local\"\n    }\n]\n","json",[3185,4570,4571,4576,4581,4596,4608,4616,4628,4640,4647,4657,4662],{"__ignoreMap":3183},[3188,4572,4573],{"class":3190,"line":3191},[3188,4574,4575],{"class":3884},"[\n",[3188,4577,4578],{"class":3190,"line":3197},[3188,4579,4580],{"class":3884},"    {\n",[3188,4582,4583,4587,4590,4593],{"class":3190,"line":3203},[3188,4584,4586],{"class":4585},"sLwNe","        \"CreatedAt\"",[3188,4588,4589],{"class":3884},": ",[3188,4591,4592],{"class":3367},"\"2026-04-14T11:20:30Z\"",[3188,4594,4595],{"class":3884},",\n",[3188,4597,4598,4601,4603,4606],{"class":3190,"line":3209},[3188,4599,4600],{"class":4585},"        \"Driver\"",[3188,4602,4589],{"class":3884},[3188,4604,4605],{"class":3367},"\"local\"",[3188,4607,4595],{"class":3884},[3188,4609,4610,4613],{"class":3190,"line":3215},[3188,4611,4612],{"class":4585},"        \"Labels\"",[3188,4614,4615],{"class":3884},": {},\n",[3188,4617,4618,4621,4623,4626],{"class":3190,"line":3221},[3188,4619,4620],{"class":4585},"        \"Mountpoint\"",[3188,4622,4589],{"class":3884},[3188,4624,4625],{"class":3367},"\"/var/lib/docker/volumes/postgres-data/_data\"",[3188,4627,4595],{"class":3884},[3188,4629,4630,4633,4635,4638],{"class":3190,"line":3227},[3188,4631,4632],{"class":4585},"        \"Name\"",[3188,4634,4589],{"class":3884},[3188,4636,4637],{"class":3367},"\"postgres-data\"",[3188,4639,4595],{"class":3884},[3188,4641,4642,4645],{"class":3190,"line":3233},[3188,4643,4644],{"class":4585},"        \"Options\"",[3188,4646,4615],{"class":3884},[3188,4648,4649,4652,4654],{"class":3190,"line":3239},[3188,4650,4651],{"class":4585},"        \"Scope\"",[3188,4653,4589],{"class":3884},[3188,4655,4656],{"class":3367},"\"local\"\n",[3188,4658,4659],{"class":3190,"line":3245},[3188,4660,4661],{"class":3884},"    }\n",[3188,4663,4664],{"class":3190,"line":3250},[3188,4665,4666],{"class":3884},"]\n",[3114,4668,4669],{},[3118,4670,4671],{},"Ключові поля:",[3620,4673,4674,4680,4686],{},[3309,4675,4676,4679],{},[3185,4677,4678],{},"Mountpoint"," — де фізично зберігаються дані на хості",[3309,4681,4682,4685],{},[3185,4683,4684],{},"Driver"," — драйвер storage (local, nfs, cloud)",[3309,4687,4688,4691],{},[3185,4689,4690],{},"Labels"," — мітки для організації volumes",[3160,4693,4695],{"id":4694},"монтування-volumes-у-контейнер","Монтування volumes у контейнер",[3114,4697,4698],{},[3118,4699,4700],{},"Два синтаксиси:",[3114,4702,4703],{},[3118,4704,4705,4706,4709],{},"1. Короткий синтаксис (",[3185,4707,4708],{},"-v","):",[3179,4711,4713],{"className":3348,"code":4712,"language":3350,"meta":3183,"style":3183},"docker run -v VOLUME_NAME:CONTAINER_PATH [OPTIONS] IMAGE\n",[3185,4714,4715],{"__ignoreMap":3183},[3188,4716,4717,4719,4721,4724,4727],{"class":3190,"line":3191},[3188,4718,3364],{"class":3363},[3188,4720,3368],{"class":3367},[3188,4722,4723],{"class":3371}," -v",[3188,4725,4726],{"class":3367}," VOLUME_NAME:CONTAINER_PATH",[3188,4728,4729],{"class":3884}," [OPTIONS] IMAGE\n",[3114,4731,4732],{},[3118,4733,4340],{},[3179,4735,4737],{"className":3348,"code":4736,"language":3350,"meta":3183,"style":3183},"# Монтувати існуючий volume\ndocker run -d \\\n  --name postgres \\\n  -v postgres-data:/var/lib/postgresql/data \\\n  postgres:16\n\n# Монтувати volume read-only\ndocker run -d \\\n  --name app \\\n  -v config-data:/app/config:ro \\\n  myapp:latest\n\n# Створити анонімний volume (Docker згенерує назву)\ndocker run -d \\\n  --name app \\\n  -v /app/data \\\n  myapp:latest\n",[3185,4738,4739,4744,4754,4762,4770,4774,4778,4783,4793,4802,4811,4815,4819,4824,4834,4842,4851],{"__ignoreMap":3183},[3188,4740,4741],{"class":3190,"line":3191},[3188,4742,4743],{"class":3357},"# Монтувати існуючий volume\n",[3188,4745,4746,4748,4750,4752],{"class":3190,"line":3197},[3188,4747,3364],{"class":3363},[3188,4749,3368],{"class":3367},[3188,4751,3372],{"class":3371},[3188,4753,3376],{"class":3375},[3188,4755,4756,4758,4760],{"class":3190,"line":3203},[3188,4757,3381],{"class":3371},[3188,4759,3452],{"class":3367},[3188,4761,3376],{"class":3375},[3188,4763,4764,4766,4768],{"class":3190,"line":3209},[3188,4765,3776],{"class":3371},[3188,4767,3779],{"class":3367},[3188,4769,3376],{"class":3375},[3188,4771,4772],{"class":3190,"line":3215},[3188,4773,3401],{"class":3367},[3188,4775,4776],{"class":3190,"line":3221},[3188,4777,3407],{"emptyLinePlaceholder":3406},[3188,4779,4780],{"class":3190,"line":3227},[3188,4781,4782],{"class":3357},"# Монтувати volume read-only\n",[3188,4784,4785,4787,4789,4791],{"class":3190,"line":3233},[3188,4786,3364],{"class":3363},[3188,4788,3368],{"class":3367},[3188,4790,3372],{"class":3371},[3188,4792,3376],{"class":3375},[3188,4794,4795,4797,4800],{"class":3190,"line":3239},[3188,4796,3381],{"class":3371},[3188,4798,4799],{"class":3367}," app",[3188,4801,3376],{"class":3375},[3188,4803,4804,4806,4809],{"class":3190,"line":3245},[3188,4805,3776],{"class":3371},[3188,4807,4808],{"class":3367}," config-data:/app/config:ro",[3188,4810,3376],{"class":3375},[3188,4812,4813],{"class":3190,"line":3250},[3188,4814,3900],{"class":3367},[3188,4816,4817],{"class":3190,"line":3255},[3188,4818,3407],{"emptyLinePlaceholder":3406},[3188,4820,4821],{"class":3190,"line":3261},[3188,4822,4823],{"class":3357},"# Створити анонімний volume (Docker згенерує назву)\n",[3188,4825,4826,4828,4830,4832],{"class":3190,"line":3267},[3188,4827,3364],{"class":3363},[3188,4829,3368],{"class":3367},[3188,4831,3372],{"class":3371},[3188,4833,3376],{"class":3375},[3188,4835,4836,4838,4840],{"class":3190,"line":3273},[3188,4837,3381],{"class":3371},[3188,4839,4799],{"class":3367},[3188,4841,3376],{"class":3375},[3188,4843,4844,4846,4849],{"class":3190,"line":3278},[3188,4845,3776],{"class":3371},[3188,4847,4848],{"class":3367}," /app/data",[3188,4850,3376],{"class":3375},[3188,4852,4853],{"class":3190,"line":3284},[3188,4854,3900],{"class":3367},[3114,4856,4857],{},[3118,4858,4859,4860,4709],{},"2. Довгий синтаксис (",[3185,4861,4862],{},"--mount",[3179,4864,4866],{"className":3348,"code":4865,"language":3350,"meta":3183,"style":3183},"docker run --mount type=volume,source=VOLUME_NAME,target=CONTAINER_PATH [OPTIONS] IMAGE\n",[3185,4867,4868],{"__ignoreMap":3183},[3188,4869,4870,4872,4874,4877,4880],{"class":3190,"line":3191},[3188,4871,3364],{"class":3363},[3188,4873,3368],{"class":3367},[3188,4875,4876],{"class":3371}," --mount",[3188,4878,4879],{"class":3367}," type=volume,source=VOLUME_NAME,target=CONTAINER_PATH",[3188,4881,4729],{"class":3884},[3114,4883,4884],{},[3118,4885,4340],{},[3179,4887,4889],{"className":3348,"code":4888,"language":3350,"meta":3183,"style":3183},"# Базове монтування\ndocker run -d \\\n  --name postgres \\\n  --mount type=volume,source=postgres-data,target=/var/lib/postgresql/data \\\n  postgres:16\n\n# Read-only монтування\ndocker run -d \\\n  --name app \\\n  --mount type=volume,source=config-data,target=/app/config,readonly \\\n  myapp:latest\n\n# З додатковими опціями\ndocker run -d \\\n  --name app \\\n  --mount type=volume,source=myapp-data,target=/app/data,volume-driver=local \\\n  myapp:latest\n",[3185,4890,4891,4896,4906,4914,4924,4928,4932,4937,4947,4955,4964,4968,4972,4977,4987,4995,5004],{"__ignoreMap":3183},[3188,4892,4893],{"class":3190,"line":3191},[3188,4894,4895],{"class":3357},"# Базове монтування\n",[3188,4897,4898,4900,4902,4904],{"class":3190,"line":3197},[3188,4899,3364],{"class":3363},[3188,4901,3368],{"class":3367},[3188,4903,3372],{"class":3371},[3188,4905,3376],{"class":3375},[3188,4907,4908,4910,4912],{"class":3190,"line":3203},[3188,4909,3381],{"class":3371},[3188,4911,3452],{"class":3367},[3188,4913,3376],{"class":3375},[3188,4915,4916,4919,4922],{"class":3190,"line":3209},[3188,4917,4918],{"class":3371},"  --mount",[3188,4920,4921],{"class":3367}," type=volume,source=postgres-data,target=/var/lib/postgresql/data",[3188,4923,3376],{"class":3375},[3188,4925,4926],{"class":3190,"line":3215},[3188,4927,3401],{"class":3367},[3188,4929,4930],{"class":3190,"line":3221},[3188,4931,3407],{"emptyLinePlaceholder":3406},[3188,4933,4934],{"class":3190,"line":3227},[3188,4935,4936],{"class":3357},"# Read-only монтування\n",[3188,4938,4939,4941,4943,4945],{"class":3190,"line":3233},[3188,4940,3364],{"class":3363},[3188,4942,3368],{"class":3367},[3188,4944,3372],{"class":3371},[3188,4946,3376],{"class":3375},[3188,4948,4949,4951,4953],{"class":3190,"line":3239},[3188,4950,3381],{"class":3371},[3188,4952,4799],{"class":3367},[3188,4954,3376],{"class":3375},[3188,4956,4957,4959,4962],{"class":3190,"line":3245},[3188,4958,4918],{"class":3371},[3188,4960,4961],{"class":3367}," type=volume,source=config-data,target=/app/config,readonly",[3188,4963,3376],{"class":3375},[3188,4965,4966],{"class":3190,"line":3250},[3188,4967,3900],{"class":3367},[3188,4969,4970],{"class":3190,"line":3255},[3188,4971,3407],{"emptyLinePlaceholder":3406},[3188,4973,4974],{"class":3190,"line":3261},[3188,4975,4976],{"class":3357},"# З додатковими опціями\n",[3188,4978,4979,4981,4983,4985],{"class":3190,"line":3267},[3188,4980,3364],{"class":3363},[3188,4982,3368],{"class":3367},[3188,4984,3372],{"class":3371},[3188,4986,3376],{"class":3375},[3188,4988,4989,4991,4993],{"class":3190,"line":3273},[3188,4990,3381],{"class":3371},[3188,4992,4799],{"class":3367},[3188,4994,3376],{"class":3375},[3188,4996,4997,4999,5002],{"class":3190,"line":3278},[3188,4998,4918],{"class":3371},[3188,5000,5001],{"class":3367}," type=volume,source=myapp-data,target=/app/data,volume-driver=local",[3188,5003,3376],{"class":3375},[3188,5005,5006],{"class":3190,"line":3284},[3188,5007,3900],{"class":3367},[3149,5009,5010,5020,5032],{},[3114,5011,5012],{},[3118,5013,5014,5015,5017,5018,4563],{},"Різниця між ",[3185,5016,4708],{}," та ",[3185,5019,4862],{},[3620,5021,5022,5027],{},[3309,5023,5024,5026],{},[3185,5025,4708],{}," — коротший, зручніший для простих випадків",[3309,5028,5029,5031],{},[3185,5030,4862],{}," — більш явний, рекомендований для production (легше читати, менше помилок)",[3114,5033,5034],{},"Обидва синтаксиси функціонально еквівалентні.",[3160,5036,5038],{"id":5037},"приклад-postgresql-з-persistent-storage","Приклад: PostgreSQL з persistent storage",[3114,5040,5041],{},[3118,5042,5043],{},"Крок 1: Створити volume",[3179,5045,5047],{"className":3348,"code":5046,"language":3350,"meta":3183,"style":3183},"docker volume create postgres-data\n",[3185,5048,5049],{"__ignoreMap":3183},[3188,5050,5051,5053,5055,5057],{"class":3190,"line":3191},[3188,5052,3364],{"class":3363},[3188,5054,3738],{"class":3367},[3188,5056,3741],{"class":3367},[3188,5058,3744],{"class":3367},[3114,5060,5061],{},[3118,5062,5063],{},"Крок 2: Запустити PostgreSQL з volume",[3179,5065,5067],{"className":3348,"code":5066,"language":3350,"meta":3183,"style":3183},"docker run -d \\\n  --name postgres \\\n  -e POSTGRES_PASSWORD=mysecret \\\n  -e POSTGRES_DB=myapp \\\n  -v postgres-data:/var/lib/postgresql/data \\\n  -p 5432:5432 \\\n  postgres:16\n",[3185,5068,5069,5079,5087,5095,5104,5112,5122],{"__ignoreMap":3183},[3188,5070,5071,5073,5075,5077],{"class":3190,"line":3191},[3188,5072,3364],{"class":3363},[3188,5074,3368],{"class":3367},[3188,5076,3372],{"class":3371},[3188,5078,3376],{"class":3375},[3188,5080,5081,5083,5085],{"class":3190,"line":3197},[3188,5082,3381],{"class":3371},[3188,5084,3452],{"class":3367},[3188,5086,3376],{"class":3375},[3188,5088,5089,5091,5093],{"class":3190,"line":3203},[3188,5090,3391],{"class":3371},[3188,5092,3394],{"class":3367},[3188,5094,3376],{"class":3375},[3188,5096,5097,5099,5102],{"class":3190,"line":3209},[3188,5098,3391],{"class":3371},[3188,5100,5101],{"class":3367}," POSTGRES_DB=myapp",[3188,5103,3376],{"class":3375},[3188,5105,5106,5108,5110],{"class":3190,"line":3215},[3188,5107,3776],{"class":3371},[3188,5109,3779],{"class":3367},[3188,5111,3376],{"class":3375},[3188,5113,5114,5117,5120],{"class":3190,"line":3221},[3188,5115,5116],{"class":3371},"  -p",[3188,5118,5119],{"class":3367}," 5432:5432",[3188,5121,3376],{"class":3375},[3188,5123,5124],{"class":3190,"line":3227},[3188,5125,3401],{"class":3367},[3114,5127,5128],{},[3118,5129,5130],{},"Крок 3: Створити дані",[3179,5132,5134],{"className":3348,"code":5133,"language":3350,"meta":3183,"style":3183},"# Підключитися до БД\ndocker exec -it postgres psql -U postgres -d myapp\n\n# Створити таблицю та додати дані\nCREATE TABLE users (\n    id SERIAL PRIMARY KEY,\n    name VARCHAR(100),\n    email VARCHAR(100)\n);\n\nINSERT INTO users (name, email) VALUES \n    ('Alice', 'alice@example.com'),\n    ('Bob', 'bob@example.com');\n\nSELECT * FROM users;\n",[3185,5135,5136,5141,5162,5166,5171,5185,5199,5217,5231,5236,5240,5259,5277,5291,5295],{"__ignoreMap":3183},[3188,5137,5138],{"class":3190,"line":3191},[3188,5139,5140],{"class":3357},"# Підключитися до БД\n",[3188,5142,5143,5145,5147,5149,5151,5153,5155,5157,5159],{"class":3190,"line":3197},[3188,5144,3364],{"class":3363},[3188,5146,3438],{"class":3367},[3188,5148,3441],{"class":3371},[3188,5150,3452],{"class":3367},[3188,5152,3446],{"class":3367},[3188,5154,3449],{"class":3371},[3188,5156,3452],{"class":3367},[3188,5158,3372],{"class":3371},[3188,5160,5161],{"class":3367}," myapp\n",[3188,5163,5164],{"class":3190,"line":3203},[3188,5165,3407],{"emptyLinePlaceholder":3406},[3188,5167,5168],{"class":3190,"line":3209},[3188,5169,5170],{"class":3357},"# Створити таблицю та додати дані\n",[3188,5172,5173,5176,5179,5182],{"class":3190,"line":3215},[3188,5174,5175],{"class":3363},"CREATE",[3188,5177,5178],{"class":3367}," TABLE",[3188,5180,5181],{"class":3367}," users",[3188,5183,5184],{"class":3884}," (\n",[3188,5186,5187,5190,5193,5196],{"class":3190,"line":3221},[3188,5188,5189],{"class":3363},"    id",[3188,5191,5192],{"class":3367}," SERIAL",[3188,5194,5195],{"class":3367}," PRIMARY",[3188,5197,5198],{"class":3367}," KEY,\n",[3188,5200,5201,5204,5207,5210,5213,5215],{"class":3190,"line":3227},[3188,5202,5203],{"class":3363},"    name",[3188,5205,5206],{"class":3367}," VARCHAR",[3188,5208,5209],{"class":3884},"(",[3188,5211,5212],{"class":3363},"100",[3188,5214,3685],{"class":3884},[3188,5216,4595],{"class":3367},[3188,5218,5219,5222,5224,5226,5228],{"class":3190,"line":3233},[3188,5220,5221],{"class":3363},"    email",[3188,5223,5206],{"class":3367},[3188,5225,5209],{"class":3884},[3188,5227,5212],{"class":3363},[3188,5229,5230],{"class":3884},")\n",[3188,5232,5233],{"class":3190,"line":3239},[3188,5234,5235],{"class":3884},");\n",[3188,5237,5238],{"class":3190,"line":3245},[3188,5239,3407],{"emptyLinePlaceholder":3406},[3188,5241,5242,5245,5248,5250,5253,5256],{"class":3190,"line":3250},[3188,5243,5244],{"class":3363},"INSERT",[3188,5246,5247],{"class":3367}," INTO",[3188,5249,5181],{"class":3367},[3188,5251,5252],{"class":3884}," (name, ",[3188,5254,5255],{"class":3367},"email",[3188,5257,5258],{"class":3884},") VALUES \n",[3188,5260,5261,5264,5267,5270,5273,5275],{"class":3190,"line":3255},[3188,5262,5263],{"class":3884},"    (",[3188,5265,5266],{"class":3363},"'Alice'",[3188,5268,5269],{"class":3363},",",[3188,5271,5272],{"class":3367}," 'alice@example.com'",[3188,5274,3685],{"class":3884},[3188,5276,4595],{"class":3363},[3188,5278,5279,5281,5284,5286,5289],{"class":3190,"line":3261},[3188,5280,5263],{"class":3884},[3188,5282,5283],{"class":3363},"'Bob'",[3188,5285,5269],{"class":3363},[3188,5287,5288],{"class":3367}," 'bob@example.com'",[3188,5290,5235],{"class":3884},[3188,5292,5293],{"class":3190,"line":3267},[3188,5294,3407],{"emptyLinePlaceholder":3406},[3188,5296,5297,5300,5303,5306,5308],{"class":3190,"line":3273},[3188,5298,5299],{"class":3363},"SELECT",[3188,5301,5302],{"class":3371}," *",[3188,5304,5305],{"class":3367}," FROM",[3188,5307,5181],{"class":3367},[3188,5309,5310],{"class":3884},";\n",[3114,5312,5313],{},[3118,5314,5315],{},"Крок 4: Видалити контейнер",[3179,5317,5319],{"className":3348,"code":5318,"language":3350,"meta":3183,"style":3183},"docker stop postgres\ndocker rm postgres\n",[3185,5320,5321,5330],{"__ignoreMap":3183},[3188,5322,5323,5325,5327],{"class":3190,"line":3191},[3188,5324,3364],{"class":3363},[3188,5326,3515],{"class":3367},[3188,5328,5329],{"class":3367}," postgres\n",[3188,5331,5332,5334,5336],{"class":3190,"line":3197},[3188,5333,3364],{"class":3363},[3188,5335,3524],{"class":3367},[3188,5337,5329],{"class":3367},[3114,5339,5340],{},[3118,5341,5342],{},"Крок 5: Запустити новий контейнер з тим самим volume",[3179,5344,5346],{"className":3348,"code":5345,"language":3350,"meta":3183,"style":3183},"docker run -d \\\n  --name postgres-new \\\n  -e POSTGRES_PASSWORD=mysecret \\\n  -v postgres-data:/var/lib/postgresql/data \\\n  -p 5432:5432 \\\n  postgres:16\n",[3185,5347,5348,5358,5367,5375,5383,5391],{"__ignoreMap":3183},[3188,5349,5350,5352,5354,5356],{"class":3190,"line":3191},[3188,5351,3364],{"class":3363},[3188,5353,3368],{"class":3367},[3188,5355,3372],{"class":3371},[3188,5357,3376],{"class":3375},[3188,5359,5360,5362,5365],{"class":3190,"line":3197},[3188,5361,3381],{"class":3371},[3188,5363,5364],{"class":3367}," postgres-new",[3188,5366,3376],{"class":3375},[3188,5368,5369,5371,5373],{"class":3190,"line":3203},[3188,5370,3391],{"class":3371},[3188,5372,3394],{"class":3367},[3188,5374,3376],{"class":3375},[3188,5376,5377,5379,5381],{"class":3190,"line":3209},[3188,5378,3776],{"class":3371},[3188,5380,3779],{"class":3367},[3188,5382,3376],{"class":3375},[3188,5384,5385,5387,5389],{"class":3190,"line":3215},[3188,5386,5116],{"class":3371},[3188,5388,5119],{"class":3367},[3188,5390,3376],{"class":3375},[3188,5392,5393],{"class":3190,"line":3221},[3188,5394,3401],{"class":3367},[3114,5396,5397],{},[3118,5398,5399],{},"Крок 6: Перевірити дані",[3179,5401,5403],{"className":3348,"code":5402,"language":3350,"meta":3183,"style":3183},"docker exec -it postgres-new psql -U postgres -d myapp -c \"SELECT * FROM users;\"\n\n# Вивід:\n#  id | name  |       email\n# ----+-------+-------------------\n#   1 | Alice | alice@example.com\n#   2 | Bob   | bob@example.com\n",[3185,5404,5405,5430,5434,5438,5443,5448,5453],{"__ignoreMap":3183},[3188,5406,5407,5409,5411,5413,5415,5417,5419,5421,5423,5425,5427],{"class":3190,"line":3191},[3188,5408,3364],{"class":3363},[3188,5410,3438],{"class":3367},[3188,5412,3441],{"class":3371},[3188,5414,5364],{"class":3367},[3188,5416,3446],{"class":3367},[3188,5418,3449],{"class":3371},[3188,5420,3452],{"class":3367},[3188,5422,3372],{"class":3371},[3188,5424,3982],{"class":3367},[3188,5426,3455],{"class":3371},[3188,5428,5429],{"class":3367}," \"SELECT * FROM users;\"\n",[3188,5431,5432],{"class":3190,"line":3197},[3188,5433,3407],{"emptyLinePlaceholder":3406},[3188,5435,5436],{"class":3190,"line":3203},[3188,5437,3488],{"class":3357},[3188,5439,5440],{"class":3190,"line":3209},[3188,5441,5442],{"class":3357},"#  id | name  |       email\n",[3188,5444,5445],{"class":3190,"line":3215},[3188,5446,5447],{"class":3357},"# ----+-------+-------------------\n",[3188,5449,5450],{"class":3190,"line":3221},[3188,5451,5452],{"class":3357},"#   1 | Alice | alice@example.com\n",[3188,5454,5455],{"class":3190,"line":3227},[3188,5456,5457],{"class":3357},"#   2 | Bob   | bob@example.com\n",[3114,5459,5460,5463],{},[3118,5461,5462],{},"Дані збереглися!"," Volume існує незалежно від контейнера.",[3160,5465,5467],{"id":5466},"спільні-volumes-між-контейнерами","Спільні volumes між контейнерами",[3114,5469,5470],{},"Кілька контейнерів можуть монтувати один volume одночасно.",[3114,5472,5473],{},[3118,5474,5475],{},"Приклад: Web API + Worker з спільним volume для файлів",[3179,5477,5479],{"className":3348,"code":5478,"language":3350,"meta":3183,"style":3183},"# Створити volume\ndocker volume create shared-uploads\n\n# Запустити Web API (приймає файли)\ndocker run -d \\\n  --name api \\\n  -v shared-uploads:/app/uploads \\\n  -p 8080:8080 \\\n  myapi:latest\n\n# Запустити Worker (обробляє файли)\ndocker run -d \\\n  --name worker \\\n  -v shared-uploads:/app/uploads \\\n  myworker:latest\n",[3185,5480,5481,5485,5496,5500,5505,5515,5524,5533,5542,5547,5551,5556,5566,5575,5583],{"__ignoreMap":3183},[3188,5482,5483],{"class":3190,"line":3191},[3188,5484,3731],{"class":3357},[3188,5486,5487,5489,5491,5493],{"class":3190,"line":3197},[3188,5488,3364],{"class":3363},[3188,5490,3738],{"class":3367},[3188,5492,3741],{"class":3367},[3188,5494,5495],{"class":3367}," shared-uploads\n",[3188,5497,5498],{"class":3190,"line":3203},[3188,5499,3407],{"emptyLinePlaceholder":3406},[3188,5501,5502],{"class":3190,"line":3209},[3188,5503,5504],{"class":3357},"# Запустити Web API (приймає файли)\n",[3188,5506,5507,5509,5511,5513],{"class":3190,"line":3215},[3188,5508,3364],{"class":3363},[3188,5510,3368],{"class":3367},[3188,5512,3372],{"class":3371},[3188,5514,3376],{"class":3375},[3188,5516,5517,5519,5522],{"class":3190,"line":3221},[3188,5518,3381],{"class":3371},[3188,5520,5521],{"class":3367}," api",[3188,5523,3376],{"class":3375},[3188,5525,5526,5528,5531],{"class":3190,"line":3227},[3188,5527,3776],{"class":3371},[3188,5529,5530],{"class":3367}," shared-uploads:/app/uploads",[3188,5532,3376],{"class":3375},[3188,5534,5535,5537,5540],{"class":3190,"line":3233},[3188,5536,5116],{"class":3371},[3188,5538,5539],{"class":3367}," 8080:8080",[3188,5541,3376],{"class":3375},[3188,5543,5544],{"class":3190,"line":3239},[3188,5545,5546],{"class":3367},"  myapi:latest\n",[3188,5548,5549],{"class":3190,"line":3245},[3188,5550,3407],{"emptyLinePlaceholder":3406},[3188,5552,5553],{"class":3190,"line":3250},[3188,5554,5555],{"class":3357},"# Запустити Worker (обробляє файли)\n",[3188,5557,5558,5560,5562,5564],{"class":3190,"line":3255},[3188,5559,3364],{"class":3363},[3188,5561,3368],{"class":3367},[3188,5563,3372],{"class":3371},[3188,5565,3376],{"class":3375},[3188,5567,5568,5570,5573],{"class":3190,"line":3261},[3188,5569,3381],{"class":3371},[3188,5571,5572],{"class":3367}," worker",[3188,5574,3376],{"class":3375},[3188,5576,5577,5579,5581],{"class":3190,"line":3267},[3188,5578,3776],{"class":3371},[3188,5580,5530],{"class":3367},[3188,5582,3376],{"class":3375},[3188,5584,5585],{"class":3190,"line":3273},[3188,5586,5587],{"class":3367},"  myworker:latest\n",[3114,5589,5590],{},[3118,5591,5592],{},"Потік даних:",[3306,5594,5595,5602,5608],{},[3309,5596,5597,5598,5601],{},"Користувач завантажує файл через API → файл зберігається у ",[3185,5599,5600],{},"/app/uploads"," (volume)",[3309,5603,5604,5605,5607],{},"Worker читає файли з ",[3185,5606,5600],{}," (той самий volume) → обробляє їх",[3309,5609,5610],{},"Обидва контейнери бачать одні й ті самі файли",[3645,5612,5613,5616],{},[3118,5614,5615],{},"Конкурентний доступ:"," Якщо кілька контейнерів пишуть у один volume одночасно, потрібна синхронізація на рівні додатку (file locking, черги). Docker не надає автоматичної синхронізації.",[3160,5618,5620],{"id":5619},"видалення-volumes","Видалення volumes",[3179,5622,5624],{"className":3348,"code":5623,"language":3350,"meta":3183,"style":3183},"# Видалити конкретний volume\ndocker volume rm postgres-data\n\n# Видалити всі невикористовувані volumes\ndocker volume prune\n\n# Видалити всі volumes (небезпечно!)\ndocker volume prune -a\n",[3185,5625,5626,5631,5641,5645,5650,5659,5663,5668],{"__ignoreMap":3183},[3188,5627,5628],{"class":3190,"line":3191},[3188,5629,5630],{"class":3357},"# Видалити конкретний volume\n",[3188,5632,5633,5635,5637,5639],{"class":3190,"line":3197},[3188,5634,3364],{"class":3363},[3188,5636,3738],{"class":3367},[3188,5638,3524],{"class":3367},[3188,5640,3744],{"class":3367},[3188,5642,5643],{"class":3190,"line":3203},[3188,5644,3407],{"emptyLinePlaceholder":3406},[3188,5646,5647],{"class":3190,"line":3209},[3188,5648,5649],{"class":3357},"# Видалити всі невикористовувані volumes\n",[3188,5651,5652,5654,5656],{"class":3190,"line":3215},[3188,5653,3364],{"class":3363},[3188,5655,3738],{"class":3367},[3188,5657,5658],{"class":3367}," prune\n",[3188,5660,5661],{"class":3190,"line":3221},[3188,5662,3407],{"emptyLinePlaceholder":3406},[3188,5664,5665],{"class":3190,"line":3227},[3188,5666,5667],{"class":3357},"# Видалити всі volumes (небезпечно!)\n",[3188,5669,5670,5672,5674,5677],{"class":3190,"line":3233},[3188,5671,3364],{"class":3363},[3188,5673,3738],{"class":3367},[3188,5675,5676],{"class":3367}," prune",[3188,5678,5679],{"class":3371}," -a\n",[3114,5681,5682,5685],{},[3118,5683,5684],{},"Важливо:"," Volume не можна видалити, якщо він використовується контейнером (навіть зупиненим).",[3179,5687,5689],{"className":3348,"code":5688,"language":3350,"meta":3183,"style":3183},"# Спочатку видалити контейнер\ndocker rm postgres\n\n# Потім видалити volume\ndocker volume rm postgres-data\n",[3185,5690,5691,5696,5704,5708,5713],{"__ignoreMap":3183},[3188,5692,5693],{"class":3190,"line":3191},[3188,5694,5695],{"class":3357},"# Спочатку видалити контейнер\n",[3188,5697,5698,5700,5702],{"class":3190,"line":3197},[3188,5699,3364],{"class":3363},[3188,5701,3524],{"class":3367},[3188,5703,5329],{"class":3367},[3188,5705,5706],{"class":3190,"line":3203},[3188,5707,3407],{"emptyLinePlaceholder":3406},[3188,5709,5710],{"class":3190,"line":3209},[3188,5711,5712],{"class":3357},"# Потім видалити volume\n",[3188,5714,5715,5717,5719,5721],{"class":3190,"line":3215},[3188,5716,3364],{"class":3363},[3188,5718,3738],{"class":3367},[3188,5720,3524],{"class":3367},[3188,5722,3744],{"class":3367},[3160,5724,5726],{"id":5725},"backup-та-restore-volumes","Backup та restore volumes",[3114,5728,5729],{},[3118,5730,5731],{},"Backup volume:",[3179,5733,5735],{"className":3348,"code":5734,"language":3350,"meta":3183,"style":3183},"# Створити backup volume у tar-архів\ndocker run --rm \\\n  -v postgres-data:/data \\\n  -v $(pwd):/backup \\\n  alpine \\\n  tar czf /backup/postgres-backup-$(date +%Y%m%d).tar.gz -C /data .\n",[3185,5736,5737,5742,5753,5762,5777,5784],{"__ignoreMap":3183},[3188,5738,5739],{"class":3190,"line":3191},[3188,5740,5741],{"class":3357},"# Створити backup volume у tar-архів\n",[3188,5743,5744,5746,5748,5751],{"class":3190,"line":3197},[3188,5745,3364],{"class":3363},[3188,5747,3368],{"class":3367},[3188,5749,5750],{"class":3371}," --rm",[3188,5752,3376],{"class":3375},[3188,5754,5755,5757,5760],{"class":3190,"line":3203},[3188,5756,3776],{"class":3371},[3188,5758,5759],{"class":3367}," postgres-data:/data",[3188,5761,3376],{"class":3375},[3188,5763,5764,5766,5768,5770,5772,5775],{"class":3190,"line":3209},[3188,5765,3776],{"class":3371},[3188,5767,3885],{"class":3884},[3188,5769,3888],{"class":3363},[3188,5771,3685],{"class":3884},[3188,5773,5774],{"class":3367},":/backup",[3188,5776,3376],{"class":3375},[3188,5778,5779,5782],{"class":3190,"line":3215},[3188,5780,5781],{"class":3367},"  alpine",[3188,5783,3376],{"class":3375},[3188,5785,5786,5789,5792,5795,5798,5801,5804,5806,5809,5812,5815],{"class":3190,"line":3221},[3188,5787,5788],{"class":3367},"  tar",[3188,5790,5791],{"class":3367}," czf",[3188,5793,5794],{"class":3367}," /backup/postgres-backup-",[3188,5796,5797],{"class":3884},"$(",[3188,5799,5800],{"class":3363},"date",[3188,5802,5803],{"class":3367}," +%Y%m%d",[3188,5805,3685],{"class":3884},[3188,5807,5808],{"class":3367},".tar.gz",[3188,5810,5811],{"class":3371}," -C",[3188,5813,5814],{"class":3367}," /data",[3188,5816,5817],{"class":3367}," .\n",[3114,5819,5820],{},[3118,5821,5822],{},"Пояснення:",[3306,5824,5825,5828,5838,5844,5849],{},[3309,5826,5827],{},"Запускаємо тимчасовий контейнер Alpine",[3309,5829,5830,5831,5834,5835],{},"Монтуємо volume ",[3185,5832,5833],{},"postgres-data"," у ",[3185,5836,5837],{},"/data",[3309,5839,5840,5841],{},"Монтуємо поточну директорію хоста у ",[3185,5842,5843],{},"/backup",[3309,5845,5846,5847],{},"Створюємо tar-архів з вмісту ",[3185,5848,5837],{},[3309,5850,5851,5852,3685],{},"Контейнер автоматично видаляється (",[3185,5853,5854],{},"--rm",[3114,5856,5857],{},[3118,5858,5859],{},"Restore volume:",[3179,5861,5863],{"className":3348,"code":5862,"language":3350,"meta":3183,"style":3183},"# Створити новий volume\ndocker volume create postgres-data-restored\n\n# Відновити дані з backup\ndocker run --rm \\\n  -v postgres-data-restored:/data \\\n  -v $(pwd):/backup \\\n  alpine \\\n  tar xzf /backup/postgres-backup-20260414.tar.gz -C /data\n",[3185,5864,5865,5870,5881,5885,5890,5900,5909,5923,5929],{"__ignoreMap":3183},[3188,5866,5867],{"class":3190,"line":3191},[3188,5868,5869],{"class":3357},"# Створити новий volume\n",[3188,5871,5872,5874,5876,5878],{"class":3190,"line":3197},[3188,5873,3364],{"class":3363},[3188,5875,3738],{"class":3367},[3188,5877,3741],{"class":3367},[3188,5879,5880],{"class":3367}," postgres-data-restored\n",[3188,5882,5883],{"class":3190,"line":3203},[3188,5884,3407],{"emptyLinePlaceholder":3406},[3188,5886,5887],{"class":3190,"line":3209},[3188,5888,5889],{"class":3357},"# Відновити дані з backup\n",[3188,5891,5892,5894,5896,5898],{"class":3190,"line":3215},[3188,5893,3364],{"class":3363},[3188,5895,3368],{"class":3367},[3188,5897,5750],{"class":3371},[3188,5899,3376],{"class":3375},[3188,5901,5902,5904,5907],{"class":3190,"line":3221},[3188,5903,3776],{"class":3371},[3188,5905,5906],{"class":3367}," postgres-data-restored:/data",[3188,5908,3376],{"class":3375},[3188,5910,5911,5913,5915,5917,5919,5921],{"class":3190,"line":3227},[3188,5912,3776],{"class":3371},[3188,5914,3885],{"class":3884},[3188,5916,3888],{"class":3363},[3188,5918,3685],{"class":3884},[3188,5920,5774],{"class":3367},[3188,5922,3376],{"class":3375},[3188,5924,5925,5927],{"class":3190,"line":3233},[3188,5926,5781],{"class":3367},[3188,5928,3376],{"class":3375},[3188,5930,5931,5933,5936,5939,5941],{"class":3190,"line":3239},[3188,5932,5788],{"class":3367},[3188,5934,5935],{"class":3367}," xzf",[3188,5937,5938],{"class":3367}," /backup/postgres-backup-20260414.tar.gz",[3188,5940,5811],{"class":3371},[3188,5942,5943],{"class":3367}," /data\n",[3160,5945,5947],{"id":5946},"volume-drivers","Volume drivers",[3114,5949,5950],{},"Docker підтримує різні драйвери для volumes:",[3114,5952,5953],{},[3118,5954,5955],{},"1. local (за замовчуванням)",[3114,5957,5958],{},"Зберігає дані на локальному диску хоста.",[3179,5960,5962],{"className":3348,"code":5961,"language":3350,"meta":3183,"style":3183},"docker volume create --driver local myvolume\n",[3185,5963,5964],{"__ignoreMap":3183},[3188,5965,5966,5968,5970,5972,5975,5977],{"class":3190,"line":3191},[3188,5967,3364],{"class":3363},[3188,5969,3738],{"class":3367},[3188,5971,3741],{"class":3367},[3188,5973,5974],{"class":3371}," --driver",[3188,5976,4448],{"class":3367},[3188,5978,5979],{"class":3367}," myvolume\n",[3114,5981,5982],{},[3118,5983,5984],{},"2. NFS (Network File System)",[3114,5986,5987],{},"Зберігає дані на віддаленому NFS-сервері.",[3179,5989,5991],{"className":3348,"code":5990,"language":3350,"meta":3183,"style":3183},"docker volume create \\\n  --driver local \\\n  --opt type=nfs \\\n  --opt o=addr=192.168.1.100,rw \\\n  --opt device=:/path/to/share \\\n  nfs-volume\n",[3185,5992,5993,6003,6011,6019,6027,6036],{"__ignoreMap":3183},[3188,5994,5995,5997,5999,6001],{"class":3190,"line":3191},[3188,5996,3364],{"class":3363},[3188,5998,3738],{"class":3367},[3188,6000,3741],{"class":3367},[3188,6002,3376],{"class":3375},[3188,6004,6005,6007,6009],{"class":3190,"line":3197},[3188,6006,4445],{"class":3371},[3188,6008,4448],{"class":3367},[3188,6010,3376],{"class":3375},[3188,6012,6013,6015,6017],{"class":3190,"line":3203},[3188,6014,4455],{"class":3371},[3188,6016,4458],{"class":3367},[3188,6018,3376],{"class":3375},[3188,6020,6021,6023,6025],{"class":3190,"line":3209},[3188,6022,4455],{"class":3371},[3188,6024,4467],{"class":3367},[3188,6026,3376],{"class":3375},[3188,6028,6029,6031,6034],{"class":3190,"line":3215},[3188,6030,4455],{"class":3371},[3188,6032,6033],{"class":3367}," device=:/path/to/share",[3188,6035,3376],{"class":3375},[3188,6037,6038],{"class":3190,"line":3221},[3188,6039,4483],{"class":3367},[3114,6041,6042],{},[3118,6043,6044],{},"3. Cloud drivers (AWS EBS, Azure Disk, GCP Persistent Disk)",[3114,6046,6047],{},"Інтеграція з хмарними сховищами через плагіни.",[3179,6049,6051],{"className":3348,"code":6050,"language":3350,"meta":3183,"style":3183},"# Приклад для AWS EBS (потрібен плагін)\ndocker volume create \\\n  --driver rexray/ebs \\\n  --opt size=10 \\\n  aws-volume\n",[3185,6052,6053,6058,6068,6077,6090],{"__ignoreMap":3183},[3188,6054,6055],{"class":3190,"line":3191},[3188,6056,6057],{"class":3357},"# Приклад для AWS EBS (потрібен плагін)\n",[3188,6059,6060,6062,6064,6066],{"class":3190,"line":3197},[3188,6061,3364],{"class":3363},[3188,6063,3738],{"class":3367},[3188,6065,3741],{"class":3367},[3188,6067,3376],{"class":3375},[3188,6069,6070,6072,6075],{"class":3190,"line":3203},[3188,6071,4445],{"class":3371},[3188,6073,6074],{"class":3367}," rexray/ebs",[3188,6076,3376],{"class":3375},[3188,6078,6079,6081,6084,6088],{"class":3190,"line":3209},[3188,6080,4455],{"class":3371},[3188,6082,6083],{"class":3367}," size=",[3188,6085,6087],{"class":6086},"sJj4R","10",[3188,6089,3376],{"class":3375},[3188,6091,6092],{"class":3190,"line":3215},[3188,6093,6094],{"class":3367},"  aws-volume\n",[3114,6096,6097],{},[3118,6098,6099],{},"4. Сторонні драйвери",[3620,6101,6102,6108,6114],{},[3309,6103,6104,6107],{},[3118,6105,6106],{},"Portworx"," — для Kubernetes",[3309,6109,6110,6113],{},[3118,6111,6112],{},"GlusterFS"," — розподілена файлова система",[3309,6115,6116,6119],{},[3118,6117,6118],{},"Ceph"," — об'єктне сховище",[3149,6121,6122,6123,6126],{},"Для більшості випадків достатньо ",[3185,6124,6125],{},"local"," драйвера. Cloud та мережеві драйвери потрібні для кластерних середовищ (Kubernetes, Docker Swarm).",[3160,6128,6130],{"id":6129},"анонімні-vs-іменовані-volumes","Анонімні vs іменовані volumes",[3114,6132,6133],{},[3118,6134,6135],{},"Іменований volume:",[3179,6137,6139],{"className":3348,"code":6138,"language":3350,"meta":3183,"style":3183},"docker run -v postgres-data:/var/lib/postgresql/data postgres:16\n",[3185,6140,6141],{"__ignoreMap":3183},[3188,6142,6143,6145,6147,6149,6151],{"class":3190,"line":3191},[3188,6144,3364],{"class":3363},[3188,6146,3368],{"class":3367},[3188,6148,4723],{"class":3371},[3188,6150,3779],{"class":3367},[3188,6152,6153],{"class":3367}," postgres:16\n",[3620,6155,6156,6162,6165],{},[3309,6157,6158,6159,3685],{},"✅ Легко ідентифікувати (",[3185,6160,6161],{},"docker volume ls",[3309,6163,6164],{},"✅ Можна перевикористовувати",[3309,6166,6167],{},"✅ Легко робити backup",[3114,6169,6170],{},[3118,6171,6172],{},"Анонімний volume:",[3179,6174,6176],{"className":3348,"code":6175,"language":3350,"meta":3183,"style":3183},"docker run -v /var/lib/postgresql/data postgres:16\n",[3185,6177,6178],{"__ignoreMap":3183},[3188,6179,6180,6182,6184,6186,6189],{"class":3190,"line":3191},[3188,6181,3364],{"class":3363},[3188,6183,3368],{"class":3367},[3188,6185,4723],{"class":3371},[3188,6187,6188],{"class":3367}," /var/lib/postgresql/data",[3188,6190,6153],{"class":3367},[3620,6192,6193,6199,6202],{},[3309,6194,6195,6196,3685],{},"⚠️ Docker генерує випадкову назву (напр. ",[3185,6197,6198],{},"abc123def456",[3309,6200,6201],{},"⚠️ Важко ідентифікувати",[3309,6203,6204],{},"⚠️ Залишаються після видалення контейнера (сміття)",[4278,6206,6207,6210],{},[3118,6208,6209],{},"Завжди використовуйте іменовані volumes для production!"," Анонімні volumes корисні лише для тимчасових експериментів.",[3153,6212],{},[3109,6214,6216],{"id":6215},"bind-mounts-монтування-директорій-хоста","Bind Mounts: монтування директорій хоста",[3160,6218,6220],{"id":6219},"що-таке-bind-mounts","Що таке Bind Mounts?",[3114,6222,6223,6226],{},[3118,6224,6225],{},"Bind Mount"," — це пряме монтування файлу або директорії з хост-системи в контейнер. На відміну від volumes, bind mounts не керуються Docker — ви повністю контролюєте розташування файлів на хості.",[3114,6228,6229],{},[3118,6230,4319],{},[3179,6232,6234],{"className":3348,"code":6233,"language":3350,"meta":3183,"style":3183},"# Короткий синтаксис\ndocker run -v HOST_PATH:CONTAINER_PATH [OPTIONS] IMAGE\n\n# Довгий синтаксис\ndocker run --mount type=bind,source=HOST_PATH,target=CONTAINER_PATH [OPTIONS] IMAGE\n",[3185,6235,6236,6241,6254,6258,6263],{"__ignoreMap":3183},[3188,6237,6238],{"class":3190,"line":3191},[3188,6239,6240],{"class":3357},"# Короткий синтаксис\n",[3188,6242,6243,6245,6247,6249,6252],{"class":3190,"line":3197},[3188,6244,3364],{"class":3363},[3188,6246,3368],{"class":3367},[3188,6248,4723],{"class":3371},[3188,6250,6251],{"class":3367}," HOST_PATH:CONTAINER_PATH",[3188,6253,4729],{"class":3884},[3188,6255,6256],{"class":3190,"line":3203},[3188,6257,3407],{"emptyLinePlaceholder":3406},[3188,6259,6260],{"class":3190,"line":3209},[3188,6261,6262],{"class":3357},"# Довгий синтаксис\n",[3188,6264,6265,6267,6269,6271,6274],{"class":3190,"line":3215},[3188,6266,3364],{"class":3363},[3188,6268,3368],{"class":3367},[3188,6270,4876],{"class":3371},[3188,6272,6273],{"class":3367}," type=bind,source=HOST_PATH,target=CONTAINER_PATH",[3188,6275,4729],{"class":3884},[3160,6277,6279],{"id":6278},"приклади-використання","Приклади використання",[3114,6281,6282],{},[3118,6283,6284],{},"1. Монтування поточної директорії:",[3179,6286,6288],{"className":3348,"code":6287,"language":3350,"meta":3183,"style":3183},"# Монтувати поточну директорію в /app\ndocker run -d \\\n  --name myapp-dev \\\n  -v $(pwd):/app \\\n  myapp:latest\n\n# Або з --mount\ndocker run -d \\\n  --name myapp-dev \\\n  --mount type=bind,source=$(pwd),target=/app \\\n  myapp:latest\n",[3185,6289,6290,6295,6305,6313,6327,6331,6335,6340,6350,6358,6376],{"__ignoreMap":3183},[3188,6291,6292],{"class":3190,"line":3191},[3188,6293,6294],{"class":3357},"# Монтувати поточну директорію в /app\n",[3188,6296,6297,6299,6301,6303],{"class":3190,"line":3197},[3188,6298,3364],{"class":3363},[3188,6300,3368],{"class":3367},[3188,6302,3372],{"class":3371},[3188,6304,3376],{"class":3375},[3188,6306,6307,6309,6311],{"class":3190,"line":3203},[3188,6308,3381],{"class":3371},[3188,6310,3875],{"class":3367},[3188,6312,3376],{"class":3375},[3188,6314,6315,6317,6319,6321,6323,6325],{"class":3190,"line":3209},[3188,6316,3776],{"class":3371},[3188,6318,3885],{"class":3884},[3188,6320,3888],{"class":3363},[3188,6322,3685],{"class":3884},[3188,6324,3893],{"class":3367},[3188,6326,3376],{"class":3375},[3188,6328,6329],{"class":3190,"line":3215},[3188,6330,3900],{"class":3367},[3188,6332,6333],{"class":3190,"line":3221},[3188,6334,3407],{"emptyLinePlaceholder":3406},[3188,6336,6337],{"class":3190,"line":3227},[3188,6338,6339],{"class":3357},"# Або з --mount\n",[3188,6341,6342,6344,6346,6348],{"class":3190,"line":3233},[3188,6343,3364],{"class":3363},[3188,6345,3368],{"class":3367},[3188,6347,3372],{"class":3371},[3188,6349,3376],{"class":3375},[3188,6351,6352,6354,6356],{"class":3190,"line":3239},[3188,6353,3381],{"class":3371},[3188,6355,3875],{"class":3367},[3188,6357,3376],{"class":3375},[3188,6359,6360,6362,6365,6367,6369,6371,6374],{"class":3190,"line":3245},[3188,6361,4918],{"class":3371},[3188,6363,6364],{"class":3367}," type=bind,source=",[3188,6366,5797],{"class":3884},[3188,6368,3888],{"class":3363},[3188,6370,3685],{"class":3884},[3188,6372,6373],{"class":3367},",target=/app",[3188,6375,3376],{"class":3375},[3188,6377,6378],{"class":3190,"line":3250},[3188,6379,3900],{"class":3367},[3114,6381,6382],{},[3118,6383,6384],{},"2. Read-only монтування:",[3179,6386,6388],{"className":3348,"code":6387,"language":3350,"meta":3183,"style":3183},"# Монтувати конфігурацію read-only\ndocker run -d \\\n  --name nginx \\\n  -v $(pwd)/nginx.conf:/etc/nginx/nginx.conf:ro \\\n  nginx:alpine\n\n# Або з --mount\ndocker run -d \\\n  --name nginx \\\n  --mount type=bind,source=$(pwd)/nginx.conf,target=/etc/nginx/nginx.conf,readonly \\\n  nginx:alpine\n",[3185,6389,6390,6395,6405,6414,6429,6434,6438,6442,6452,6460,6477],{"__ignoreMap":3183},[3188,6391,6392],{"class":3190,"line":3191},[3188,6393,6394],{"class":3357},"# Монтувати конфігурацію read-only\n",[3188,6396,6397,6399,6401,6403],{"class":3190,"line":3197},[3188,6398,3364],{"class":3363},[3188,6400,3368],{"class":3367},[3188,6402,3372],{"class":3371},[3188,6404,3376],{"class":3375},[3188,6406,6407,6409,6412],{"class":3190,"line":3203},[3188,6408,3381],{"class":3371},[3188,6410,6411],{"class":3367}," nginx",[3188,6413,3376],{"class":3375},[3188,6415,6416,6418,6420,6422,6424,6427],{"class":3190,"line":3209},[3188,6417,3776],{"class":3371},[3188,6419,3885],{"class":3884},[3188,6421,3888],{"class":3363},[3188,6423,3685],{"class":3884},[3188,6425,6426],{"class":3367},"/nginx.conf:/etc/nginx/nginx.conf:ro",[3188,6428,3376],{"class":3375},[3188,6430,6431],{"class":3190,"line":3215},[3188,6432,6433],{"class":3367},"  nginx:alpine\n",[3188,6435,6436],{"class":3190,"line":3221},[3188,6437,3407],{"emptyLinePlaceholder":3406},[3188,6439,6440],{"class":3190,"line":3227},[3188,6441,6339],{"class":3357},[3188,6443,6444,6446,6448,6450],{"class":3190,"line":3233},[3188,6445,3364],{"class":3363},[3188,6447,3368],{"class":3367},[3188,6449,3372],{"class":3371},[3188,6451,3376],{"class":3375},[3188,6453,6454,6456,6458],{"class":3190,"line":3239},[3188,6455,3381],{"class":3371},[3188,6457,6411],{"class":3367},[3188,6459,3376],{"class":3375},[3188,6461,6462,6464,6466,6468,6470,6472,6475],{"class":3190,"line":3245},[3188,6463,4918],{"class":3371},[3188,6465,6364],{"class":3367},[3188,6467,5797],{"class":3884},[3188,6469,3888],{"class":3363},[3188,6471,3685],{"class":3884},[3188,6473,6474],{"class":3367},"/nginx.conf,target=/etc/nginx/nginx.conf,readonly",[3188,6476,3376],{"class":3375},[3188,6478,6479],{"class":3190,"line":3250},[3188,6480,6433],{"class":3367},[3114,6482,6483],{},[3118,6484,6485],{},"3. Монтування окремого файлу:",[3179,6487,6489],{"className":3348,"code":6488,"language":3350,"meta":3183,"style":3183},"# Монтувати лише один файл\ndocker run -d \\\n  --name app \\\n  -v $(pwd)/appsettings.json:/app/appsettings.json:ro \\\n  myapp:latest\n",[3185,6490,6491,6496,6506,6514,6529],{"__ignoreMap":3183},[3188,6492,6493],{"class":3190,"line":3191},[3188,6494,6495],{"class":3357},"# Монтувати лише один файл\n",[3188,6497,6498,6500,6502,6504],{"class":3190,"line":3197},[3188,6499,3364],{"class":3363},[3188,6501,3368],{"class":3367},[3188,6503,3372],{"class":3371},[3188,6505,3376],{"class":3375},[3188,6507,6508,6510,6512],{"class":3190,"line":3203},[3188,6509,3381],{"class":3371},[3188,6511,4799],{"class":3367},[3188,6513,3376],{"class":3375},[3188,6515,6516,6518,6520,6522,6524,6527],{"class":3190,"line":3209},[3188,6517,3776],{"class":3371},[3188,6519,3885],{"class":3884},[3188,6521,3888],{"class":3363},[3188,6523,3685],{"class":3884},[3188,6525,6526],{"class":3367},"/appsettings.json:/app/appsettings.json:ro",[3188,6528,3376],{"class":3375},[3188,6530,6531],{"class":3190,"line":3215},[3188,6532,3900],{"class":3367},[3160,6534,6536],{"id":6535},"hot-reload-для-net-додатків","Hot-reload для .NET додатків",[3114,6538,6539],{},"Bind mounts ідеально підходять для розробки — зміни коду на хості одразу видимі в контейнері.",[3114,6541,6542],{},[3118,6543,6544],{},"Dockerfile для розробки:",[3179,6546,6550],{"className":6547,"code":6548,"language":6549,"meta":3183,"style":3183},"language-dockerfile shiki shiki-themes light-plus dark-plus dark-plus","FROM mcr.microsoft.com/dotnet/sdk:8.0\n\nWORKDIR /app\n\n# Копіюємо лише .csproj для restore (кешування)\nCOPY *.csproj .\nRUN dotnet restore\n\n# Код буде монтуватися через bind mount\n# Тому не копіюємо його в образ\n\n# Запускаємо з hot-reload\nENTRYPOINT [\"dotnet\", \"watch\", \"run\", \"--no-launch-profile\"]\n","dockerfile",[3185,6551,6552,6560,6564,6572,6576,6581,6589,6597,6601,6606,6611,6615,6620],{"__ignoreMap":3183},[3188,6553,6554,6557],{"class":3190,"line":3191},[3188,6555,6556],{"class":3371},"FROM",[3188,6558,6559],{"class":3884}," mcr.microsoft.com/dotnet/sdk:8.0\n",[3188,6561,6562],{"class":3190,"line":3197},[3188,6563,3407],{"emptyLinePlaceholder":3406},[3188,6565,6566,6569],{"class":3190,"line":3203},[3188,6567,6568],{"class":3371},"WORKDIR",[3188,6570,6571],{"class":3884}," /app\n",[3188,6573,6574],{"class":3190,"line":3209},[3188,6575,3407],{"emptyLinePlaceholder":3406},[3188,6577,6578],{"class":3190,"line":3215},[3188,6579,6580],{"class":3357},"# Копіюємо лише .csproj для restore (кешування)\n",[3188,6582,6583,6586],{"class":3190,"line":3221},[3188,6584,6585],{"class":3371},"COPY",[3188,6587,6588],{"class":3884}," *.csproj .\n",[3188,6590,6591,6594],{"class":3190,"line":3227},[3188,6592,6593],{"class":3371},"RUN",[3188,6595,6596],{"class":3884}," dotnet restore\n",[3188,6598,6599],{"class":3190,"line":3233},[3188,6600,3407],{"emptyLinePlaceholder":3406},[3188,6602,6603],{"class":3190,"line":3239},[3188,6604,6605],{"class":3357},"# Код буде монтуватися через bind mount\n",[3188,6607,6608],{"class":3190,"line":3245},[3188,6609,6610],{"class":3357},"# Тому не копіюємо його в образ\n",[3188,6612,6613],{"class":3190,"line":3250},[3188,6614,3407],{"emptyLinePlaceholder":3406},[3188,6616,6617],{"class":3190,"line":3255},[3188,6618,6619],{"class":3357},"# Запускаємо з hot-reload\n",[3188,6621,6622,6625,6628,6631,6634,6637,6639,6642,6644,6647],{"class":3190,"line":3261},[3188,6623,6624],{"class":3371},"ENTRYPOINT",[3188,6626,6627],{"class":3884}," [",[3188,6629,6630],{"class":3367},"\"dotnet\"",[3188,6632,6633],{"class":3884},", ",[3188,6635,6636],{"class":3367},"\"watch\"",[3188,6638,6633],{"class":3884},[3188,6640,6641],{"class":3367},"\"run\"",[3188,6643,6633],{"class":3884},[3188,6645,6646],{"class":3367},"\"--no-launch-profile\"",[3188,6648,4666],{"class":3884},[3114,6650,6651],{},[3118,6652,6653],{},"Запуск з bind mount:",[3179,6655,6657],{"className":3348,"code":6656,"language":3350,"meta":3183,"style":3183},"# Монтувати код для hot-reload\ndocker run -d \\\n  --name myapp-dev \\\n  -v $(pwd):/app \\\n  -p 8080:8080 \\\n  -e ASPNETCORE_ENVIRONMENT=Development \\\n  myapp-dev:latest\n",[3185,6658,6659,6664,6674,6682,6696,6704,6713],{"__ignoreMap":3183},[3188,6660,6661],{"class":3190,"line":3191},[3188,6662,6663],{"class":3357},"# Монтувати код для hot-reload\n",[3188,6665,6666,6668,6670,6672],{"class":3190,"line":3197},[3188,6667,3364],{"class":3363},[3188,6669,3368],{"class":3367},[3188,6671,3372],{"class":3371},[3188,6673,3376],{"class":3375},[3188,6675,6676,6678,6680],{"class":3190,"line":3203},[3188,6677,3381],{"class":3371},[3188,6679,3875],{"class":3367},[3188,6681,3376],{"class":3375},[3188,6683,6684,6686,6688,6690,6692,6694],{"class":3190,"line":3209},[3188,6685,3776],{"class":3371},[3188,6687,3885],{"class":3884},[3188,6689,3888],{"class":3363},[3188,6691,3685],{"class":3884},[3188,6693,3893],{"class":3367},[3188,6695,3376],{"class":3375},[3188,6697,6698,6700,6702],{"class":3190,"line":3215},[3188,6699,5116],{"class":3371},[3188,6701,5539],{"class":3367},[3188,6703,3376],{"class":3375},[3188,6705,6706,6708,6711],{"class":3190,"line":3221},[3188,6707,3391],{"class":3371},[3188,6709,6710],{"class":3367}," ASPNETCORE_ENVIRONMENT=Development",[3188,6712,3376],{"class":3375},[3188,6714,6715],{"class":3190,"line":3227},[3188,6716,6717],{"class":3367},"  myapp-dev:latest\n",[3114,6719,6720],{},[3118,6721,6722],{},"Тепер:",[3306,6724,6725,6732,6738],{},[3309,6726,6727,6728,6731],{},"Змініть ",[3185,6729,6730],{},"Program.cs"," на хості",[3309,6733,6734,6737],{},[3185,6735,6736],{},"dotnet watch"," автоматично перекомпілює код",[3309,6739,6740],{},"Зміни одразу видимі без перебудови образу",[3114,6742,6743],{},[3118,6744,6745],{},"Логи:",[3179,6747,6752],{"className":6748,"code":6750,"language":6751},[6749],"language-text","watch : Started\ninfo: Microsoft.Hosting.Lifetime[14]\n      Now listening on: http://[::]:8080\nwatch : File changed: /app/Program.cs\nwatch : Building...\nwatch : Started\n","text",[3185,6753,6750],{"__ignoreMap":3183},[3160,6755,6757],{"id":6756},"проблеми-з-правами-доступу","Проблеми з правами доступу",[3114,6759,6760,6762],{},[3118,6761,3331],{}," Файли, створені контейнером, можуть мати неправильні права доступу на хості.",[3179,6764,6766],{"className":3348,"code":6765,"language":3350,"meta":3183,"style":3183},"# Запустити контейнер, який створює файл\ndocker run --rm \\\n  -v $(pwd):/data \\\n  alpine \\\n  sh -c \"echo 'test' > /data/file.txt\"\n\n# Перевірити власника на хості\nls -l file.txt\n# -rw-r--r-- 1 root root 5 Apr 14 11:30 file.txt\n",[3185,6767,6768,6773,6783,6798,6804,6814,6818,6823,6834],{"__ignoreMap":3183},[3188,6769,6770],{"class":3190,"line":3191},[3188,6771,6772],{"class":3357},"# Запустити контейнер, який створює файл\n",[3188,6774,6775,6777,6779,6781],{"class":3190,"line":3197},[3188,6776,3364],{"class":3363},[3188,6778,3368],{"class":3367},[3188,6780,5750],{"class":3371},[3188,6782,3376],{"class":3375},[3188,6784,6785,6787,6789,6791,6793,6796],{"class":3190,"line":3203},[3188,6786,3776],{"class":3371},[3188,6788,3885],{"class":3884},[3188,6790,3888],{"class":3363},[3188,6792,3685],{"class":3884},[3188,6794,6795],{"class":3367},":/data",[3188,6797,3376],{"class":3375},[3188,6799,6800,6802],{"class":3190,"line":3209},[3188,6801,5781],{"class":3367},[3188,6803,3376],{"class":3375},[3188,6805,6806,6809,6811],{"class":3190,"line":3215},[3188,6807,6808],{"class":3367},"  sh",[3188,6810,3455],{"class":3371},[3188,6812,6813],{"class":3367}," \"echo 'test' > /data/file.txt\"\n",[3188,6815,6816],{"class":3190,"line":3221},[3188,6817,3407],{"emptyLinePlaceholder":3406},[3188,6819,6820],{"class":3190,"line":3227},[3188,6821,6822],{"class":3357},"# Перевірити власника на хості\n",[3188,6824,6825,6828,6831],{"class":3190,"line":3233},[3188,6826,6827],{"class":3363},"ls",[3188,6829,6830],{"class":3371}," -l",[3188,6832,6833],{"class":3367}," file.txt\n",[3188,6835,6836],{"class":3190,"line":3239},[3188,6837,6838],{"class":3357},"# -rw-r--r-- 1 root root 5 Apr 14 11:30 file.txt\n",[3114,6840,6841,6844],{},[3118,6842,6843],{},"Файл належить root!"," Це може створити проблеми, якщо ваш користувач не має прав root.",[3114,6846,6847],{},[3118,6848,6849],{},"Рішення 1: Запуск від non-root користувача",[3179,6851,6853],{"className":3348,"code":6852,"language":3350,"meta":3183,"style":3183},"# Запустити від поточного користувача\ndocker run --rm \\\n  -v $(pwd):/data \\\n  -u $(id -u):$(id -g) \\\n  alpine \\\n  sh -c \"echo 'test' > /data/file.txt\"\n\n# Тепер файл належить вашому користувачу\nls -l file.txt\n# -rw-r--r-- 1 youruser yourgroup 5 Apr 14 11:30 file.txt\n",[3185,6854,6855,6860,6870,6884,6914,6920,6928,6932,6937,6945],{"__ignoreMap":3183},[3188,6856,6857],{"class":3190,"line":3191},[3188,6858,6859],{"class":3357},"# Запустити від поточного користувача\n",[3188,6861,6862,6864,6866,6868],{"class":3190,"line":3197},[3188,6863,3364],{"class":3363},[3188,6865,3368],{"class":3367},[3188,6867,5750],{"class":3371},[3188,6869,3376],{"class":3375},[3188,6871,6872,6874,6876,6878,6880,6882],{"class":3190,"line":3203},[3188,6873,3776],{"class":3371},[3188,6875,3885],{"class":3884},[3188,6877,3888],{"class":3363},[3188,6879,3685],{"class":3884},[3188,6881,6795],{"class":3367},[3188,6883,3376],{"class":3375},[3188,6885,6886,6889,6891,6894,6897,6899,6901,6903,6905,6908,6911],{"class":3190,"line":3209},[3188,6887,6888],{"class":3371},"  -u",[3188,6890,3885],{"class":3884},[3188,6892,6893],{"class":3363},"id",[3188,6895,6896],{"class":3371}," -u",[3188,6898,3685],{"class":3884},[3188,6900,4563],{"class":3367},[3188,6902,5797],{"class":3884},[3188,6904,6893],{"class":3363},[3188,6906,6907],{"class":3371}," -g",[3188,6909,6910],{"class":3884},") ",[3188,6912,6913],{"class":3375},"\\\n",[3188,6915,6916,6918],{"class":3190,"line":3215},[3188,6917,5781],{"class":3367},[3188,6919,3376],{"class":3375},[3188,6921,6922,6924,6926],{"class":3190,"line":3221},[3188,6923,6808],{"class":3367},[3188,6925,3455],{"class":3371},[3188,6927,6813],{"class":3367},[3188,6929,6930],{"class":3190,"line":3227},[3188,6931,3407],{"emptyLinePlaceholder":3406},[3188,6933,6934],{"class":3190,"line":3233},[3188,6935,6936],{"class":3357},"# Тепер файл належить вашому користувачу\n",[3188,6938,6939,6941,6943],{"class":3190,"line":3239},[3188,6940,6827],{"class":3363},[3188,6942,6830],{"class":3371},[3188,6944,6833],{"class":3367},[3188,6946,6947],{"class":3190,"line":3245},[3188,6948,6949],{"class":3357},"# -rw-r--r-- 1 youruser yourgroup 5 Apr 14 11:30 file.txt\n",[3114,6951,6952],{},[3118,6953,6954],{},"Рішення 2: Налаштування USER в Dockerfile",[3179,6956,6958],{"className":6547,"code":6957,"language":6549,"meta":3183,"style":3183},"FROM mcr.microsoft.com/dotnet/sdk:8.0\n\n# Створити користувача з тим самим UID, що на хості\nARG USER_ID=1000\nARG GROUP_ID=1000\n\nRUN addgroup -g ${GROUP_ID} appuser && \\\n    adduser -u ${USER_ID} -G appuser -s /bin/sh -D appuser\n\nUSER appuser\n\nWORKDIR /app\n",[3185,6959,6960,6966,6970,6975,6983,6990,6994,7001,7006,7010,7018,7022],{"__ignoreMap":3183},[3188,6961,6962,6964],{"class":3190,"line":3191},[3188,6963,6556],{"class":3371},[3188,6965,6559],{"class":3884},[3188,6967,6968],{"class":3190,"line":3197},[3188,6969,3407],{"emptyLinePlaceholder":3406},[3188,6971,6972],{"class":3190,"line":3203},[3188,6973,6974],{"class":3357},"# Створити користувача з тим самим UID, що на хості\n",[3188,6976,6977,6980],{"class":3190,"line":3209},[3188,6978,6979],{"class":3371},"ARG",[3188,6981,6982],{"class":3884}," USER_ID=1000\n",[3188,6984,6985,6987],{"class":3190,"line":3215},[3188,6986,6979],{"class":3371},[3188,6988,6989],{"class":3884}," GROUP_ID=1000\n",[3188,6991,6992],{"class":3190,"line":3221},[3188,6993,3407],{"emptyLinePlaceholder":3406},[3188,6995,6996,6998],{"class":3190,"line":3227},[3188,6997,6593],{"class":3371},[3188,6999,7000],{"class":3884}," addgroup -g ${GROUP_ID} appuser && \\\n",[3188,7002,7003],{"class":3190,"line":3233},[3188,7004,7005],{"class":3884},"    adduser -u ${USER_ID} -G appuser -s /bin/sh -D appuser\n",[3188,7007,7008],{"class":3190,"line":3239},[3188,7009,3407],{"emptyLinePlaceholder":3406},[3188,7011,7012,7015],{"class":3190,"line":3245},[3188,7013,7014],{"class":3371},"USER",[3188,7016,7017],{"class":3884}," appuser\n",[3188,7019,7020],{"class":3190,"line":3250},[3188,7021,3407],{"emptyLinePlaceholder":3406},[3188,7023,7024,7026],{"class":3190,"line":3255},[3188,7025,6568],{"class":3371},[3188,7027,6571],{"class":3884},[3114,7029,7030],{},[3118,7031,7032],{},"Збірка з передачею UID:",[3179,7034,7036],{"className":3348,"code":7035,"language":3350,"meta":3183,"style":3183},"docker build \\\n  --build-arg USER_ID=$(id -u) \\\n  --build-arg GROUP_ID=$(id -g) \\\n  -t myapp-dev .\n",[3185,7037,7038,7047,7065,7082],{"__ignoreMap":3183},[3188,7039,7040,7042,7045],{"class":3190,"line":3191},[3188,7041,3364],{"class":3363},[3188,7043,7044],{"class":3367}," build",[3188,7046,3376],{"class":3375},[3188,7048,7049,7052,7055,7057,7059,7061,7063],{"class":3190,"line":3197},[3188,7050,7051],{"class":3371},"  --build-arg",[3188,7053,7054],{"class":3367}," USER_ID=",[3188,7056,5797],{"class":3884},[3188,7058,6893],{"class":3363},[3188,7060,6896],{"class":3371},[3188,7062,6910],{"class":3884},[3188,7064,6913],{"class":3375},[3188,7066,7067,7069,7072,7074,7076,7078,7080],{"class":3190,"line":3203},[3188,7068,7051],{"class":3371},[3188,7070,7071],{"class":3367}," GROUP_ID=",[3188,7073,5797],{"class":3884},[3188,7075,6893],{"class":3363},[3188,7077,6907],{"class":3371},[3188,7079,6910],{"class":3884},[3188,7081,6913],{"class":3375},[3188,7083,7084,7087,7089],{"class":3190,"line":3209},[3188,7085,7086],{"class":3371},"  -t",[3188,7088,3875],{"class":3367},[3188,7090,5817],{"class":3367},[3160,7092,7094],{"id":7093},"різниця-між-volumes-та-bind-mounts","Різниця між Volumes та Bind Mounts",[4004,7096,7097,7107],{},[4007,7098,7099],{},[4010,7100,7101,7103,7105],{},[4013,7102,4016],{"align":4015},[4013,7104,3138],{"align":4015},[4013,7106,3142],{"align":4015},[4025,7108,7109,7119,7131,7144,7158,7169,7180,7189,7199],{},[4010,7110,7111,7114,7116],{},[4030,7112,7113],{"align":4015},"Керування",[4030,7115,2659],{"align":4015},[4030,7117,7118],{"align":4015},"Користувач",[4010,7120,7121,7124,7128],{},[4030,7122,7123],{"align":4015},"Розташування",[4030,7125,7126],{"align":4015},[3185,7127,3684],{},[4030,7129,7130],{"align":4015},"Будь-де на хості",[4010,7132,7133,7136,7141],{},[4030,7134,7135],{"align":4015},"Створення",[4030,7137,7138],{"align":4015},[3185,7139,7140],{},"docker volume create",[4030,7142,7143],{"align":4015},"Автоматично при монтуванні",[4010,7145,7146,7149,7155],{},[4030,7147,7148],{"align":4015},"Backup",[4030,7150,7151,7154],{"align":4015},[3185,7152,7153],{},"docker run"," з tar",[4030,7156,7157],{"align":4015},"Звичайні інструменти хоста",[4010,7159,7160,7163,7166],{},[4030,7161,7162],{"align":4015},"Права доступу",[4030,7164,7165],{"align":4015},"Керуються Docker",[4030,7167,7168],{"align":4015},"Залежать від хоста",[4010,7170,7171,7174,7177],{},[4030,7172,7173],{"align":4015},"Продуктивність",[4030,7175,7176],{"align":4015},"Оптимізована",[4030,7178,7179],{"align":4015},"Залежить від FS хоста",[4010,7181,7182,7184,7186],{},[4030,7183,4082],{"align":4015},[4030,7185,4035],{"align":4015},[4030,7187,7188],{"align":4015},"⚠️ (шляхи відрізняються)",[4010,7190,7191,7193,7196],{},[4030,7192,4106],{"align":4015},[4030,7194,7195],{"align":4015},"✅ Рекомендовано",[4030,7197,7198],{"align":4015},"⚠️ Обережно",[4010,7200,7201,7203,7205],{},[4030,7202,4118],{"align":4015},[4030,7204,4035],{"align":4015},[4030,7206,7195],{"align":4015},[3645,7208,7209,7215,7228],{},[3114,7210,7211,7214],{},[3118,7212,7213],{},"Bind Mounts у production:"," Уникайте bind mounts у production, бо:",[3620,7216,7217,7220,7222,7225],{},[3309,7218,7219],{},"Залежність від структури хост-системи",[3309,7221,6757],{},[3309,7223,7224],{},"Складність міграції між серверами",[3309,7226,7227],{},"Менша ізоляція (безпека)",[3114,7229,7230],{},"Використовуйте volumes для production та bind mounts лише для розробки.",[3153,7232],{},[3109,7234,7236],{"id":7235},"tmpfs-mounts-тимчасове-сховище-в-памяті","tmpfs Mounts: тимчасове сховище в пам'яті",[3160,7238,7240],{"id":7239},"що-таке-tmpfs","Що таке tmpfs?",[3114,7242,7243,7245],{},[3118,7244,3146],{}," — це файлова система в оперативній пам'яті (RAM), яка не зберігається на диску. Дані існують лише поки працює контейнер.",[3114,7247,7248],{},[3118,7249,3673],{},[3620,7251,7252,7255,7257,7260,7262,7264],{},[3309,7253,7254],{},"✅ Дуже швидке (RAM швидше за SSD у 10-100 разів)",[3309,7256,3924],{},[3309,7258,7259],{},"✅ Автоматично очищається при зупинці",[3309,7261,3927],{},[3309,7263,3930],{},[3309,7265,3933],{},[3114,7267,7268],{},[3118,7269,4319],{},[3179,7271,7273],{"className":3348,"code":7272,"language":3350,"meta":3183,"style":3183},"# Короткий синтаксис\ndocker run --tmpfs CONTAINER_PATH:OPTIONS IMAGE\n\n# Довгий синтаксис\ndocker run --mount type=tmpfs,target=CONTAINER_PATH,tmpfs-size=SIZE IMAGE\n",[3185,7274,7275,7279,7294,7298,7302],{"__ignoreMap":3183},[3188,7276,7277],{"class":3190,"line":3191},[3188,7278,6240],{"class":3357},[3188,7280,7281,7283,7285,7288,7291],{"class":3190,"line":3197},[3188,7282,3364],{"class":3363},[3188,7284,3368],{"class":3367},[3188,7286,7287],{"class":3371}," --tmpfs",[3188,7289,7290],{"class":3367}," CONTAINER_PATH:OPTIONS",[3188,7292,7293],{"class":3367}," IMAGE\n",[3188,7295,7296],{"class":3190,"line":3203},[3188,7297,3407],{"emptyLinePlaceholder":3406},[3188,7299,7300],{"class":3190,"line":3209},[3188,7301,6262],{"class":3357},[3188,7303,7304,7306,7308,7310,7313],{"class":3190,"line":3215},[3188,7305,3364],{"class":3363},[3188,7307,3368],{"class":3367},[3188,7309,4876],{"class":3371},[3188,7311,7312],{"class":3367}," type=tmpfs,target=CONTAINER_PATH,tmpfs-size=SIZE",[3188,7314,7293],{"class":3367},[3160,7316,6279],{"id":7317},"приклади-використання-1",[3114,7319,7320],{},[3118,7321,7322],{},"1. Тимчасові файли:",[3179,7324,7326],{"className":3348,"code":7325,"language":3350,"meta":3183,"style":3183},"# Монтувати /tmp у RAM\ndocker run -d \\\n  --name myapp \\\n  --tmpfs /tmp:rw,size=100m \\\n  myapp:latest\n",[3185,7327,7328,7333,7343,7351,7359],{"__ignoreMap":3183},[3188,7329,7330],{"class":3190,"line":3191},[3188,7331,7332],{"class":3357},"# Монтувати /tmp у RAM\n",[3188,7334,7335,7337,7339,7341],{"class":3190,"line":3197},[3188,7336,3364],{"class":3363},[3188,7338,3368],{"class":3367},[3188,7340,3372],{"class":3371},[3188,7342,3376],{"class":3375},[3188,7344,7345,7347,7349],{"class":3190,"line":3203},[3188,7346,3381],{"class":3371},[3188,7348,3982],{"class":3367},[3188,7350,3376],{"class":3375},[3188,7352,7353,7355,7357],{"class":3190,"line":3209},[3188,7354,3989],{"class":3371},[3188,7356,3992],{"class":3367},[3188,7358,3376],{"class":3375},[3188,7360,7361],{"class":3190,"line":3215},[3188,7362,3900],{"class":3367},[3114,7364,7365],{},[3118,7366,7367],{},"2. Кеш:",[3179,7369,7371],{"className":3348,"code":7370,"language":3350,"meta":3183,"style":3183},"# Монтувати директорію кешу у RAM\ndocker run -d \\\n  --name myapp \\\n  --tmpfs /app/cache:rw,size=200m,mode=1777 \\\n  myapp:latest\n",[3185,7372,7373,7378,7388,7396,7408],{"__ignoreMap":3183},[3188,7374,7375],{"class":3190,"line":3191},[3188,7376,7377],{"class":3357},"# Монтувати директорію кешу у RAM\n",[3188,7379,7380,7382,7384,7386],{"class":3190,"line":3197},[3188,7381,3364],{"class":3363},[3188,7383,3368],{"class":3367},[3188,7385,3372],{"class":3371},[3188,7387,3376],{"class":3375},[3188,7389,7390,7392,7394],{"class":3190,"line":3203},[3188,7391,3381],{"class":3371},[3188,7393,3982],{"class":3367},[3188,7395,3376],{"class":3375},[3188,7397,7398,7400,7403,7406],{"class":3190,"line":3209},[3188,7399,3989],{"class":3371},[3188,7401,7402],{"class":3367}," /app/cache:rw,size=200m,mode=",[3188,7404,7405],{"class":6086},"1777",[3188,7407,3376],{"class":3375},[3188,7409,7410],{"class":3190,"line":3215},[3188,7411,3900],{"class":3367},[3114,7413,7414],{},[3118,7415,7416],{},"3. Секрети (паролі, токени):",[3179,7418,7420],{"className":3348,"code":7419,"language":3350,"meta":3183,"style":3183},"# Монтувати директорію для секретів у RAM\ndocker run -d \\\n  --name myapp \\\n  --tmpfs /run/secrets:rw,size=10m,mode=0700 \\\n  myapp:latest\n",[3185,7421,7422,7427,7437,7445,7457],{"__ignoreMap":3183},[3188,7423,7424],{"class":3190,"line":3191},[3188,7425,7426],{"class":3357},"# Монтувати директорію для секретів у RAM\n",[3188,7428,7429,7431,7433,7435],{"class":3190,"line":3197},[3188,7430,3364],{"class":3363},[3188,7432,3368],{"class":3367},[3188,7434,3372],{"class":3371},[3188,7436,3376],{"class":3375},[3188,7438,7439,7441,7443],{"class":3190,"line":3203},[3188,7440,3381],{"class":3371},[3188,7442,3982],{"class":3367},[3188,7444,3376],{"class":3375},[3188,7446,7447,7449,7452,7455],{"class":3190,"line":3209},[3188,7448,3989],{"class":3371},[3188,7450,7451],{"class":3367}," /run/secrets:rw,size=10m,mode=",[3188,7453,7454],{"class":6086},"0700",[3188,7456,3376],{"class":3375},[3188,7458,7459],{"class":3190,"line":3215},[3188,7460,3900],{"class":3367},[3114,7462,7463],{},[3118,7464,7465],{},"Опції tmpfs:",[3620,7467,7468,7480,7490,7496],{},[3309,7469,7470,7473,7474,6633,7477,3685],{},[3185,7471,7472],{},"size"," — максимальний розмір (напр. ",[3185,7475,7476],{},"100m",[3185,7478,7479],{},"1g",[3309,7481,7482,7485,7486,6633,7488,3685],{},[3185,7483,7484],{},"mode"," — права доступу (напр. ",[3185,7487,7405],{},[3185,7489,7454],{},[3309,7491,7492,7495],{},[3185,7493,7494],{},"uid"," — власник (User ID)",[3309,7497,7498,7501],{},[3185,7499,7500],{},"gid"," — група (Group ID)",[3160,7503,7505],{"id":7504},"приклад-aspnet-core-з-tmpfs-для-кешу","Приклад: ASP.NET Core з tmpfs для кешу",[3114,7507,7508],{},[3118,7509,7510],{},"Dockerfile:",[3179,7512,7514],{"className":6547,"code":7513,"language":6549,"meta":3183,"style":3183},"FROM mcr.microsoft.com/dotnet/aspnet:8.0-alpine\n\nWORKDIR /app\nCOPY --from=build /app/publish .\n\n# tmpfs буде монтуватися при запуску\nENV ASPNETCORE_TEMP=/tmp\n\nENTRYPOINT [\"dotnet\", \"MyWebApi.dll\"]\n",[3185,7515,7516,7523,7527,7533,7540,7544,7549,7557,7561],{"__ignoreMap":3183},[3188,7517,7518,7520],{"class":3190,"line":3191},[3188,7519,6556],{"class":3371},[3188,7521,7522],{"class":3884}," mcr.microsoft.com/dotnet/aspnet:8.0-alpine\n",[3188,7524,7525],{"class":3190,"line":3197},[3188,7526,3407],{"emptyLinePlaceholder":3406},[3188,7528,7529,7531],{"class":3190,"line":3203},[3188,7530,6568],{"class":3371},[3188,7532,6571],{"class":3884},[3188,7534,7535,7537],{"class":3190,"line":3209},[3188,7536,6585],{"class":3371},[3188,7538,7539],{"class":3884}," --from=build /app/publish .\n",[3188,7541,7542],{"class":3190,"line":3215},[3188,7543,3407],{"emptyLinePlaceholder":3406},[3188,7545,7546],{"class":3190,"line":3221},[3188,7547,7548],{"class":3357},"# tmpfs буде монтуватися при запуску\n",[3188,7550,7551,7554],{"class":3190,"line":3227},[3188,7552,7553],{"class":3371},"ENV",[3188,7555,7556],{"class":3884}," ASPNETCORE_TEMP=/tmp\n",[3188,7558,7559],{"class":3190,"line":3233},[3188,7560,3407],{"emptyLinePlaceholder":3406},[3188,7562,7563,7565,7567,7569,7571,7574],{"class":3190,"line":3239},[3188,7564,6624],{"class":3371},[3188,7566,6627],{"class":3884},[3188,7568,6630],{"class":3367},[3188,7570,6633],{"class":3884},[3188,7572,7573],{"class":3367},"\"MyWebApi.dll\"",[3188,7575,4666],{"class":3884},[3114,7577,7578],{},[3118,7579,7580],{},"Запуск:",[3179,7582,7584],{"className":3348,"code":7583,"language":3350,"meta":3183,"style":3183},"docker run -d \\\n  --name myapi \\\n  -p 8080:8080 \\\n  --tmpfs /tmp:rw,size=100m \\\n  --tmpfs /app/cache:rw,size=200m \\\n  myapi:latest\n",[3185,7585,7586,7596,7605,7613,7621,7630],{"__ignoreMap":3183},[3188,7587,7588,7590,7592,7594],{"class":3190,"line":3191},[3188,7589,3364],{"class":3363},[3188,7591,3368],{"class":3367},[3188,7593,3372],{"class":3371},[3188,7595,3376],{"class":3375},[3188,7597,7598,7600,7603],{"class":3190,"line":3197},[3188,7599,3381],{"class":3371},[3188,7601,7602],{"class":3367}," myapi",[3188,7604,3376],{"class":3375},[3188,7606,7607,7609,7611],{"class":3190,"line":3203},[3188,7608,5116],{"class":3371},[3188,7610,5539],{"class":3367},[3188,7612,3376],{"class":3375},[3188,7614,7615,7617,7619],{"class":3190,"line":3209},[3188,7616,3989],{"class":3371},[3188,7618,3992],{"class":3367},[3188,7620,3376],{"class":3375},[3188,7622,7623,7625,7628],{"class":3190,"line":3215},[3188,7624,3989],{"class":3371},[3188,7626,7627],{"class":3367}," /app/cache:rw,size=200m",[3188,7629,3376],{"class":3375},[3188,7631,7632],{"class":3190,"line":3221},[3188,7633,5546],{"class":3367},[3114,7635,7636],{},[3118,7637,7638],{},"Переваги:",[3620,7640,7641,7644,7647],{},[3309,7642,7643],{},"Тимчасові файли ASP.NET Core зберігаються в RAM (швидше)",[3309,7645,7646],{},"Кеш у RAM (швидкий доступ)",[3309,7648,7649],{},"Не забруднює диск",[3160,7651,7653],{"id":7652},"порівняння-продуктивності","Порівняння продуктивності",[3114,7655,7656],{},[3118,7657,7658],{},"Тест: запис 1000 файлів по 1 КБ",[4004,7660,7661,7673],{},[4007,7662,7663],{},[4010,7664,7665,7668,7671],{},[4013,7666,7667],{"align":4015},"Storage",[4013,7669,7670],{"align":4015},"Час",[4013,7672,4056],{"align":4015},[4025,7674,7675,7686,7697],{},[4010,7676,7677,7680,7683],{},[4030,7678,7679],{"align":4015},"HDD",[4030,7681,7682],{"align":4015},"5.2 с",[4030,7684,7685],{"align":4015},"192 файлів/с",[4010,7687,7688,7691,7694],{},[4030,7689,7690],{"align":4015},"SSD",[4030,7692,7693],{"align":4015},"0.8 с",[4030,7695,7696],{"align":4015},"1250 файлів/с",[4010,7698,7699,7702,7705],{},[4030,7700,7701],{"align":4015},"tmpfs (RAM)",[4030,7703,7704],{"align":4015},"0.05 с",[4030,7706,7707],{"align":4015},"20000 файлів/с",[3114,7709,7710],{},[3118,7711,7712],{},"tmpfs у 16 разів швидше за SSD!",[4278,7714,7715,7720],{},[3114,7716,7717],{},[3118,7718,7719],{},"Коли використовувати tmpfs:",[3620,7721,7722,7725,7728,7731,7734],{},[3309,7723,7724],{},"✅ Тимчасові файли (кеш, сесії)",[3309,7726,7727],{},"✅ Секрети (не зберігаються на диску)",[3309,7729,7730],{},"✅ Високошвидкісна обробка даних",[3309,7732,7733],{},"❌ Persistent storage (дані втрачаються)",[3309,7735,7736],{},"❌ Великі обсяги даних (обмежено RAM)",[3153,7738],{},[3109,7740,7742],{"id":7741},"практичні-приклади","Практичні приклади",[3160,7744,7746],{"id":7745},"приклад-1-postgresql-з-persistent-storage","Приклад 1: PostgreSQL з persistent storage",[3114,7748,7749],{},[3118,7750,7751],{},"docker-compose.yml:",[3179,7753,7757],{"className":7754,"code":7755,"language":7756,"meta":3183,"style":3183},"language-yaml shiki shiki-themes light-plus dark-plus dark-plus","version: '3.8'\n\nservices:\n  postgres:\n    image: postgres:16-alpine\n    container_name: postgres\n    environment:\n      POSTGRES_USER: myuser\n      POSTGRES_PASSWORD: mysecret\n      POSTGRES_DB: myapp\n    volumes:\n      # Named volume для даних БД\n      - postgres-data:/var/lib/postgresql/data\n      # Bind mount для init-скриптів\n      - ./init-scripts:/docker-entrypoint-initdb.d:ro\n    ports:\n      - \"5432:5432\"\n    restart: unless-stopped\n\nvolumes:\n  postgres-data:\n    driver: local\n","yaml",[3185,7758,7759,7771,7775,7783,7790,7800,7810,7817,7827,7837,7847,7854,7859,7867,7872,7879,7886,7893,7903,7907,7914,7921],{"__ignoreMap":3183},[3188,7760,7761,7765,7767],{"class":3190,"line":3191},[3188,7762,7764],{"class":7763},"sKtos","version",[3188,7766,4589],{"class":3884},[3188,7768,7770],{"class":7769},"su9tN","'3.8'\n",[3188,7772,7773],{"class":3190,"line":3197},[3188,7774,3407],{"emptyLinePlaceholder":3406},[3188,7776,7777,7780],{"class":3190,"line":3203},[3188,7778,7779],{"class":7763},"services",[3188,7781,7782],{"class":3884},":\n",[3188,7784,7785,7788],{"class":3190,"line":3209},[3188,7786,7787],{"class":7763},"  postgres",[3188,7789,7782],{"class":3884},[3188,7791,7792,7795,7797],{"class":3190,"line":3215},[3188,7793,7794],{"class":7763},"    image",[3188,7796,4589],{"class":3884},[3188,7798,7799],{"class":7769},"postgres:16-alpine\n",[3188,7801,7802,7805,7807],{"class":3190,"line":3221},[3188,7803,7804],{"class":7763},"    container_name",[3188,7806,4589],{"class":3884},[3188,7808,7809],{"class":7769},"postgres\n",[3188,7811,7812,7815],{"class":3190,"line":3227},[3188,7813,7814],{"class":7763},"    environment",[3188,7816,7782],{"class":3884},[3188,7818,7819,7822,7824],{"class":3190,"line":3233},[3188,7820,7821],{"class":7763},"      POSTGRES_USER",[3188,7823,4589],{"class":3884},[3188,7825,7826],{"class":7769},"myuser\n",[3188,7828,7829,7832,7834],{"class":3190,"line":3239},[3188,7830,7831],{"class":7763},"      POSTGRES_PASSWORD",[3188,7833,4589],{"class":3884},[3188,7835,7836],{"class":7769},"mysecret\n",[3188,7838,7839,7842,7844],{"class":3190,"line":3245},[3188,7840,7841],{"class":7763},"      POSTGRES_DB",[3188,7843,4589],{"class":3884},[3188,7845,7846],{"class":7769},"myapp\n",[3188,7848,7849,7852],{"class":3190,"line":3250},[3188,7850,7851],{"class":7763},"    volumes",[3188,7853,7782],{"class":3884},[3188,7855,7856],{"class":3190,"line":3255},[3188,7857,7858],{"class":3357},"      # Named volume для даних БД\n",[3188,7860,7861,7864],{"class":3190,"line":3261},[3188,7862,7863],{"class":3884},"      - ",[3188,7865,7866],{"class":7769},"postgres-data:/var/lib/postgresql/data\n",[3188,7868,7869],{"class":3190,"line":3267},[3188,7870,7871],{"class":3357},"      # Bind mount для init-скриптів\n",[3188,7873,7874,7876],{"class":3190,"line":3273},[3188,7875,7863],{"class":3884},[3188,7877,7878],{"class":7769},"./init-scripts:/docker-entrypoint-initdb.d:ro\n",[3188,7880,7881,7884],{"class":3190,"line":3278},[3188,7882,7883],{"class":7763},"    ports",[3188,7885,7782],{"class":3884},[3188,7887,7888,7890],{"class":3190,"line":3284},[3188,7889,7863],{"class":3884},[3188,7891,7892],{"class":3367},"\"5432:5432\"\n",[3188,7894,7895,7898,7900],{"class":3190,"line":3290},[3188,7896,7897],{"class":7763},"    restart",[3188,7899,4589],{"class":3884},[3188,7901,7902],{"class":7769},"unless-stopped\n",[3188,7904,7905],{"class":3190,"line":3296},[3188,7906,3407],{"emptyLinePlaceholder":3406},[3188,7908,7909,7912],{"class":3190,"line":4221},[3188,7910,7911],{"class":7763},"volumes",[3188,7913,7782],{"class":3884},[3188,7915,7916,7919],{"class":3190,"line":4227},[3188,7917,7918],{"class":7763},"  postgres-data",[3188,7920,7782],{"class":3884},[3188,7922,7923,7926,7928],{"class":3190,"line":4232},[3188,7924,7925],{"class":7763},"    driver",[3188,7927,4589],{"class":3884},[3188,7929,7930],{"class":7769},"local\n",[3114,7932,7933],{},[3118,7934,7935],{},"init-scripts/01-create-tables.sql:",[3179,7937,7941],{"className":7938,"code":7939,"language":7940,"meta":3183,"style":3183},"language-sql shiki shiki-themes light-plus dark-plus dark-plus","CREATE TABLE users (\n    id SERIAL PRIMARY KEY,\n    name VARCHAR(100) NOT NULL,\n    email VARCHAR(100) UNIQUE NOT NULL,\n    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP\n);\n\nCREATE INDEX idx_users_email ON users(email);\n","sql",[3185,7942,7943,7953,7966,7983,8005,8019,8023,8027],{"__ignoreMap":3183},[3188,7944,7945,7947,7949,7951],{"class":3190,"line":3191},[3188,7946,5175],{"class":3371},[3188,7948,5178],{"class":3371},[3188,7950,5181],{"class":3363},[3188,7952,5184],{"class":3884},[3188,7954,7955,7958,7961,7964],{"class":3190,"line":3197},[3188,7956,7957],{"class":3884},"    id ",[3188,7959,7960],{"class":3371},"SERIAL",[3188,7962,7963],{"class":3371}," PRIMARY KEY",[3188,7965,4595],{"class":3884},[3188,7967,7968,7970,7972,7974,7976,7978,7981],{"class":3190,"line":3203},[3188,7969,5203],{"class":3371},[3188,7971,5206],{"class":3371},[3188,7973,5209],{"class":3884},[3188,7975,5212],{"class":6086},[3188,7977,6910],{"class":3884},[3188,7979,7980],{"class":3371},"NOT NULL",[3188,7982,4595],{"class":3884},[3188,7984,7985,7988,7991,7993,7995,7997,8000,8003],{"class":3190,"line":3209},[3188,7986,7987],{"class":3884},"    email ",[3188,7989,7990],{"class":3371},"VARCHAR",[3188,7992,5209],{"class":3884},[3188,7994,5212],{"class":6086},[3188,7996,6910],{"class":3884},[3188,7998,7999],{"class":3371},"UNIQUE",[3188,8001,8002],{"class":3371}," NOT NULL",[3188,8004,4595],{"class":3884},[3188,8006,8007,8010,8013,8016],{"class":3190,"line":3215},[3188,8008,8009],{"class":3884},"    created_at ",[3188,8011,8012],{"class":3371},"TIMESTAMP",[3188,8014,8015],{"class":3371}," DEFAULT",[3188,8017,8018],{"class":3884}," CURRENT_TIMESTAMP\n",[3188,8020,8021],{"class":3190,"line":3221},[3188,8022,5235],{"class":3884},[3188,8024,8025],{"class":3190,"line":3227},[3188,8026,3407],{"emptyLinePlaceholder":3406},[3188,8028,8029,8031,8034,8037,8040],{"class":3190,"line":3233},[3188,8030,5175],{"class":3371},[3188,8032,8033],{"class":3371}," INDEX",[3188,8035,8036],{"class":3363}," idx_users_email",[3188,8038,8039],{"class":3371}," ON",[3188,8041,8042],{"class":3884}," users(email);\n",[3114,8044,8045],{},[3118,8046,7580],{},[3179,8048,8050],{"className":3348,"code":8049,"language":3350,"meta":3183,"style":3183},"docker compose up -d\n",[3185,8051,8052],{"__ignoreMap":3183},[3188,8053,8054,8056,8059,8062],{"class":3190,"line":3191},[3188,8055,3364],{"class":3363},[3188,8057,8058],{"class":3367}," compose",[3188,8060,8061],{"class":3367}," up",[3188,8063,8064],{"class":3371}," -d\n",[3114,8066,8067],{},[3118,8068,7638],{},[3620,8070,8071,8074,8077],{},[3309,8072,8073],{},"✅ Дані зберігаються у volume (не втрачаються)",[3309,8075,8076],{},"✅ Init-скрипти монтуються через bind mount (легко редагувати)",[3309,8078,8079],{},"✅ Автоматична ініціалізація БД при першому запуску",[3160,8081,8083],{"id":8082},"приклад-2-net-web-api-з-hot-reload","Приклад 2: .NET Web API з hot-reload",[3114,8085,8086],{},[3118,8087,8088],{},"Структура проєкту:",[3179,8090,8093],{"className":8091,"code":8092,"language":6751},[6749],"MyWebApi/\n├── Controllers/\n│   └── WeatherController.cs\n├── Program.cs\n├── MyWebApi.csproj\n├── Dockerfile.dev\n└── docker-compose.dev.yml\n",[3185,8094,8092],{"__ignoreMap":3183},[3114,8096,8097],{},[3118,8098,8099],{},"Dockerfile.dev:",[3179,8101,8103],{"className":6547,"code":8102,"language":6549,"meta":3183,"style":3183},"FROM mcr.microsoft.com/dotnet/sdk:8.0\n\nWORKDIR /app\n\n# Копіюємо .csproj для restore\nCOPY *.csproj .\nRUN dotnet restore\n\n# Код монтується через bind mount\n# Тому не копіюємо його\n\n# Встановлюємо dotnet-ef для міграцій (опціонально)\nRUN dotnet tool install --global dotnet-ef\nENV PATH=\"${PATH}:/root/.dotnet/tools\"\n\n# Запускаємо з hot-reload\nCMD [\"dotnet\", \"watch\", \"run\", \"--no-launch-profile\", \"--urls\", \"http://0.0.0.0:8080\"]\n",[3185,8104,8105,8111,8115,8121,8125,8130,8136,8142,8146,8151,8156,8160,8165,8172,8182,8186,8190],{"__ignoreMap":3183},[3188,8106,8107,8109],{"class":3190,"line":3191},[3188,8108,6556],{"class":3371},[3188,8110,6559],{"class":3884},[3188,8112,8113],{"class":3190,"line":3197},[3188,8114,3407],{"emptyLinePlaceholder":3406},[3188,8116,8117,8119],{"class":3190,"line":3203},[3188,8118,6568],{"class":3371},[3188,8120,6571],{"class":3884},[3188,8122,8123],{"class":3190,"line":3209},[3188,8124,3407],{"emptyLinePlaceholder":3406},[3188,8126,8127],{"class":3190,"line":3215},[3188,8128,8129],{"class":3357},"# Копіюємо .csproj для restore\n",[3188,8131,8132,8134],{"class":3190,"line":3221},[3188,8133,6585],{"class":3371},[3188,8135,6588],{"class":3884},[3188,8137,8138,8140],{"class":3190,"line":3227},[3188,8139,6593],{"class":3371},[3188,8141,6596],{"class":3884},[3188,8143,8144],{"class":3190,"line":3233},[3188,8145,3407],{"emptyLinePlaceholder":3406},[3188,8147,8148],{"class":3190,"line":3239},[3188,8149,8150],{"class":3357},"# Код монтується через bind mount\n",[3188,8152,8153],{"class":3190,"line":3245},[3188,8154,8155],{"class":3357},"# Тому не копіюємо його\n",[3188,8157,8158],{"class":3190,"line":3250},[3188,8159,3407],{"emptyLinePlaceholder":3406},[3188,8161,8162],{"class":3190,"line":3255},[3188,8163,8164],{"class":3357},"# Встановлюємо dotnet-ef для міграцій (опціонально)\n",[3188,8166,8167,8169],{"class":3190,"line":3261},[3188,8168,6593],{"class":3371},[3188,8170,8171],{"class":3884}," dotnet tool install --global dotnet-ef\n",[3188,8173,8174,8176,8179],{"class":3190,"line":3267},[3188,8175,7553],{"class":3371},[3188,8177,8178],{"class":3884}," PATH=",[3188,8180,8181],{"class":3367},"\"${PATH}:/root/.dotnet/tools\"\n",[3188,8183,8184],{"class":3190,"line":3273},[3188,8185,3407],{"emptyLinePlaceholder":3406},[3188,8187,8188],{"class":3190,"line":3278},[3188,8189,6619],{"class":3357},[3188,8191,8192,8195,8197,8199,8201,8203,8205,8207,8209,8211,8213,8216,8218,8221],{"class":3190,"line":3284},[3188,8193,8194],{"class":3371},"CMD",[3188,8196,6627],{"class":3884},[3188,8198,6630],{"class":3367},[3188,8200,6633],{"class":3884},[3188,8202,6636],{"class":3367},[3188,8204,6633],{"class":3884},[3188,8206,6641],{"class":3367},[3188,8208,6633],{"class":3884},[3188,8210,6646],{"class":3367},[3188,8212,6633],{"class":3884},[3188,8214,8215],{"class":3367},"\"--urls\"",[3188,8217,6633],{"class":3884},[3188,8219,8220],{"class":3367},"\"http://0.0.0.0:8080\"",[3188,8222,4666],{"class":3884},[3114,8224,8225],{},[3118,8226,8227],{},"docker-compose.dev.yml:",[3179,8229,8231],{"className":7754,"code":8230,"language":7756,"meta":3183,"style":3183},"version: '3.8'\n\nservices:\n  api:\n    build:\n      context: .\n      dockerfile: Dockerfile.dev\n    container_name: myapi-dev\n    volumes:\n      # Bind mount для hot-reload\n      - .:/app\n      # Exclude bin та obj (не монтувати)\n      - /app/bin\n      - /app/obj\n    ports:\n      - \"8080:8080\"\n    environment:\n      - ASPNETCORE_ENVIRONMENT=Development\n      - ASPNETCORE_URLS=http://+:8080\n    depends_on:\n      - postgres\n\n  postgres:\n    image: postgres:16-alpine\n    container_name: postgres-dev\n    environment:\n      POSTGRES_PASSWORD: dev_password\n      POSTGRES_DB: myapp_dev\n    volumes:\n      - postgres-dev-data:/var/lib/postgresql/data\n    ports:\n      - \"5432:5432\"\n\nvolumes:\n  postgres-dev-data:\n",[3185,8232,8233,8241,8245,8251,8258,8265,8275,8285,8294,8300,8305,8312,8317,8324,8331,8337,8344,8350,8357,8364,8371,8377,8381,8387,8395,8404,8410,8419,8428,8434,8442,8449,8456,8461,8468],{"__ignoreMap":3183},[3188,8234,8235,8237,8239],{"class":3190,"line":3191},[3188,8236,7764],{"class":7763},[3188,8238,4589],{"class":3884},[3188,8240,7770],{"class":7769},[3188,8242,8243],{"class":3190,"line":3197},[3188,8244,3407],{"emptyLinePlaceholder":3406},[3188,8246,8247,8249],{"class":3190,"line":3203},[3188,8248,7779],{"class":7763},[3188,8250,7782],{"class":3884},[3188,8252,8253,8256],{"class":3190,"line":3209},[3188,8254,8255],{"class":7763},"  api",[3188,8257,7782],{"class":3884},[3188,8259,8260,8263],{"class":3190,"line":3215},[3188,8261,8262],{"class":7763},"    build",[3188,8264,7782],{"class":3884},[3188,8266,8267,8270,8272],{"class":3190,"line":3221},[3188,8268,8269],{"class":7763},"      context",[3188,8271,4589],{"class":3884},[3188,8273,8274],{"class":6086},".\n",[3188,8276,8277,8280,8282],{"class":3190,"line":3227},[3188,8278,8279],{"class":7763},"      dockerfile",[3188,8281,4589],{"class":3884},[3188,8283,8284],{"class":7769},"Dockerfile.dev\n",[3188,8286,8287,8289,8291],{"class":3190,"line":3233},[3188,8288,7804],{"class":7763},[3188,8290,4589],{"class":3884},[3188,8292,8293],{"class":7769},"myapi-dev\n",[3188,8295,8296,8298],{"class":3190,"line":3239},[3188,8297,7851],{"class":7763},[3188,8299,7782],{"class":3884},[3188,8301,8302],{"class":3190,"line":3245},[3188,8303,8304],{"class":3357},"      # Bind mount для hot-reload\n",[3188,8306,8307,8309],{"class":3190,"line":3250},[3188,8308,7863],{"class":3884},[3188,8310,8311],{"class":7769},".:/app\n",[3188,8313,8314],{"class":3190,"line":3255},[3188,8315,8316],{"class":3357},"      # Exclude bin та obj (не монтувати)\n",[3188,8318,8319,8321],{"class":3190,"line":3261},[3188,8320,7863],{"class":3884},[3188,8322,8323],{"class":7769},"/app/bin\n",[3188,8325,8326,8328],{"class":3190,"line":3267},[3188,8327,7863],{"class":3884},[3188,8329,8330],{"class":7769},"/app/obj\n",[3188,8332,8333,8335],{"class":3190,"line":3273},[3188,8334,7883],{"class":7763},[3188,8336,7782],{"class":3884},[3188,8338,8339,8341],{"class":3190,"line":3278},[3188,8340,7863],{"class":3884},[3188,8342,8343],{"class":3367},"\"8080:8080\"\n",[3188,8345,8346,8348],{"class":3190,"line":3284},[3188,8347,7814],{"class":7763},[3188,8349,7782],{"class":3884},[3188,8351,8352,8354],{"class":3190,"line":3290},[3188,8353,7863],{"class":3884},[3188,8355,8356],{"class":7769},"ASPNETCORE_ENVIRONMENT=Development\n",[3188,8358,8359,8361],{"class":3190,"line":3296},[3188,8360,7863],{"class":3884},[3188,8362,8363],{"class":7769},"ASPNETCORE_URLS=http://+:8080\n",[3188,8365,8366,8369],{"class":3190,"line":4221},[3188,8367,8368],{"class":7763},"    depends_on",[3188,8370,7782],{"class":3884},[3188,8372,8373,8375],{"class":3190,"line":4227},[3188,8374,7863],{"class":3884},[3188,8376,7809],{"class":7769},[3188,8378,8379],{"class":3190,"line":4232},[3188,8380,3407],{"emptyLinePlaceholder":3406},[3188,8382,8383,8385],{"class":3190,"line":4238},[3188,8384,7787],{"class":7763},[3188,8386,7782],{"class":3884},[3188,8388,8389,8391,8393],{"class":3190,"line":4243},[3188,8390,7794],{"class":7763},[3188,8392,4589],{"class":3884},[3188,8394,7799],{"class":7769},[3188,8396,8397,8399,8401],{"class":3190,"line":4249},[3188,8398,7804],{"class":7763},[3188,8400,4589],{"class":3884},[3188,8402,8403],{"class":7769},"postgres-dev\n",[3188,8405,8406,8408],{"class":3190,"line":4255},[3188,8407,7814],{"class":7763},[3188,8409,7782],{"class":3884},[3188,8411,8412,8414,8416],{"class":3190,"line":4261},[3188,8413,7831],{"class":7763},[3188,8415,4589],{"class":3884},[3188,8417,8418],{"class":7769},"dev_password\n",[3188,8420,8421,8423,8425],{"class":3190,"line":4267},[3188,8422,7841],{"class":7763},[3188,8424,4589],{"class":3884},[3188,8426,8427],{"class":7769},"myapp_dev\n",[3188,8429,8430,8432],{"class":3190,"line":4273},[3188,8431,7851],{"class":7763},[3188,8433,7782],{"class":3884},[3188,8435,8437,8439],{"class":3190,"line":8436},30,[3188,8438,7863],{"class":3884},[3188,8440,8441],{"class":7769},"postgres-dev-data:/var/lib/postgresql/data\n",[3188,8443,8445,8447],{"class":3190,"line":8444},31,[3188,8446,7883],{"class":7763},[3188,8448,7782],{"class":3884},[3188,8450,8452,8454],{"class":3190,"line":8451},32,[3188,8453,7863],{"class":3884},[3188,8455,7892],{"class":3367},[3188,8457,8459],{"class":3190,"line":8458},33,[3188,8460,3407],{"emptyLinePlaceholder":3406},[3188,8462,8464,8466],{"class":3190,"line":8463},34,[3188,8465,7911],{"class":7763},[3188,8467,7782],{"class":3884},[3188,8469,8471,8474],{"class":3190,"line":8470},35,[3188,8472,8473],{"class":7763},"  postgres-dev-data",[3188,8475,7782],{"class":3884},[3114,8477,8478],{},[3118,8479,7580],{},[3179,8481,8483],{"className":3348,"code":8482,"language":3350,"meta":3183,"style":3183},"docker compose -f docker-compose.dev.yml up\n",[3185,8484,8485],{"__ignoreMap":3183},[3188,8486,8487,8489,8491,8494,8497],{"class":3190,"line":3191},[3188,8488,3364],{"class":3363},[3188,8490,8058],{"class":3367},[3188,8492,8493],{"class":3371}," -f",[3188,8495,8496],{"class":3367}," docker-compose.dev.yml",[3188,8498,8499],{"class":3367}," up\n",[3114,8501,8502],{},[3118,8503,6722],{},[3306,8505,8506,8512,8515,8520,8523],{},[3309,8507,8508,8509],{},"Змініть код у ",[3185,8510,8511],{},"Controllers/WeatherController.cs",[3309,8513,8514],{},"Збережіть файл",[3309,8516,8517,8519],{},[3185,8518,6736],{}," автоматично перекомпілює",[3309,8521,8522],{},"API перезапускається з новим кодом",[3309,8524,8525,8526],{},"Зміни видимі одразу на ",[3185,8527,8528],{},"http://localhost:8080",[3114,8530,8531],{},[3118,8532,6745],{},[3179,8534,8537],{"className":8535,"code":8536,"language":6751},[6749],"api-dev  | watch : File changed: /app/Controllers/WeatherController.cs\napi-dev  | watch : Building...\napi-dev  | watch : Build succeeded\napi-dev  | watch : Started\napi-dev  | info: Now listening on: http://[::]:8080\n",[3185,8538,8536],{"__ignoreMap":3183},[3160,8540,8542],{"id":8541},"приклад-3-full-stack-з-volumes-та-bind-mounts","Приклад 3: Full-stack з volumes та bind mounts",[3114,8544,8545],{},[3118,8546,7751],{},[3179,8548,8550],{"className":7754,"code":8549,"language":7756,"meta":3183,"style":3183},"version: '3.8'\n\nservices:\n  # Frontend (React/Vue) з hot-reload\n  frontend:\n    image: node:20-alpine\n    working_dir: /app\n    command: npm run dev\n    volumes:\n      - ./frontend:/app\n      - /app/node_modules  # Exclude node_modules\n    ports:\n      - \"3000:3000\"\n    environment:\n      - NODE_ENV=development\n\n  # Backend (.NET API) з hot-reload\n  backend:\n    build:\n      context: ./backend\n      dockerfile: Dockerfile.dev\n    volumes:\n      - ./backend:/app\n      - /app/bin\n      - /app/obj\n    ports:\n      - \"8080:8080\"\n    environment:\n      - ASPNETCORE_ENVIRONMENT=Development\n      - ConnectionStrings__DefaultConnection=Host=postgres;Database=myapp;Username=postgres;Password=secret\n    depends_on:\n      - postgres\n      - redis\n\n  # PostgreSQL з persistent storage\n  postgres:\n    image: postgres:16-alpine\n    volumes:\n      - postgres-data:/var/lib/postgresql/data\n      - ./database/init:/docker-entrypoint-initdb.d:ro\n    environment:\n      POSTGRES_PASSWORD: secret\n      POSTGRES_DB: myapp\n    ports:\n      - \"5432:5432\"\n\n  # Redis з tmpfs для швидкого кешу\n  redis:\n    image: redis:7-alpine\n    command: redis-server --save \"\"\n    tmpfs:\n      - /data:rw,size=100m\n    ports:\n      - \"6379:6379\"\n\n  # Nginx reverse proxy\n  nginx:\n    image: nginx:alpine\n    volumes:\n      - ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro\n      - nginx-logs:/var/log/nginx\n    ports:\n      - \"80:80\"\n    depends_on:\n      - frontend\n      - backend\n\nvolumes:\n  postgres-data:\n  nginx-logs:\n",[3185,8551,8552,8560,8564,8570,8575,8582,8591,8601,8611,8617,8624,8634,8640,8647,8653,8660,8664,8669,8676,8682,8691,8699,8705,8712,8718,8724,8730,8736,8742,8748,8755,8761,8767,8774,8778,8783,8790,8799,8806,8813,8821,8828,8838,8847,8854,8861,8866,8872,8880,8890,8900,8908,8916,8923,8931,8936,8942,8950,8960,8967,8975,8983,8990,8998,9005,9013,9021,9026,9033,9040],{"__ignoreMap":3183},[3188,8553,8554,8556,8558],{"class":3190,"line":3191},[3188,8555,7764],{"class":7763},[3188,8557,4589],{"class":3884},[3188,8559,7770],{"class":7769},[3188,8561,8562],{"class":3190,"line":3197},[3188,8563,3407],{"emptyLinePlaceholder":3406},[3188,8565,8566,8568],{"class":3190,"line":3203},[3188,8567,7779],{"class":7763},[3188,8569,7782],{"class":3884},[3188,8571,8572],{"class":3190,"line":3209},[3188,8573,8574],{"class":3357},"  # Frontend (React/Vue) з hot-reload\n",[3188,8576,8577,8580],{"class":3190,"line":3215},[3188,8578,8579],{"class":7763},"  frontend",[3188,8581,7782],{"class":3884},[3188,8583,8584,8586,8588],{"class":3190,"line":3221},[3188,8585,7794],{"class":7763},[3188,8587,4589],{"class":3884},[3188,8589,8590],{"class":7769},"node:20-alpine\n",[3188,8592,8593,8596,8598],{"class":3190,"line":3227},[3188,8594,8595],{"class":7763},"    working_dir",[3188,8597,4589],{"class":3884},[3188,8599,8600],{"class":7769},"/app\n",[3188,8602,8603,8606,8608],{"class":3190,"line":3233},[3188,8604,8605],{"class":7763},"    command",[3188,8607,4589],{"class":3884},[3188,8609,8610],{"class":7769},"npm run dev\n",[3188,8612,8613,8615],{"class":3190,"line":3239},[3188,8614,7851],{"class":7763},[3188,8616,7782],{"class":3884},[3188,8618,8619,8621],{"class":3190,"line":3245},[3188,8620,7863],{"class":3884},[3188,8622,8623],{"class":7769},"./frontend:/app\n",[3188,8625,8626,8628,8631],{"class":3190,"line":3250},[3188,8627,7863],{"class":3884},[3188,8629,8630],{"class":7769},"/app/node_modules",[3188,8632,8633],{"class":3357},"  # Exclude node_modules\n",[3188,8635,8636,8638],{"class":3190,"line":3255},[3188,8637,7883],{"class":7763},[3188,8639,7782],{"class":3884},[3188,8641,8642,8644],{"class":3190,"line":3261},[3188,8643,7863],{"class":3884},[3188,8645,8646],{"class":3367},"\"3000:3000\"\n",[3188,8648,8649,8651],{"class":3190,"line":3267},[3188,8650,7814],{"class":7763},[3188,8652,7782],{"class":3884},[3188,8654,8655,8657],{"class":3190,"line":3273},[3188,8656,7863],{"class":3884},[3188,8658,8659],{"class":7769},"NODE_ENV=development\n",[3188,8661,8662],{"class":3190,"line":3278},[3188,8663,3407],{"emptyLinePlaceholder":3406},[3188,8665,8666],{"class":3190,"line":3284},[3188,8667,8668],{"class":3357},"  # Backend (.NET API) з hot-reload\n",[3188,8670,8671,8674],{"class":3190,"line":3290},[3188,8672,8673],{"class":7763},"  backend",[3188,8675,7782],{"class":3884},[3188,8677,8678,8680],{"class":3190,"line":3296},[3188,8679,8262],{"class":7763},[3188,8681,7782],{"class":3884},[3188,8683,8684,8686,8688],{"class":3190,"line":4221},[3188,8685,8269],{"class":7763},[3188,8687,4589],{"class":3884},[3188,8689,8690],{"class":7769},"./backend\n",[3188,8692,8693,8695,8697],{"class":3190,"line":4227},[3188,8694,8279],{"class":7763},[3188,8696,4589],{"class":3884},[3188,8698,8284],{"class":7769},[3188,8700,8701,8703],{"class":3190,"line":4232},[3188,8702,7851],{"class":7763},[3188,8704,7782],{"class":3884},[3188,8706,8707,8709],{"class":3190,"line":4238},[3188,8708,7863],{"class":3884},[3188,8710,8711],{"class":7769},"./backend:/app\n",[3188,8713,8714,8716],{"class":3190,"line":4243},[3188,8715,7863],{"class":3884},[3188,8717,8323],{"class":7769},[3188,8719,8720,8722],{"class":3190,"line":4249},[3188,8721,7863],{"class":3884},[3188,8723,8330],{"class":7769},[3188,8725,8726,8728],{"class":3190,"line":4255},[3188,8727,7883],{"class":7763},[3188,8729,7782],{"class":3884},[3188,8731,8732,8734],{"class":3190,"line":4261},[3188,8733,7863],{"class":3884},[3188,8735,8343],{"class":3367},[3188,8737,8738,8740],{"class":3190,"line":4267},[3188,8739,7814],{"class":7763},[3188,8741,7782],{"class":3884},[3188,8743,8744,8746],{"class":3190,"line":4273},[3188,8745,7863],{"class":3884},[3188,8747,8356],{"class":7769},[3188,8749,8750,8752],{"class":3190,"line":8436},[3188,8751,7863],{"class":3884},[3188,8753,8754],{"class":7769},"ConnectionStrings__DefaultConnection=Host=postgres;Database=myapp;Username=postgres;Password=secret\n",[3188,8756,8757,8759],{"class":3190,"line":8444},[3188,8758,8368],{"class":7763},[3188,8760,7782],{"class":3884},[3188,8762,8763,8765],{"class":3190,"line":8451},[3188,8764,7863],{"class":3884},[3188,8766,7809],{"class":7769},[3188,8768,8769,8771],{"class":3190,"line":8458},[3188,8770,7863],{"class":3884},[3188,8772,8773],{"class":7769},"redis\n",[3188,8775,8776],{"class":3190,"line":8463},[3188,8777,3407],{"emptyLinePlaceholder":3406},[3188,8779,8780],{"class":3190,"line":8470},[3188,8781,8782],{"class":3357},"  # PostgreSQL з persistent storage\n",[3188,8784,8786,8788],{"class":3190,"line":8785},36,[3188,8787,7787],{"class":7763},[3188,8789,7782],{"class":3884},[3188,8791,8793,8795,8797],{"class":3190,"line":8792},37,[3188,8794,7794],{"class":7763},[3188,8796,4589],{"class":3884},[3188,8798,7799],{"class":7769},[3188,8800,8802,8804],{"class":3190,"line":8801},38,[3188,8803,7851],{"class":7763},[3188,8805,7782],{"class":3884},[3188,8807,8809,8811],{"class":3190,"line":8808},39,[3188,8810,7863],{"class":3884},[3188,8812,7866],{"class":7769},[3188,8814,8816,8818],{"class":3190,"line":8815},40,[3188,8817,7863],{"class":3884},[3188,8819,8820],{"class":7769},"./database/init:/docker-entrypoint-initdb.d:ro\n",[3188,8822,8824,8826],{"class":3190,"line":8823},41,[3188,8825,7814],{"class":7763},[3188,8827,7782],{"class":3884},[3188,8829,8831,8833,8835],{"class":3190,"line":8830},42,[3188,8832,7831],{"class":7763},[3188,8834,4589],{"class":3884},[3188,8836,8837],{"class":7769},"secret\n",[3188,8839,8841,8843,8845],{"class":3190,"line":8840},43,[3188,8842,7841],{"class":7763},[3188,8844,4589],{"class":3884},[3188,8846,7846],{"class":7769},[3188,8848,8850,8852],{"class":3190,"line":8849},44,[3188,8851,7883],{"class":7763},[3188,8853,7782],{"class":3884},[3188,8855,8857,8859],{"class":3190,"line":8856},45,[3188,8858,7863],{"class":3884},[3188,8860,7892],{"class":3367},[3188,8862,8864],{"class":3190,"line":8863},46,[3188,8865,3407],{"emptyLinePlaceholder":3406},[3188,8867,8869],{"class":3190,"line":8868},47,[3188,8870,8871],{"class":3357},"  # Redis з tmpfs для швидкого кешу\n",[3188,8873,8875,8878],{"class":3190,"line":8874},48,[3188,8876,8877],{"class":7763},"  redis",[3188,8879,7782],{"class":3884},[3188,8881,8883,8885,8887],{"class":3190,"line":8882},49,[3188,8884,7794],{"class":7763},[3188,8886,4589],{"class":3884},[3188,8888,8889],{"class":7769},"redis:7-alpine\n",[3188,8891,8893,8895,8897],{"class":3190,"line":8892},50,[3188,8894,8605],{"class":7763},[3188,8896,4589],{"class":3884},[3188,8898,8899],{"class":7769},"redis-server --save \"\"\n",[3188,8901,8903,8906],{"class":3190,"line":8902},51,[3188,8904,8905],{"class":7763},"    tmpfs",[3188,8907,7782],{"class":3884},[3188,8909,8911,8913],{"class":3190,"line":8910},52,[3188,8912,7863],{"class":3884},[3188,8914,8915],{"class":7769},"/data:rw,size=100m\n",[3188,8917,8919,8921],{"class":3190,"line":8918},53,[3188,8920,7883],{"class":7763},[3188,8922,7782],{"class":3884},[3188,8924,8926,8928],{"class":3190,"line":8925},54,[3188,8927,7863],{"class":3884},[3188,8929,8930],{"class":3367},"\"6379:6379\"\n",[3188,8932,8934],{"class":3190,"line":8933},55,[3188,8935,3407],{"emptyLinePlaceholder":3406},[3188,8937,8939],{"class":3190,"line":8938},56,[3188,8940,8941],{"class":3357},"  # Nginx reverse proxy\n",[3188,8943,8945,8948],{"class":3190,"line":8944},57,[3188,8946,8947],{"class":7763},"  nginx",[3188,8949,7782],{"class":3884},[3188,8951,8953,8955,8957],{"class":3190,"line":8952},58,[3188,8954,7794],{"class":7763},[3188,8956,4589],{"class":3884},[3188,8958,8959],{"class":7769},"nginx:alpine\n",[3188,8961,8963,8965],{"class":3190,"line":8962},59,[3188,8964,7851],{"class":7763},[3188,8966,7782],{"class":3884},[3188,8968,8970,8972],{"class":3190,"line":8969},60,[3188,8971,7863],{"class":3884},[3188,8973,8974],{"class":7769},"./nginx/nginx.conf:/etc/nginx/nginx.conf:ro\n",[3188,8976,8978,8980],{"class":3190,"line":8977},61,[3188,8979,7863],{"class":3884},[3188,8981,8982],{"class":7769},"nginx-logs:/var/log/nginx\n",[3188,8984,8986,8988],{"class":3190,"line":8985},62,[3188,8987,7883],{"class":7763},[3188,8989,7782],{"class":3884},[3188,8991,8993,8995],{"class":3190,"line":8992},63,[3188,8994,7863],{"class":3884},[3188,8996,8997],{"class":3367},"\"80:80\"\n",[3188,8999,9001,9003],{"class":3190,"line":9000},64,[3188,9002,8368],{"class":7763},[3188,9004,7782],{"class":3884},[3188,9006,9008,9010],{"class":3190,"line":9007},65,[3188,9009,7863],{"class":3884},[3188,9011,9012],{"class":7769},"frontend\n",[3188,9014,9016,9018],{"class":3190,"line":9015},66,[3188,9017,7863],{"class":3884},[3188,9019,9020],{"class":7769},"backend\n",[3188,9022,9024],{"class":3190,"line":9023},67,[3188,9025,3407],{"emptyLinePlaceholder":3406},[3188,9027,9029,9031],{"class":3190,"line":9028},68,[3188,9030,7911],{"class":7763},[3188,9032,7782],{"class":3884},[3188,9034,9036,9038],{"class":3190,"line":9035},69,[3188,9037,7918],{"class":7763},[3188,9039,7782],{"class":3884},[3188,9041,9043,9046],{"class":3190,"line":9042},70,[3188,9044,9045],{"class":7763},"  nginx-logs",[3188,9047,7782],{"class":3884},[3114,9049,9050],{},[3118,9051,9052],{},"Типи storage у цьому прикладі:",[3620,9054,9055,9061,9067,9073],{},[3309,9056,9057,9060],{},[3118,9058,9059],{},"Bind mounts:"," Frontend та Backend код (hot-reload)",[3309,9062,9063,9066],{},[3118,9064,9065],{},"Named volumes:"," PostgreSQL data, Nginx logs (persistent)",[3309,9068,9069,9072],{},[3118,9070,9071],{},"tmpfs:"," Redis data (швидкий кеш, не persistent)",[3309,9074,9075,9078,9079,6633,9082,6633,9085,9088],{},[3118,9076,9077],{},"Excluded volumes:"," ",[3185,9080,9081],{},"node_modules",[3185,9083,9084],{},"bin",[3185,9086,9087],{},"obj"," (не монтувати з хоста)",[3153,9090],{},[3109,9092,9094],{"id":9093},"практичні-завдання","Практичні завдання",[3160,9096,9098],{"id":9097},"завдання-1-postgresql-з-persistent-storage","Завдання 1: PostgreSQL з persistent storage",[3114,9100,9101,9104],{},[3118,9102,9103],{},"Мета:"," Навчитися зберігати дані БД у volume.",[3114,9106,9107],{},[3118,9108,9109],{},"Кроки:",[3306,9111,9112,9118,9121,9124,9127,9130],{},[3309,9113,9114,9115],{},"Створіть volume: ",[3185,9116,9117],{},"docker volume create postgres-data",[3309,9119,9120],{},"Запустіть PostgreSQL з цим volume",[3309,9122,9123],{},"Створіть базу даних та таблицю з даними",[3309,9125,9126],{},"Видаліть контейнер",[3309,9128,9129],{},"Запустіть новий контейнер з тим самим volume",[3309,9131,9132],{},"Перевірте, що дані збереглися",[3114,9134,9135,9138],{},[3118,9136,9137],{},"Очікуваний результат:"," Дані не втрачаються при видаленні контейнера.",[3160,9140,9142],{"id":9141},"завдання-2-hot-reload-для-net-додатку","Завдання 2: Hot-reload для .NET додатку",[3114,9144,9145,9147],{},[3118,9146,9103],{}," Налаштувати розробницьке середовище з автоматичним перезапуском.",[3114,9149,9150],{},[3118,9151,9109],{},[3306,9153,9154,9157,9166,9169,9172],{},[3309,9155,9156],{},"Створіть ASP.NET Core Web API проєкт",[3309,9158,9159,9160,9163,9164],{},"Створіть ",[3185,9161,9162],{},"Dockerfile.dev"," з ",[3185,9165,6736],{},[3309,9167,9168],{},"Запустіть контейнер з bind mount поточної директорії",[3309,9170,9171],{},"Змініть код контролера",[3309,9173,9174],{},"Перевірте, що зміни застосувалися без перебудови образу",[3114,9176,9177,9179],{},[3118,9178,9137],{}," Зміни коду видимі одразу після збереження файлу.",[3160,9181,9183],{"id":9182},"завдання-3-backup-та-restore-volume","Завдання 3: Backup та restore volume",[3114,9185,9186,9188],{},[3118,9187,9103],{}," Навчитися робити backup даних з volume.",[3114,9190,9191],{},[3118,9192,9109],{},[3306,9194,9195,9198,9201,9204,9207,9210],{},[3309,9196,9197],{},"Створіть volume з даними (PostgreSQL або файли)",[3309,9199,9200],{},"Зробіть backup volume у tar-архів",[3309,9202,9203],{},"Видаліть volume",[3309,9205,9206],{},"Створіть новий volume",[3309,9208,9209],{},"Відновіть дані з backup",[3309,9211,9212],{},"Перевірте, що дані відновилися коректно",[3114,9214,9215,9217],{},[3118,9216,9137],{}," Дані успішно відновлені з backup.",[3160,9219,9221],{"id":9220},"завдання-4-порівняння-продуктивності","Завдання 4: Порівняння продуктивності",[3114,9223,9224,9226],{},[3118,9225,9103],{}," Виміряти різницю швидкості між volume, bind mount та tmpfs.",[3114,9228,9229],{},[3118,9230,9109],{},[3306,9232,9233,9236,9239,9242,9245],{},[3309,9234,9235],{},"Створіть скрипт, який записує 1000 файлів",[3309,9237,9238],{},"Запустіть скрипт з volume",[3309,9240,9241],{},"Запустіть скрипт з bind mount",[3309,9243,9244],{},"Запустіть скрипт з tmpfs",[3309,9246,9247],{},"Порівняйте час виконання",[3114,9249,9250,9252],{},[3118,9251,9137],{}," tmpfs найшвидший, volume та bind mount приблизно однакові.",[3153,9254],{},[3109,9256,9258],{"id":9257},"резюме","Резюме",[3114,9260,9261],{},"У цій статті ми детально розглянули збереження даних у Docker:",[3114,9263,9264],{},[3118,9265,9266],{},"Проблема ефемерності:",[3620,9268,9269,9272,9275],{},[3309,9270,9271],{},"Контейнери тимчасові — дані у container layer видаляються разом з контейнером",[3309,9273,9274],{},"Для stateful додатків (БД, файлові сховища) потрібен persistent storage",[3309,9276,9277],{},"Docker надає три типи storage: Volumes, Bind Mounts, tmpfs",[3114,9279,9280],{},[3118,9281,9282],{},"Docker Volumes:",[3620,9284,9285,9288,9293,9296,9312,9315],{},[3309,9286,9287],{},"Керовані Docker томи для persistent storage",[3309,9289,9290,9291],{},"Зберігаються у ",[3185,9292,3684],{},[3309,9294,9295],{},"Ідеально для production (БД, файли додатків)",[3309,9297,9298,9299,6633,9301,6633,9303,6633,9306,6633,9309],{},"Команди: ",[3185,9300,7140],{},[3185,9302,6827],{},[3185,9304,9305],{},"inspect",[3185,9307,9308],{},"rm",[3185,9310,9311],{},"prune",[3309,9313,9314],{},"Підтримують різні драйвери (local, NFS, cloud)",[3309,9316,9317],{},"Можуть бути спільними між контейнерами",[3114,9319,9320],{},[3118,9321,9322],{},"Bind Mounts:",[3620,9324,9325,9328,9331,9334,9341],{},[3309,9326,9327],{},"Пряме монтування директорій хоста в контейнер",[3309,9329,9330],{},"Ідеально для розробки (hot-reload коду)",[3309,9332,9333],{},"Зміни на хості одразу видимі в контейнері",[3309,9335,9336,9337,9340],{},"Проблеми з правами доступу (вирішуються через ",[3185,9338,9339],{},"-u"," або USER в Dockerfile)",[3309,9342,9343],{},"Не рекомендовано для production (залежність від хоста)",[3114,9345,9346],{},[3118,9347,9348],{},"tmpfs Mounts:",[3620,9350,9351,9354,9357,9360,9363],{},[3309,9352,9353],{},"Тимчасове сховище в RAM (не на диску)",[3309,9355,9356],{},"Дуже швидке (у 10-100 разів швидше за SSD)",[3309,9358,9359],{},"Автоматично очищується при зупинці",[3309,9361,9362],{},"Ідеально для кешу, тимчасових файлів, секретів",[3309,9364,9365],{},"Доступно лише на Linux",[3114,9367,9368],{},[3118,9369,9370],{},"Практичні сценарії:",[3620,9372,9373,9382,9390,9399,9409],{},[3309,9374,9375,9378,9379],{},[3118,9376,9377],{},"PostgreSQL:"," Named volume для ",[3185,9380,9381],{},"/var/lib/postgresql/data",[3309,9383,9384,9387,9388],{},[3118,9385,9386],{},".NET hot-reload:"," Bind mount коду + ",[3185,9389,6736],{},[3309,9391,9392,9395,9396,9398],{},[3118,9393,9394],{},"Redis кеш:"," tmpfs для ",[3185,9397,5837],{}," (швидко, не persistent)",[3309,9400,9401,9404,9405,9408],{},[3118,9402,9403],{},"Nginx конфігурація:"," Bind mount для ",[3185,9406,9407],{},"nginx.conf"," (легко редагувати)",[3309,9410,9411,9414],{},[3118,9412,9413],{},"Full-stack:"," Комбінація volumes, bind mounts та tmpfs",[3114,9416,9417],{},[3118,9418,9419],{},"Найкращі практики:",[3620,9421,9422,9425,9428,9431,9434,9444,9447],{},[3309,9423,9424],{},"✅ Використовуйте іменовані volumes для production",[3309,9426,9427],{},"✅ Використовуйте bind mounts для розробки",[3309,9429,9430],{},"✅ Використовуйте tmpfs для кешу та секретів",[3309,9432,9433],{},"✅ Робіть регулярні backup volumes",[3309,9435,9436,9437,6633,9439,6633,9441,9443],{},"✅ Exclude ",[3185,9438,9081],{},[3185,9440,9084],{},[3185,9442,9087],{}," при bind mount",[3309,9445,9446],{},"❌ Не використовуйте анонімні volumes (важко керувати)",[3309,9448,9449],{},"❌ Не зберігайте критичні дані в container layer",[3114,9451,9452],{},[3118,9453,9454],{},"Порівняльна таблиця:",[4004,9456,9457,9467],{},[4007,9458,9459],{},[4010,9460,9461,9464],{},[4013,9462,9463],{"align":4015},"Сценарій",[4013,9465,9466],{"align":4015},"Рекомендація",[4025,9468,9469,9477,9485,9492,9499,9507,9515],{},[4010,9470,9471,9474],{},[4030,9472,9473],{"align":4015},"Production БД",[4030,9475,9476],{"align":4015},"Named volume",[4010,9478,9479,9482],{},[4030,9480,9481],{"align":4015},"Development hot-reload",[4030,9483,9484],{"align":4015},"Bind mount",[4010,9486,9487,9490],{},[4030,9488,9489],{"align":4015},"Кеш, тимчасові файли",[4030,9491,3146],{"align":4015},[4010,9493,9494,9496],{},[4030,9495,3838],{"align":4015},[4030,9497,9498],{"align":4015},"Bind mount (read-only)",[4010,9500,9501,9504],{},[4030,9502,9503],{"align":4015},"Логи для аналізу",[4030,9505,9506],{"align":4015},"Named volume або bind mount",[4010,9508,9509,9512],{},[4030,9510,9511],{"align":4015},"Секрети (паролі, токени)",[4030,9513,9514],{"align":4015},"tmpfs (не залишає слідів)",[4010,9516,9517,9519],{},[4030,9518,3713],{"align":4015},[4030,9520,9476],{"align":4015},[4278,9522,9523,9528,9547],{},[3114,9524,9525],{},[3118,9526,9527],{},"Золоте правило storage:",[3620,9529,9530,9535,9541],{},[3309,9531,9532,4292],{},[3118,9533,9534],{},"Production:",[3309,9536,9537,9540],{},[3118,9538,9539],{},"Development:"," Bind Mounts (hot-reload, зручність)",[3309,9542,9543,9546],{},[3118,9544,9545],{},"Кеш/Секрети:"," tmpfs (швидко, безпечно)",[3114,9548,3649],{},[9550,9551,9552],"style",{},"html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sjcCO, html code.shiki .sjcCO{--shiki-light:#EE0000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sLwNe, html code.shiki .sLwNe{--shiki-light:#0451A5;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html pre.shiki code .sKtos, html code.shiki .sKtos{--shiki-light:#800000;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .su9tN, html code.shiki .su9tN{--shiki-light:#0000FF;--shiki-default:#CE9178;--shiki-dark:#CE9178}",{"title":3183,"searchDepth":3197,"depth":3197,"links":9554},[9555,9556,9561,9567,9578,9585,9591,9596,9602],{"id":3111,"depth":3197,"text":3112},{"id":3157,"depth":3197,"text":3158,"children":9557},[9558,9559,9560],{"id":3162,"depth":3203,"text":3163},{"id":3339,"depth":3203,"text":3340},{"id":3612,"depth":3203,"text":3613},{"id":3655,"depth":3197,"text":3656,"children":9562},[9563,9564,9565,9566],{"id":3662,"depth":3203,"text":3663},{"id":3796,"depth":3203,"text":3797},{"id":3903,"depth":3203,"text":3904},{"id":4001,"depth":3203,"text":4002},{"id":4309,"depth":3197,"text":4310,"children":9568},[9569,9570,9571,9572,9573,9574,9575,9576,9577],{"id":4313,"depth":3203,"text":4314},{"id":4486,"depth":3203,"text":4487},{"id":4694,"depth":3203,"text":4695},{"id":5037,"depth":3203,"text":5038},{"id":5466,"depth":3203,"text":5467},{"id":5619,"depth":3203,"text":5620},{"id":5725,"depth":3203,"text":5726},{"id":5946,"depth":3203,"text":5947},{"id":6129,"depth":3203,"text":6130},{"id":6215,"depth":3197,"text":6216,"children":9579},[9580,9581,9582,9583,9584],{"id":6219,"depth":3203,"text":6220},{"id":6278,"depth":3203,"text":6279},{"id":6535,"depth":3203,"text":6536},{"id":6756,"depth":3203,"text":6757},{"id":7093,"depth":3203,"text":7094},{"id":7235,"depth":3197,"text":7236,"children":9586},[9587,9588,9589,9590],{"id":7239,"depth":3203,"text":7240},{"id":7317,"depth":3203,"text":6279},{"id":7504,"depth":3203,"text":7505},{"id":7652,"depth":3203,"text":7653},{"id":7741,"depth":3197,"text":7742,"children":9592},[9593,9594,9595],{"id":7745,"depth":3203,"text":7746},{"id":8082,"depth":3203,"text":8083},{"id":8541,"depth":3203,"text":8542},{"id":9093,"depth":3197,"text":9094,"children":9597},[9598,9599,9600,9601],{"id":9097,"depth":3203,"text":9098},{"id":9141,"depth":3203,"text":9142},{"id":9182,"depth":3203,"text":9183},{"id":9220,"depth":3203,"text":9221},{"id":9257,"depth":3197,"text":9258},"Persistent storage в Docker — volumes, bind mounts, tmpfs та управління даними контейнерів","md",null,{},{"title":2715,"description":9603},"T4f5NjKcNcQxRMR3091M6h8ZdPvX345FXyrouyFM4VM",[9610,9612],{"title":2711,"path":2712,"stem":2713,"description":9611,"children":-1},"Повний цикл контейнеризації C# додатків — від консольних програм до ASP.NET Core Web API з production-ready конфігурацією",{"title":2719,"path":2720,"stem":2721,"description":9613,"children":-1},"Docker networking — bridge, host, overlay мережі, комунікація між контейнерами та зовнішнім світом",1778489429481]