Lecture description for HSE winter semester
-
The NIST Cloud Definition (2011)
- Breakdown of the NIST’s five essential cloud characteristics, deployment models, and service models.
-
Overview of Major Cloud Providers
- Key players in the cloud space (AWS, Azure, Google Cloud, etc.).
- Comparing evolution.
-
Cloud Service/Abstraction Models
- IaaS, PaaS, SaaS revisited, with modern examples.
- The evolution of abstraction models, including FaaS and Containers-as-a-Service (CaaS).
-
Introduction to CNCF
- Role of the Cloud Native Computing Foundation (CNCF) in the cloud ecosystem.
- CNCF Landscape: technologies, tools, and projects.
-
Popular Technologies
- Kubernetes: Container orchestration in cloud-native environments.
- eBPF: Extending kernel capabilities for monitoring and security.
- OpenTelemetry: Observability standards and practices in modern cloud systems.
By the end of this lecture, students will be able to:
- Describe the NIST cloud definition and its significance in the modern cloud landscape.
- Identify the major cloud providers and tell about their evolution.
- Differentiate between cloud service models and discuss their evolution, including modern abstraction models like CaaS.
- Explain the role of CNCF and analyze the CNCF landscape to identify key technologies and trends.
- Provide an overview of Kubernetes, eBPF, and OpenTelemetry, explaining their impact on cloud-native development.
- What are the five essential characteristics of cloud computing according to NIST, and how do they apply to modern cloud services?
- Identify 3 main cloud providers.
- What are the differences between IaaS, PaaS, and SaaS? Give examples of each in today's cloud ecosystem.
- What is the CNCF, and why is it important in the context of cloud-native technologies?
- How does Kubernetes help in managing containerized applications in cloud-native environments?
- What is eBPF, and what advantages does it provide in terms of system monitoring and security?
- Explain the role of OpenTelemetry in modern cloud systems. How does it contribute to observability?
- NIST 2011 Cloud Computing Definition
- CNCF Cloud Native Landscape
- Introduction to Kubernetes
- Understanding eBPF
- OpenTelemetry Documentation
- Get a GitHub or GitLab or Bitbucket account
2024 / 09 / 30 - Overview of distributed systems implementation options - Frameworks, Kubernetes, Service Meshes (sidecar-based and eBPF-based)
-
Reasons for Distributed Systems: Heterogeneity and Resilience
- Why distributed systems? The need for handling heterogeneous environments (multiple platforms, languages, and architectures).
- Achieving resilience in modern systems: ensuring fault tolerance, scalability, and high availability in distributed environments.
-
Implementation Options for Distributed Systems
- Overview of software frameworks for distributed systems (e.g., Spring Boot).
- Platforms enabling distributed architectures: Kubernetes and its orchestration capabilities.
- Extensions: service meshes (e.g., Istio, Linkerd) for enhancing communication and security.
- Exploring new capabilities through eBPF for controlling network traffic.
-
Overview of Cloud-Based IDEs
- Introduction to cloud-based integrated development environments (IDEs).
- GitHub Codespaces: Full development environments in the cloud.
- Gitpod: Automating and provisioning cloud-based workspaces for development.
- Benefits of cloud-based IDEs for distributed systems development.
By the end of this lecture, students will be able to:
- Explain the importance of heterogeneity and resilience as key drivers for distributed systems.
- Identify different implementation options for building distributed systems using frameworks, platforms, and extensions.
- Compare the features of traditional service meshes and newer approaches leveraging eBPF.
- Explain the advantages of using cloud-based IDEs, such as GitHub Codespaces and Gitpod, for distributed system development.
- Demonstrate an understanding of how these tools enhance collaboration and scalability in cloud-native environments.
- Why are heterogeneity and resilience important factors in the design of distributed systems?
- What are the main differences between a software framework (e.g., Spring Boot) and a platform (e.g., Kubernetes) when building distributed systems?
- How do service meshes like Istio or Linkerd improve communication in microservices architectures?
- What is eBPF, and how does it enhance service mesh capabilities in modern cloud-native systems?
- Analyze GitHub Codespaces and Gitpod. What are the key features that make them suitable for developing distributed systems?
- What are the main benefits of using cloud-based IDEs compared to traditional, local development environments?
- Introduction to Spring Boot for Microservices
- Kubernetes Documentation
- Service Mesh Overview
- eBPF - A New Frontier
- GitHub Codespaces Documentation
- Gitpod Documentation
-
Development in distributed teams withouth containers and the potential problems:
- Polyglot application landscapes are challenging as all work environments need to match all runtime requirements for all languages
- Transporting application from environment A to environment B introduces challenges and problems with mismatching runtimes
-
Containers
- Isolate Applications from each other
- Package Applications along with all Runtime requirements for easy execution and transportation between working environments
- Simplify configuration of working environments -> only container engine needed
- handling of all application containers through same mechanisms: docker build, docker run
-
Docker
- Docker ecosystem consists of the Docker Daemon, Docker CLI and Docker Hub+
- Creation of Dockerfiles
- Building Images
- Running Containers
-
Exercises
- Exercises can be found at: https://lecture.new.trainings.nvtc.io/basics/container/
- What is Docker, and how does it differ from traditional virtual machines?
- Explain the concept of a Docker image and a Docker container. How are they related?
- What are the main components of a Dockerfile? Describe the purpose of each component.
- How does Docker ensure isolation and security between containers?
- What is a container registry, and how do you use Docker Hub to share or deploy images?
- Describe the process of building and running a containerized application using Docker, including common commands.
- Get a Dockerhub account
- Work through the exercises
-
Multi-Container Applications
- Introduction to the concept of multi-container applications.
- Understanding container isolation: how containers are isolated from each other and the host system to ensure security and resource control.
- Port Mapping: How port mapping allows external access to containerized applications while maintaining isolation between the container and the host network.
- Executing a Shell in a Container for Debugging: Using Docker to open a shell inside a running container to troubleshoot issues, inspect processes, or test the environment.
-
Creating Containerized Applications with Spring Boot
- Building containerized applications using pre-built Spring Boot code.
- Writing and using Dockerfiles to package Spring Boot applications into containers.
-
Connecting Containers Using Docker Networks
- Overview of Docker networking and its role in enabling communication between containers.
- Different types of Docker networks (bridge, host).
-
Docker Compose for Multi-Container Applications
- Introduction to Docker Compose and its benefits for managing multi-container applications.
- Creating and running multi-container setups using
docker-compose.yml
to define and orchestrate services.
By the end of this lecture, students will be able to:
- Explain the concept of multi-container applications and the importance of container isolation, including port mapping and shell access for debugging.
- Create containerized Spring Boot applications using Dockerfiles.
- Set up Docker networks to connect multiple containers and enable communication.
- Use Docker Compose to define and manage multi-container applications in a streamlined way.
- What is container isolation, and why is it important in multi-container applications?
- How does port mapping work, and how does it maintain isolation between a container and the host system while allowing external access?
- How can you execute a shell inside a running container to debug an application? Provide an example of when this might be useful.
- How would you create a Dockerfile for a Spring Boot application to package it into a container?
- What is the role of Docker networks in multi-container applications, and what are the different network types?
- How does Docker Compose simplify the management of multi-container applications? Provide an example of how services are defined in a
docker-compose.yml
file. - What are some advantages of using Docker Compose over manually running multiple containers with Docker commands?
- Spring Boot Docker Guide
- Docker Networking Overview
- Docker Port Mapping
- Using Docker Exec for Debugging
- Docker Compose Documentation
- Best Practices for Multi-Container Applications
- DO THE DOCKER EXERCISES
-
Introduction to Spring Boot
- Evolution of Spring to Spring Boot: Understanding how Spring Boot simplifies Spring applications, focusing on convention over configuration.
- Spring Initializr: A web-based tool for quickly creating Spring Boot projects with customizable dependencies.
- Key Dependencies:
- Web: Building RESTful web services and web applications.
- Actuator: Providing production-ready features such as monitoring and health checks.
- application.properties: Configuration of application settings in Spring Boot projects.
- Spring Boot Project Structure: Understanding the typical structure of a Spring Boot project and how it facilitates development.
- OpenAPI: Use the OpenAPI dependency to make the REST API definition universally available and accessible through a JSON format and the Swagger UI
-
Overview of Cloud-Based IDEs
- GitHub Codespaces: Cloud-hosted development environments integrated with GitHub, enabling easy setup and collaboration.
- Gitpod: Automating cloud-based development workspaces with pre-configured environments.
- Advantages of cloud-based IDEs for Spring Boot development: instant setup, collaboration, and scalability.
By the end of this lecture, students will be able to:
- Describe the evolution of Spring to Spring Boot and how Spring Boot improves application development.
- Use Spring Initializr to create Spring Boot projects with appropriate dependencies.
- Understand and configure application properties using
application.properties
in Spring Boot. - Identify the key components and structure of a typical Spring Boot project.
- Create a REST API using Spring Boot by using common annotations.
- Extend the Spring Boot dependencies to use OpenAPI and Swagger UI.
- Compare GitHub Codespaces and Gitpod, and explain how cloud-based IDEs enhance Spring Boot development workflows.
- Describe basic core concepts of Spring Boot.
- How does Spring Initializr simplify the creation of Spring Boot projects, and what are some essential dependencies you might include?
- What role does the
application.properties
file play in a Spring Boot project? - Explain the typical structure of a Spring Boot project. Why is this structure useful for developers?
- What do the annotations
@RestController
,@PathVariable
and@RequestMapping
do? - What are the key benefits of using a cloud-based IDE over a local development environment for a cloud-native application in general and a Spring Boot project in particular?
- Spring Boot Documentation
- Spring Initializr
- Spring Boot Actuator Documentation
- GitHub Codespaces Documentation
- Gitpod Documentation
- Rebuild the sample of the lecture
Here's the documentation for today’s longer lecture:
-
Distributed Systems Theory
- CAP Theorem: Understanding the trade-offs between Consistency, Availability, and Partition Tolerance in distributed systems.
- Conway's Law: Exploring how software design reflects organizational structure and its implications for distributed systems.
- 12-Factor Applications: Best practices for building scalable, maintainable applications, focusing on principles like configuration, dependencies, and logging.
- Microservices: Basic concept of microservices, its advantages, and challenges in distributed systems.
-
API and REST
- HTTP Basics: Core concepts of HTTP for APIs, including request/response structure.
- Introduction to REST: Understanding the foundational ideas of REST as defined by Roy Fielding and how RESTful APIs communicate.
- Nouns and Verbs: Structuring REST APIs around resources (nouns) and actions (verbs).
- Representation: Data formats in REST (e.g., JSON, XML) and the role of content negotiation.
- HTTP Return Codes: Standard HTTP status codes, their meanings, and when to use each in API responses.
- Idempotency: Ensuring repeatable requests yield the same results to prevent unintended side effects.
- Richardson's Maturity Model: Levels of RESTful maturity, from Level 0 (HTTP as a tunnel) to Level 3 (HATEOAS), to understand API design progression.
By the end of this lecture, students will be able to:
- Describe the CAP Theorem, its components, and how it affects design choices in distributed systems.
- Explain Conway’s Law and its influence on software architecture, especially in the context of microservices.
- List and apply the 12 factors for building scalable, portable, and maintainable applications.
- Define and differentiate microservices architecture from other architectural styles.
- Understand and apply REST principles, including HTTP methods, status codes, and idempotency, to design effective APIs.
- Recognize different levels of RESTful API maturity and their implications for API design.
Be able to relate the concepts of CAP theorem and the 12-factor apps to the technologies we are covering in the lecture, e.g. how do technologies like Spring Boot (or other frameworks/languages), Docker, Kubernetes incorporate or implement those aspects
- What are the components of the CAP Theorem, and why can’t a distributed system fully achieve all three?
- How does Conway’s Law impact the structure of a distributed system, especially when adopting a microservices architecture?
- What are the key factors of a 12-factor app, and how do they contribute to application scalability and resilience?
- Describe microservices concepts and some of its advantages over a monolithic architecture.
- What are the basic components of HTTP and their role in RESTful APIs?
- Who is Roy Fielding, and what are the core principles of REST as outlined in his dissertation?
- In RESTful API design, why is it essential to distinguish between nouns and verbs? Provide an example of an appropriate noun-verb pairing in a REST API.
- List at least three common HTTP status codes and explain their meanings.
- What is idempotency, and why is it important in the context of REST APIs? Provide an example of an idempotent HTTP method.
- Describe the levels of Richardson’s Maturity Model. Why is each level a step toward a more RESTful API?
- Understanding the CAP Theorem
- Conway’s Law - A Key Consideration in Architecture
- The Twelve-Factor App
- Microservices Architecture Documentation
- Roy Fielding’s REST Dissertation
- HTTP Status Codes
- Richardson's Maturity Model
-
Recap of 12-Factor Configuration
- Separation of Configuration from Code: Reinforcing the principle of externalizing configuration to make applications more flexible and scalable, especially in distributed environments.
- Environment Variables for Configuration: Understanding the use of environment variables for managing application settings across various environments (development, staging, production).
- Configuration in Modern Technologies:
- Spring Boot: Managing settings such as database connections and ports using
application.properties
orapplication.yml
files to keep them outside the core application logic. - Docker: Externalizing configuration with
docker-compose
files,docker run
commands (e.g.,-e
for environment variables and-p
for port mapping), and avoiding hardcoding in Dockerfiles to support flexibility. - Kubernetes: Using ConfigMaps and Secrets to manage application settings, making it easy to adjust configurations dynamically without rebuilding containers.
- Spring Boot: Managing settings such as database connections and ports using
-
Lookout on lab
By the end of this lecture, students will be able to:
- Explain the importance of separating configuration from code, specifically in the context of distributed systems.
- Relate the configuration principle of the 12-factor methodology to technologies such as Spring Boot, Docker, and Kubernetes.
- Describe how these technologies implement configuration externalization to support flexibility, scalability, and best practices in distributed systems.
- Discuss the impact of improper configuration management in distributed systems and the challenges of maintaining dynamic configuration across different environments.
-
Describe the configuration factor in the 12-factor methodology. Why is it essential for distributed systems, and how is it implemented in Spring Boot, Docker, and Kubernetes?
Example Answer: In distributed systems, configuration often varies between environments. Spring Boot usesapplication.properties
files for settings like database connections and ports, Docker supports configuration viadocker-compose
anddocker run
options, and Kubernetes uses ConfigMaps and Secrets. -
What happens if you store port configuration directly in your source code?
Answer: The port configuration becomes fixed, requiring a rebuild of the application if changes are needed. Externalizing this allows easy updates without code changes. -
Why is external configuration more crucial for a distributed system than a monolithic application?
Answer: Distributed systems often require dynamic configuration changes across multiple services or containers, whereas monolithic applications generally have fewer, more static configuration needs. -
Why isn’t the Dockerfile suited for storing external configurations? How can you apply configurations in a Docker environment?
Answer: Dockerfiles are designed for building images, not for external settings that may change. Configuration should be applied at runtime usingdocker-compose
or thedocker run
command with-e
for environment variables and-p
for port mapping.
- The Twelve-Factor App: Configuration
- Spring Boot Externalized Configuration
- Docker Environment Variables and Configurations
- Kubernetes ConfigMaps and Secrets
Certainly! Here’s the revised summary with a more concise structure for points 2, 3, and 4:
-
Introduction to Persistence, ORM, Spring Data, and Spring Data JPA
- Persistence and ORM: Discussed the importance of persistence for long-term data storage, introducing ORM as a way to map objects to relational database tables seamlessly.
- Spring Data JPA: Explored how Spring Data JPA simplifies data access through repository interfaces, enabling easy CRUD operations and custom queries without boilerplate code.
-
Enhancing the Spring Boot Application with PostgreSQL
- Transitioned the shopping list storage from
ArrayList
to a PostgreSQL database using Spring Data JPA, refining endpoints for CRUD operations and adding logic to update item quantities based on names.
- Transitioned the shopping list storage from
-
Developing a Flask Frontend
- Built a Flask-based frontend for interacting with the Spring Boot API, configuring the Flask app to retrieve the API URL from environment variables and perform CRUD actions on shopping list items.
-
Dockerizing the Application Stack with Docker Compose
- Containerized both the Spring Boot and Flask apps using Dockerfiles alongside PostgreSQL and using a single Docker Compose file to manage and deploy the full application stack in a multi-container environment.
Students should be able to:
- Explain the concepts of persistence and ORM and identify their importance in distributed, database-driven applications.
- Set up Spring Data JPA to interact with a relational database and configure it using Docker Compose.
- Describe the benefits of Dockerization for both frontend and backend applications and use Docker Compose to manage and deploy a complete multi-container setup.
Exercise: Use this as a reference implementation to build your component as described in Lab Exercise
-
What is Object-Relational Mapping (ORM), and why is it beneficial for a database-backed application?
-
Explain how Spring Data JPA helps in managing CRUD operations in a database.
-
How does Docker Compose facilitate the deployment and management of the Spring Boot app, Flask frontend, and PostgreSQL database in a single environment?
-
Describe the purpose of externalizing configuration, and explain how it was implemented in this lab using Docker and environment variables.
-
Why is enabling a non-localhost API connection important for a frontend service like Flask, and how does Docker Compose make this possible?
-
Extending Docker Compose for Scaling and Load-Balancing
- Demonstrated how to scale services using Docker Compose to handle increased traffic or workloads.
- Explored Docker’s limitations in advanced network traffic control and routing options.
-
Introducing Nginx as a Reverse Proxy
- Configured Nginx as a reverse proxy to route traffic between the frontend and backend services efficiently.
- Discussed its role in improving request handling and enabling basic load balancing.
-
Alternatives to Nginx
- Briefly introduced other reverse proxy and load-balancing tools, such as Envoy and HAProxy, highlighting their use cases and differences compared to Nginx.
-
Adding Additional Services to the Docker Compose Network
- Showed how to extend the Docker Compose file by adding more containers and explained how they automatically join the shared network, simplifying service integration.
Students should be able to:
- Configure and scale services in a Docker Compose environment for load balancing.
- Set up and utilize Nginx as a reverse proxy for routing and basic load balancing.
- Extend Docker Compose configurations with additional services and understand how they integrate into the network.
- How can you scale a service in Docker Compose, and what are the limitations of this approach?
- Explain the role of a reverse proxy in a distributed application and why Nginx is a popular choice for this purpose.
- What advantages do alternatives like Envoy or HAProxy offer over Nginx in certain use cases?
- When adding a new service to a Docker Compose setup, how does Docker ensure it integrates into the network?
- What network traffic limitations exist in Docker, and how can tools like reverse proxies help mitigate them?
-
Introduction to Kubernetes
- What is Kubernetes?: High-level overview of Kubernetes as a container orchestration platform.
- Why Kubernetes?: Key benefits, including scalability, fault tolerance, and management of containerized applications.
-
Kubernetes Cluster Architecture
- Control Plane and Worker Nodes: Explanation of the roles and responsibilities of the control plane and worker nodes in a Kubernetes cluster.
- Key Components: Overview of critical components like
kube-apiserver
,etcd
,kube-scheduler
,kube-controller-manager
, andkubelet
.
-
Declarative Working Mode
- Configuration as Code: Introduction to Kubernetes' declarative approach for managing application state using YAML manifests.
- Reconciliation Loop: How Kubernetes ensures desired state matches the actual state through its control loop.
-
Most Important API Objects
- Pods: The smallest deployable unit in Kubernetes, representing one or more containers.
- ReplicaSets: Ensuring the desired number of pod replicas are running.
- Deployments: Managing updates and rollbacks for applications.
- Services: Enabling communication between pods and exposing applications to external users.
Students should be able to:
- Explain what Kubernetes is, why it is used, and its primary benefits.
- Describe the architecture of a Kubernetes cluster and the roles of its key components.
- Demonstrate understanding of the declarative approach for managing applications in Kubernetes.
- Identify and explain the purpose of key Kubernetes API objects, including pods, ReplicaSets, deployments, and services.
- What is Kubernetes, and why is it essential for managing containerized applications?
- Describe the roles of the control plane and worker nodes in a Kubernetes cluster.
- What is the function of the
kube-apiserver
andetcd
in Kubernetes? - Explain Kubernetes’ declarative working mode. How does the reconciliation loop ensure consistency?
- What is a pod in Kubernetes, and how does it differ from a container?
- How do ReplicaSets help ensure application reliability?
- What are deployments in Kubernetes, and how do they simplify updates and rollbacks?
- How do services in Kubernetes enable communication between pods and expose applications externally?
This lecture provides an introduction to Kubernetes deployment options and revisits essential Kubernetes API objects in greater detail. Students will explore free Kubernetes trials offered by major cloud providers, local deployment tools like Minikube and Kind, and how to use Kubernetes in cloud-based IDEs like GitHub Codespaces. The session also deepens understanding of fundamental API objects such as Pods, Deployments, and Services, equipping students with practical knowledge for managing containerized applications in Kubernetes.
By the end of this lecture, students will be able to:
- Identify and compare Kubernetes deployment options, including cloud trials and local setups.
- Set up a Kubernetes cluster locally using tools like Minikube or Kind, and within GitHub Codespaces.
- Describe the roles and relationships of basic Kubernetes API objects, including Pods, Deployments, and Services.
- Deploy and manage containerized applications using Kubernetes API objects.
- What are the advantages and limitations of using Kubernetes free trials from cloud providers compared to local tools like Minikube?
- How does Minikube enable Kubernetes functionality within a GitHub Codespaces environment?
- What is the role of a Pod in Kubernetes, and how does it differ from a Deployment?
- How do Services enable communication between Kubernetes Pods and external clients?
- How can you use a Deployment to ensure high availability for an application in Kubernetes?