Comprehensive Docker

Upcoming trainings

Level:For IT professionals
Provider:Other
Length (days):6
Hours/day:4
Delivery method:On-line
Price:1.380$ + VAT

As the leading containerization platform, Docker simplifies building, shipping, and running applications at any scale by providing a lightweight, portable, and consistent runtime environment.

Docker is widely used by developers for application packaging, IT professionals for infrastructure management, and DevOps teams for automating deployments in cloud environments and microservices architectures.

For the past several years, the renowned Stack Overflow Developer Survey has consistently ranked Docker among the most loved and widely used technologies.

As the leading containerization platform, Docker simplifies building, shipping, and running applications at any scale by providing a lightweight, portable, and consistent runtime environment. Docker is widely used by developers for application packaging, IT professionals for infrastructure management, and DevOps teams for automating deployments in cloud environments and microservices architectures.

Using Docker effectively is no longer optional—it's a critical skill for staying competitive in today's software industry.

This training is designed for anyone who wants to confidently use Docker for real-world applications—whether you're new to containers or looking to deepen your understanding.

To grasp the key concepts, that are particularly valuable in development settings, you'll gain hands-on experience with

  • Working with Docker CLI commands
  • Writing Dockerfiles
  • Managing storage with volumes and bind mounts
  • Networking containers
  • Orchestrating multi-container applications

Beyond development, you'll also learn how to integrate Docker into business environments from scratch: setting up Docker for teams, managing private registries and implementing access controls for secure collaboration.

On the production side, you'll explore automation for CI/CD pipelines, container monitoring, and strategies for maintaining reliable deployments.

By the end, you'll be ready to integrate Docker seamlessly into your workflow and use it productively on your own.

Finally, you'll also receive a brief introduction to Kubernetes—the industry-standard orchestration tool—so you understand when and why to use it for managing containerized workloads, even at the highest levels of scale and complexity.

Outline:

Module 1: Container Lifecycle Management

Here, you will learn what containers are and how to manage them using Docker CLI commands. You'll work with starting, stopping, restarting, pausing, and deleting containers, as well as inspecting their states. We'll also cover container logs, process management, and restart policies, ensuring you can effectively control and troubleshoot running containers.

Module 2: Working with Docker Images

Docker images are the foundation of containers. In this module, you'll learn how to pull, list, inspect, and remove images using the Docker CLI. We'll cover image layers, caching, and tagging strategies to help you manage versions efficiently. You'll also explore optimizing image sizes and understanding the difference between official, custom, and third-party images.

Module 3: Building Custom Images with Dockerfiles

You'll learn how to create your own custom images using Dockerfiles while containerizing a real-world full-stack application step by step. We'll cover Dockerfile syntax and structure, best practices for efficient builds, and techniques like layer caching and multi-stage builds to optimize image size and speed. By the end, you will have successfully containerized both a backend and frontend.

Module 4: Storage Mechanisms

By default, containers don't store data permanently. This module covers how to keep data persistent using volumes and bind mounts. You'll explore the differences between stateful and stateless applications and learn to set up database containers with volumes for reliable storage. We'll also look at how bind mounts streamline development by syncing files between the host and containers.

Module 5: Bridging Container Networks

Containers need to communicate—with each other, with services, and with the outside world. This module focuses on bridge networks, Docker's default networking mode. You'll learn how to connect containers, enable inter-container communication, and manage network access. We'll also cover best practices for securing container traffic.

Module 6: Multi-Container Setups with Docker Compose

Managing multi-container applications manually can be tedious. With Docker Compose, you'll learn how to define and run multi-container setups using a simple compose.yaml file. This module covers service dependencies, environment variables, networking between containers, and techniques to simplify local development and testing. By the end, you will have fully containerized a complex full-stack application and will be able to launch it effortlessly with a single command.

Module 7: Managing Private Registries with Harbor

Once your application is containerized, you need a secure and efficient way to store and share images within your team or organization. In this module, you'll learn how to set up a private container registry and manage images effectively. We'll then dive into Harbor, an open-source registry, and explore how to configure user access with Role-Based Access Control (RBAC), enforce security policies, and integrate Trivy for automated vulnerability scanning to keep your containerized workflow secure and compliant.

Module 8: Fully Managed Cloud Registries

Managing your own container registry gives you full control, but it also comes with administrative overhead. In this module, we'll explore fully managed cloud registries like Docker Hub, AWS Elastic Container Registry (ECR), GitHub Container Registry, and Google Artifact Registry. You'll learn how these services handle image storage, access control, and automated security scanning, as well as their pricing models.

Module 9: Automated Image Creation with GitHub Workflows

Building and managing container images manually can be time-consuming and error-prone. In this module, you'll learn how to automate image creation using GitHub Actions, ensuring that every code change triggers a Docker build, tag, and push to a container registry.

Module 10: Deployment Best Practices

In this module, we'll start with a simple deployment, demonstrating how to run containers in a fully managed cloud environment with minimal setup, including Google Cloud Run. From there, we'll explore best practices for container deployments, covering zero-downtime updates, rollback strategies, environment variables, resource limits, and strategies for horizontal scaling using multiple containers and load balancing to ensure smooth and scalable application delivery.

Module 11: Production Monitoring with cAdvisor, Prometheus, Grafana

Keeping track of container performance and resource usage is essential in production environments. In this module, you'll learn how to monitor Docker containers using cAdvisor for real-time container metrics, Prometheus for data collection and alerting, and Grafana for visualizing key performance indicators. We'll cover CPU, memory, network, and disk usage monitoring, setting up custom dashboards, and implementing alerting strategies to detect and respond to issues before they impact your application.

Module 12: Automated Container Updates with Watchtower

Keeping containers up to date is crucial for security and stability, but manually redeploying them can be tedious. In this module, you'll learn how to use Watchtower to automate container updates, ensuring your running services always use the latest images. We'll cover how Watchtower detects new image versions, updates containers seamlessly, and handles restarts with minimal downtime. Additionally, we'll discuss when to use automated updates in production and when manual control is preferable to avoid unintended disruptions.

Module 13: Introduction to Kubernetes

As applications grow, managing containers manually becomes impractical. This module introduces Kubernetes as the industry-standard orchestrator and explains when to use it over Docker alone. You'll explore Kubernetes architecture (Pods, Nodes, Control Plane) and key concepts like declarative configuration and desired state management to understand how Kubernetes automates deployment and scaling.

Module 14: Managing Workloads in Kubernetes

Running applications in Kubernetes requires more than just deploying containers. Here, you'll learn how to define and manage workloads using Deployments, StatefulSets, and DaemonSets—each designed for different types of applications. We'll cover scaling strategies, rolling updates, and rollback mechanisms to ensure reliability and high availability in production environments.

Module 15: Networking and Services in Kubernetes

Containers inside Kubernetes need to communicate efficiently, both with each other and the outside world. In this module, you'll learn how Kubernetes Services enable reliable networking between Pods. We'll explore different service types—ClusterIP, NodePort, LoadBalancer, and Ingress—and show how they facilitate internal networking, external exposure, and traffic routing for your applications.

Module 16: Persistent Storage in Kubernetes

Unlike traditional containers, applications running in Kubernetes often require persistent storage. This module covers Persistent Volumes (PVs), Persistent Volume Claims (PVCs), StorageClasses, and dynamic provisioning. You'll learn how Kubernetes handles stateful applications, data persistence, and volume management across clusters.

Final Project: Deploying a Scalable Full-Stack App on Kubernetes

In this final hands-on project, you'll apply everything you've learned to deploy a real-world full-stack application on Kubernetes. You'll set up a frontend, backend, and database, configure networking with Services and Ingress, and implement scaling, storage, and monitoring to make it production-ready.

We'll also discuss real Kubernetes clusters (e.g., GKE, EKS, AKS) and guide you on next steps for running Kubernetes in a cloud environment.

 

The course is technical, because of this it is expected that participants are capable of typing and have a general knowledge about computers and programs.

To participate in a course it's helpful to have a foundational understanding of certain concepts and technologies. Here are some general prerequisites that are recommended but not mandatory:

  • Linux Command Line
  • Networking Concepts: Basic knowledge of networking concepts such as IP addressing, ports, and protocols will be beneficial
  • Basic System Administration
  • Virtualization Concepts: Understanding virtualization concepts, such as hypervisors and virtual machines, can help
  • Cloud Computing Basics: having some understanding of cloud computing concepts, such as infrastructure as a service (IaaS) and platform as a service (PaaS), can be helpful.
Location SLO Online Confirmed

7 April 2025 - 14 April 2025

  • Price: 1.380$ + VAT
Show Schedule
  • 07.04.2025, 09:00-13:00
    Online classroom
  • 08.04.2025, 09:00-13:00
    Online classroom
  • 09.04.2025, 09:00-13:00
    Online classroom
  • 10.04.2025, 09:00-13:00
    Online classroom
  • 11.04.2025, 09:00-13:00
    Online classroom
  • 14.04.2025, 09:00-13:00
    Online classroom

For more information please call +386 1 568 40 40 or send an e-mail to trzenje@housing.si