ALL > Computer and Education > courses > university courses > graduate courses > modern operating system > ZSTU-(2019-2020-2) Class > student directories > Deep L20192E060107 >
Homework 05: write a review paper about communication technologies in distributed systems , submit one choice question for the exam database and one dialog for self tutor. Version 0
👤 Author: by shekhdeepgmailcom 2020-05-17 12:50:47
Definition

A distributed system, also known as distributed computing, is a system with multiple components located on different machines that communicate and coordinate actions in order to appear as a single coherent system to the end-user.

Overview

The machines that are a part of a distributed system may be computers, physical servers, virtual machines, containers, or any other node that can connect to the network, have local memory, and communicate by passing messages.

There are two general ways that distributed systems function:

  1. Each machine works toward a common goal and the results of the end-user view as one cohesive unit.

  2. Each machine has its own end-user and the distributed system facilitates sharing resources or communication services.


Although distributed systems can sometimes be obscure, they usually have three primary characteristics: all components run concurrently, there is no global clock, and all components fail independently of each other.

Benefits and challenges of distributed systems

There are three reasons that teams generally decide to implement distributed systems:

  • Horizontal Scalability— since computing happens independently on each node, it is easy and generally inexpensive to add additional nodes and functionality as necessary.

  • Reliability— most distributed systems are fault-tolerant as they can be made up of hundreds of nodes that work together. The system generally doesn’t experience any disruptions if a single machine fails.

  • Performance—Distributed systems are extremely efficient because workloads can be broken up and sent to multiple machines.


However, distributed systems are not without challenges. Complex architectural design, construction, and debugging processes that are required to create an effective distributed system can be overwhelming.

Three more challenges you may encounter include:

  • Scheduling—a distributed system has to decide which jobs need to run, when they should run, and where they should run. Schedulers ultimately have limitations, leading to underutilized hardware and unpredictable runtimes.

  • Latency—the more widely your system is distributed, the more latency you can experience with communications. This often leads to teams making tradeoffs between availability, consistency, and latency.

  • Observability—Gathering, processing, presenting, and monitoring hardware usage metrics for large clusters is a significant challenge.


How a Distributed System Works

Hardware and software architectures are used to maintain a distributed system. Everything must be interconnected—CPUs via the network and processes via the communication system.

Types of distributed systems

Distributed systems generally fall into one of four different basic architecture models:

  1. Client-server—Clients contact the server for data, then format it and display it to the end-user. The end-user can also make a change from the client-side and commit it back to the server to make it permanent.

  2. Three-tier—Information about the client is stored in a middle-tier rather than on the client to simplify application deployment. This architecture model is most common for web applications.

  3. N-tier—generally used when an application or server needs to forward requests to additional enterprise services on the network.

  4. Peer-to-peer—there are no additional machines used to provide services or manage resources. Responsibilities are uniformly distributed among machines in the system, known as peers, which can serve as either client or server.


Example of a Distributed System

Distributed systems have endless use cases, a few being electronic banking systems, massively multiplayer online games, and sensor networks.

StackPath utilizes a particularly large distributed system to power its content delivery network service. Every one of our points of presence (PoPs) has nodes that form a worldwide distributed system. And to provide top-notch content delivery, StackPath stores the most recently and frequently requested content in edge locations closest to the location it is being used.

Distributed systems at the edge

With StackPath’s edge compute services, virtual machines, and containers, users can create their own distributed systems. By interconnecting VMs and containers, while also leveraging the speed and agility that comes with edge computing, your system can handle thousands of simultaneous requests at a lightning-fast speed.

Key Takeaways

  • Distributed systems can be made up of any machine capable of connecting to a network, having local memory, and communicating by passing messages.

  • By spreading out requests and workloads, distributed systems can support far more requests and compute jobs than a standard single system.

  • You can create your own lightning-fast distributed system by interconnecting Stack Path’s edge computing containers and virtual machines.


 

Please login to reply. Login

Reversion History

Loading...
No reversions found.