Unicamp MC714 Distributed Systems Slides by Maarten van Steen, - - PowerPoint PPT Presentation

unicamp mc714
SMART_READER_LITE
LIVE PREVIEW

Unicamp MC714 Distributed Systems Slides by Maarten van Steen, - - PowerPoint PPT Presentation

Unicamp MC714 Distributed Systems Slides by Maarten van Steen, adapted from Distributed Systems, 3rd edition Chapter 01: Introduction Informac oes sobre a disciplina: MC714 Sistemas Distrubu dos Professor Lucas Wanner


slide-1
SLIDE 1

Unicamp MC714

Distributed Systems

Slides by Maarten van Steen, adapted from Distributed Systems, 3rd edition

Chapter 01: Introduction

slide-2
SLIDE 2

Informac ¸ ˜

  • es sobre a disciplina:

MC714 – Sistemas Distrubu´ ıdos

Professor Lucas Wanner – lucas@ic.unicamp.br Hor´ ario Terc ¸as 21:00-23:00, Sala CB XX Quintas 19:00-21:00, Sala CB XX Website http://www.lucaswanner.com/sd Lista de Emails https://groups.google.com/d/forum/sd-2017-2 Todos os alunos matriculados foram adicionados ` a lista com seus emails da DAC. Solicite ingresso na lista caso n˜ ao tenha recebido notificac ¸ ˜ ao.

2 / 55

slide-3
SLIDE 3

Informac ¸ ˜

  • es sobre a disciplina:

MC714 – Sistemas Distrubu´ ıdos

Ementa

  • Sistemas Distribu´

ıdos • Comunicac ¸ ˜ ao entre processos • Sistemas de arquivos • Servic ¸os de nomes • Coordenac ¸ ˜ ao • Replicac ¸ ˜ ao

  • Seguranc

¸a Bibliografia Texto principal: A. S. Tanenbaum and M. Van Steen. Distributed Systems: Principles and Paradigms. 3rd ed., 2017. Link para download na p´ agina do curso. Coulouris, J. Dollimore, T. Kindberg, and G. Blair. Distributed Systems: Concepts and Design. 5th ed., Addison-Wesley, 2011. A.D. Kshemkalyani, M. Singhal, Distributed Computing: Principles, Algorithms, and Systems. Paperback ed., Cambridge University Press, 2011.

3 / 55

slide-4
SLIDE 4

Informac ¸ ˜

  • es sobre a disciplina:

Programa: Primeira Parte

  • pico

Cap´ ıtulo Introduc ¸ ˜ ao e Fundamentos 1 Arquituras de sistemas distribu´ ıdos 2 Processos e Threads Revis˜ ao, 3 Clientes/Servidores, Virtualizac ¸ ˜ ao e N´ uvem 3 Comunicac ¸ ˜ ao: Revis˜ ao, Sockets, Troca de Mensagens Revis˜ ao, 4 Multicast, Disseminac ¸ ˜ ao de informac ¸ ˜ ao 4 Remote Procedure Call 4 Nomeac ¸ ˜ ao 5 Sincronizac ¸ ˜ ao de rel´

  • gio, Rel´
  • gios L´
  • gicos

6 Exclus˜ ao m´ utua 6 Eleic ¸ ˜ ao de l´ ıder 6

4 / 55

slide-5
SLIDE 5

Informac ¸ ˜

  • es sobre a disciplina:

Programa: Segunda Parte

  • pico

Cap´ ıtulo Consistˆ encia: Fundamentos, Modelos 7 Replicac ¸ ˜ ao: Gerˆ encia, Distribuic ¸ ˜ ao de conte´ udo 7 Tolerˆ ancia a falhas: Fundamentos 8 Commit distribu´ ıdo 8 Recuperac ¸ ˜ ao, Checkpointing 8 PAXOS 8 Sistemas de Arquivos 2nd ed. 11 P2P: Introduc ¸ ˜ ao, Distributed Hash Table (DHT) Coulouris 10 P2P: Chrod, Kademlia, BitTorrent Singhal 18 Web: AHTTP , SOAP , Caching 2nd ed. 12

5 / 55

slide-6
SLIDE 6

Informac ¸ ˜

  • es sobre a disciplina:

Avaliac ¸ ˜ ao

Componentes Provas: (P) Ser˜ ao aplicadas duas provas te´

  • ricas, P1 e P2.

Semin´ arios: (S) Semin´ arios ser˜ ao apresentados em sala de aula. Os grupos, datas, e t´

  • picos para apresentac

¸ ˜ ao ser˜ ao definidos durante o semestre. Testes: (T) Ser˜ ao aplicados uma s´ erie de pequenos testes e exerc´ ıcios de implementac ¸ ˜

  • ao. A nota dos testes T ser´

a a m´ edia aritm´ etica entre

  • s testes aplicados.

Pol´ ıtica de atraso Cada dia em atraso implicar´ a em um desconto de 2.5/10 pontos para cada entreg´ avel.

6 / 55

slide-7
SLIDE 7

Informac ¸ ˜

  • es sobre a disciplina:

Avaliac ¸ ˜ ao

M´ edia A m´ edia M da disciplina ser´ a calculada como: M = P1 ×0.3+P2 ×0.35+T ×0.2+S ×0.15 Exame Alunos com m´ edia 2.5 ≤ M < 5 poder˜ ao fazer um exame final (E). Nota final A nota final F ser´ a calculada como: F =

  • min {5, M+E

2

} caso 2.5 ≤ M < 5 e o aluno tenha feito exame. M caso contr´ ario.

7 / 55

slide-8
SLIDE 8

Informac ¸ ˜

  • es sobre a disciplina:

Avaliac ¸ ˜ ao

Datas Importantes P1: 21/09/2017 P2: 23/11/2017 Exame: 12/12/2017

8 / 55

slide-9
SLIDE 9

Informac ¸ ˜

  • es sobre a disciplina:

Integridade Acadˆ emica

Pol´ ıtica de tolerˆ ancia zero Toda e qualquer violac ¸ ˜ ao de integridade acadˆ emica ser´ a punida at´ e o limite da autoridade do professor, incluindo mas n˜ ao limitado ` a nota zero na m´ edia final do curso para todos os envolvidos. Exemplos (n˜ ao exaustivos) de violac ¸ ˜

  • es

Cola e pl´ agio Compartilhamento de soluc ¸ ˜

  • es e c´
  • digo (e.g., “dar uma olhada” no

  • digo)

Falsificac ¸ ˜ ao de dados e resultados N˜ ao violac ¸ ˜

  • es

Grupos de estudo Discuss˜ ao de estrat´ egias de implementac ¸ ˜ ao, excluindo detalhes de c´

  • digo

9 / 55

slide-10
SLIDE 10

Informac ¸ ˜

  • es sobre a disciplina:

Avaliac ¸ ˜ ao

Como ir bem no curso (em ordem de importˆ ancia)

1

Resolver os exerc´ ıcios de cada aula.

2

Ler os cap´ ıtulos do livro antes da aula correspondente.

3

Entregar soluc ¸ ˜

  • es para testes dentro do prazo.

4

Fazer uma boa apresentac ¸ ˜ ao no semin´ ario.

5

Assistir ` as aulas.

10 / 55

slide-11
SLIDE 11

Informac ¸ ˜

  • es sobre a disciplina:

Estilo das Aulas

1

Revis˜ ao breve da aula anterior.

2

Discuss˜ ao dos exerc´ ıcos da aula anterior.

3

Apresentac ¸ ˜ ao das perguntas para a aula.

4

Conte´ udo.

5

(em algumas aulas) Testes. Participac ¸ ˜ ao Participac ¸ ˜ ao ser´ a ativamente encorajada na discuss˜ ao, revis˜ ao, e apresentac ¸ ˜ ao do conte´ udo.

11 / 55

slide-12
SLIDE 12

Informac ¸ ˜

  • es sobre a disciplina:

Exerc´ ıcios

1

Defina e compare sistemas distribu´ ıdos e sistemas paralelos.

2

Qual ´ e o papel de um middleware em sistemas distribu´ ıdos?

3

Dˆ e exemplos e defina diferentes tipos de transparˆ encia de distribuic ¸ ˜ ao.

4

Qual ´ e a diferenc ¸a entre transparˆ encia de migrac ¸ ˜ ao e transparˆ encia de relocac ¸ ˜ ao?

5

Defina escalabilidade. Quais t´ ecnicas s˜ ao usadas para atingir escalabilidade?

6

Qual ´ e a diferenc ¸a entre replicac ¸ ˜ ao e caching?

7

A vis˜ ao tradicional de transac ¸ ˜

  • es diz que quando uma transac

¸ ˜ ao ´ e abortada, ´ e como se a transac ¸ ˜ ao nunca tivesse acontecido. Dˆ e um exemplo onde isto n˜ ao ´ e verdade.

12 / 55

slide-13
SLIDE 13

Introduction: What is a distributed system?

Distributed System

Definition A distributed system is a collection of autonomous computing elements that appears to its users as a single coherent system. Characteristic features Autonomous computing elements, also referred to as nodes, be they hardware devices or software processes. Single coherent system: users or applications perceive a single system ⇒ nodes need to collaborate.

13 / 55

slide-14
SLIDE 14

Introduction: What is a distributed system?

Distributed System: Alternative Definition

You know you have [a distributed system] when the crash of a computer you’ve never heard of stops you from getting any work done.

  • Leslie Lamport

14 / 55

slide-15
SLIDE 15

Introduction: What is a distributed system? Characteristic 1: Collection of autonomous computing elements

Collection of autonomous nodes

Independent behavior Each node is autonomous and will thus have its own notion of time: there is no global clock. Leads to fundamental synchronization and coordination problems. Collection of nodes How to manage group membership? How to know that you are indeed communicating with an authorized (non)member?

15 / 55

slide-16
SLIDE 16

Introduction: What is a distributed system? Characteristic 1: Collection of autonomous computing elements

Organization

Overlay network Each node in the collection communicates only with other nodes in the system, its neighbors. The set of neighbors may be dynamic, or may even be known

  • nly implicitly (i.e., requires a lookup).

Overlay types Well-known example of overlay networks: peer-to-peer systems. Structured: each node has a well-defined set of neighbors with whom it can communicate (tree, ring). Unstructured: each node has references to randomly selected other nodes from the system.

16 / 55

slide-17
SLIDE 17

Introduction: What is a distributed system? Characteristic 2: Single coherent system

Coherent system

Essence The collection of nodes as a whole operates the same, no matter where, when, and how interaction between a user and the system takes place. Examples An end user cannot tell where a computation is taking place Where data is exactly stored should be irrelevant to an application If or not data has been replicated is completely hidden Keyword is distribution transparency The snag: partial failures It is inevitable that at any time only a part of the distributed system fails. Hiding partial failures and their recovery is often very difficult and in general impossible to hide.

17 / 55

slide-18
SLIDE 18

Introduction: What is a distributed system? Middleware and distributed systems

Middleware: the OS of distributed systems

Local OS 1 Local OS 2 Local OS 3 Local OS 4

  • Appl. A

Application B

  • Appl. C

Distributed-system layer (middleware) Computer 1 Computer 2 Computer 3 Computer 4 Same interface everywhere Network

What does it contain? Commonly used components and functions that need not be implemented by applications separately.

18 / 55

slide-19
SLIDE 19

Introduction: Design goals

What do we want to achieve?

Support sharing of resources Distribution transparency Openness Scalability

19 / 55

slide-20
SLIDE 20

Introduction: Design goals Supporting resource sharing

Sharing resources

Canonical examples Cloud-based shared storage and files Peer-to-peer assisted multimedia streaming Shared mail services (think of outsourced mail systems) Shared Web hosting (think of content distribution networks) Observation “The network is the computer” (quote from John Gage, then at Sun Microsystems)

20 / 55

slide-21
SLIDE 21

Introduction: Design goals Making distribution transparent

Distribution transparency

Types Transparency Description Access Hide differences in data representation and how an

  • bject is accessed

Location Hide where an object is located Relocation Hide that an object may be moved to another location while in use Migration Hide that an object may move to another location Replication Hide that an object is replicated Concurrency Hide that an object may be shared by several independent users Failure Hide the failure and recovery of an object

Types of distribution transparency 21 / 55

slide-22
SLIDE 22

Introduction: Design goals Making distribution transparent

Degree of transparency

Observation Aiming at full distribution transparency may be too much:

Degree of distribution transparency 22 / 55

slide-23
SLIDE 23

Introduction: Design goals Making distribution transparent

Degree of transparency

Observation Aiming at full distribution transparency may be too much: There are communication latencies that cannot be hidden

Degree of distribution transparency 22 / 55

slide-24
SLIDE 24

Introduction: Design goals Making distribution transparent

Degree of transparency

Observation Aiming at full distribution transparency may be too much: There are communication latencies that cannot be hidden Completely hiding failures of networks and nodes is (theoretically and practically) impossible You cannot distinguish a slow computer from a failing one You can never be sure that a server actually performed an operation before a crash

Degree of distribution transparency 22 / 55

slide-25
SLIDE 25

Introduction: Design goals Making distribution transparent

Degree of transparency

Observation Aiming at full distribution transparency may be too much: There are communication latencies that cannot be hidden Completely hiding failures of networks and nodes is (theoretically and practically) impossible You cannot distinguish a slow computer from a failing one You can never be sure that a server actually performed an operation before a crash Full transparency will cost performance, exposing distribution of the system Keeping replicas exactly up-to-date with the master takes time Immediately flushing write operations to disk for fault tolerance

Degree of distribution transparency 22 / 55

slide-26
SLIDE 26

Introduction: Design goals Making distribution transparent

Degree of transparency

Exposing distribution may be good Making use of location-based services (finding your nearby friends) When dealing with users in different time zones When it makes it easier for a user to understand what’s going on (when e.g., a server does not respond for a long time, report it as failing).

Degree of distribution transparency 23 / 55

slide-27
SLIDE 27

Introduction: Design goals Making distribution transparent

Degree of transparency

Exposing distribution may be good Making use of location-based services (finding your nearby friends) When dealing with users in different time zones When it makes it easier for a user to understand what’s going on (when e.g., a server does not respond for a long time, report it as failing). Conclusion Distribution transparency is a nice a goal, but achieving it is a different story, and it should often not even be aimed at.

Degree of distribution transparency 23 / 55

slide-28
SLIDE 28

Introduction: Design goals Being open

Openness of distributed systems

What are we talking about? Be able to interact with services from other open systems, irrespective of the underlying environment: Systems should conform to well-defined interfaces Systems should easily interoperate Systems should support portability of applications Systems should be easily extensible

Interoperability, composability, and extensibility 24 / 55

slide-29
SLIDE 29

Introduction: Design goals Being open

Policies versus mechanisms

Implementing openness: policies What level of consistency do we require for client-cached data? Which operations do we allow downloaded code to perform? Which QoS requirements do we adjust in the face of varying bandwidth? What level of secrecy do we require for communication? Implementing openness: mechanisms Allow (dynamic) setting of caching policies Support different levels of trust for mobile code Provide adjustable QoS parameters per data stream Offer different encryption algorithms

Separating policy from mechanism 25 / 55

slide-30
SLIDE 30

Introduction: Design goals Being open

On strict separation

Observation The stricter the separation between policy and mechanism, the more we need to make ensure proper mechanisms, potentially leading to many configuration parameters and complex management. Finding a balance Hard coding policies often simplifies management and reduces complexity at the price of less flexibility. There is no obvious solution.

Separating policy from mechanism 26 / 55

slide-31
SLIDE 31

Introduction: Design goals Being scalable

Scale in distributed systems

Observation Many developers of modern distributed systems easily use the adjective “scalable” without making clear why their system actually scales.

Scalability dimensions 27 / 55

slide-32
SLIDE 32

Introduction: Design goals Being scalable

Scale in distributed systems

Observation Many developers of modern distributed systems easily use the adjective “scalable” without making clear why their system actually scales. At least three components Number of users and/or processes (size scalability) Maximum distance between nodes (geographical scalability) Number of administrative domains (administrative scalability)

Scalability dimensions 27 / 55

slide-33
SLIDE 33

Introduction: Design goals Being scalable

Scale in distributed systems

Observation Many developers of modern distributed systems easily use the adjective “scalable” without making clear why their system actually scales. At least three components Number of users and/or processes (size scalability) Maximum distance between nodes (geographical scalability) Number of administrative domains (administrative scalability) Observation Most systems account only, to a certain extent, for size scalability. Often a solution: multiple powerful servers operating independently in parallel. Today, the challenge still lies in geographical and administrative scalability.

Scalability dimensions 27 / 55

slide-34
SLIDE 34

Introduction: Design goals Being scalable

Size scalability

Root causes for scalability problems with centralized solutions The computational capacity, limited by the CPUs The storage capacity, including the transfer rate between CPUs and disks The network between the user and the centralized service

Scalability dimensions 28 / 55

slide-35
SLIDE 35

Introduction: Design goals Being scalable

Problems with geographical scalability

Cannot simply go from LAN to WAN: many distributed systems assume synchronous client-server interactions: client sends request and waits for an answer. Latency may easily prohibit this scheme. WAN links are often inherently unreliable: simply moving streaming video from LAN to WAN is bound to fail. Lack of multipoint communication, so that a simple search broadcast cannot be deployed. Solution is to develop separate naming and directory services (having their own scalability problems).

Scalability dimensions 29 / 55

slide-36
SLIDE 36

Introduction: Design goals Being scalable

Problems with administrative scalability

Essence Conflicting policies concerning usage (and thus payment), management, and security Examples Computational grids: share expensive resources between different domains. Shared equipment: how to control, manage, and use a shared radio telescope constructed as large-scale shared sensor network? Exception: several peer-to-peer networks File-sharing systems (based, e.g., on BitTorrent) Peer-to-peer telephony (Skype) Peer-assisted audio streaming (Spotify) Note: end users collaborate and not administrative entities.

Scalability dimensions 30 / 55

slide-37
SLIDE 37

Introduction: Design goals Being scalable

Techniques for scaling

Hide communication latencies Make use of asynchronous communication Have separate handler for incoming response Problem: not every application fits this model

Scaling techniques 31 / 55

slide-38
SLIDE 38

Introduction: Design goals Being scalable

Techniques for scaling

Facilitate solution by moving computations to client

M A A R T E N

FIRST NAME LAST NAME E-MAIL

Server Client Check form Process form

MAARTEN MVS VAN-STEEN.NET @ VAN STEEN

FIRST NAME LAST NAME E-MAIL

Server Client Check form Process form

MAARTEN MVS@VAN-STEEN.NET VAN STEEN MAARTEN VAN STEEN MVS@VAN-STEEN.NET

Scaling techniques 32 / 55

slide-39
SLIDE 39

Introduction: Design goals Being scalable

Techniques for scaling

Partition data and computations across multiple machines Move computations to clients (Java applets) Decentralized naming services (DNS) Decentralized information systems (WWW)

Scaling techniques 33 / 55

slide-40
SLIDE 40

Introduction: Design goals Being scalable

Techniques for scaling

Replication and caching: Make copies of data available at different machines Replicated file servers and databases Mirrored Web sites Web caches (in browsers and proxies) File caching (at server and client)

Scaling techniques 34 / 55

slide-41
SLIDE 41

Introduction: Design goals Being scalable

Scaling: The problem with replication

Applying replication is easy, except for one thing

Scaling techniques 35 / 55

slide-42
SLIDE 42

Introduction: Design goals Being scalable

Scaling: The problem with replication

Applying replication is easy, except for one thing Having multiple copies (cached or replicated), leads to inconsistencies: modifying one copy makes that copy different from the rest.

Scaling techniques 35 / 55

slide-43
SLIDE 43

Introduction: Design goals Being scalable

Scaling: The problem with replication

Applying replication is easy, except for one thing Having multiple copies (cached or replicated), leads to inconsistencies: modifying one copy makes that copy different from the rest. Always keeping copies consistent and in a general way requires global synchronization on each modification.

Scaling techniques 35 / 55

slide-44
SLIDE 44

Introduction: Design goals Being scalable

Scaling: The problem with replication

Applying replication is easy, except for one thing Having multiple copies (cached or replicated), leads to inconsistencies: modifying one copy makes that copy different from the rest. Always keeping copies consistent and in a general way requires global synchronization on each modification. Global synchronization precludes large-scale solutions.

Scaling techniques 35 / 55

slide-45
SLIDE 45

Introduction: Design goals Being scalable

Scaling: The problem with replication

Applying replication is easy, except for one thing Having multiple copies (cached or replicated), leads to inconsistencies: modifying one copy makes that copy different from the rest. Always keeping copies consistent and in a general way requires global synchronization on each modification. Global synchronization precludes large-scale solutions. Observation If we can tolerate inconsistencies, we may reduce the need for global synchronization, but tolerating inconsistencies is application dependent.

Scaling techniques 35 / 55

slide-46
SLIDE 46

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made.

36 / 55

slide-47
SLIDE 47

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions

36 / 55

slide-48
SLIDE 48

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable

36 / 55

slide-49
SLIDE 49

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable The network is secure

36 / 55

slide-50
SLIDE 50

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable The network is secure The network is homogeneous

36 / 55

slide-51
SLIDE 51

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable The network is secure The network is homogeneous The topology does not change

36 / 55

slide-52
SLIDE 52

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable The network is secure The network is homogeneous The topology does not change Latency is zero

36 / 55

slide-53
SLIDE 53

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable The network is secure The network is homogeneous The topology does not change Latency is zero Bandwidth is infinite

36 / 55

slide-54
SLIDE 54

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable The network is secure The network is homogeneous The topology does not change Latency is zero Bandwidth is infinite Transport cost is zero

36 / 55

slide-55
SLIDE 55

Introduction: Design goals Pitfalls

Developing distributed systems: Pitfalls

Observation Many distributed systems are needlessly complex caused by mistakes that required patching later on. Many false assumptions are often made. False (and often hidden) assumptions The network is reliable The network is secure The network is homogeneous The topology does not change Latency is zero Bandwidth is infinite Transport cost is zero There is one administrator

36 / 55

slide-56
SLIDE 56

Introduction: Types of distributed systems

Three types of distributed systems

High performance distributed computing systems Distributed information systems Distributed systems for pervasive computing

37 / 55

slide-57
SLIDE 57

Introduction: Types of distributed systems High performance distributed computing

Parallel computing

Observation High-performance distributed computing started with parallel computing Multiprocessor and multicore versus multicomputer

Shared memory Processor P P P P M M M Interconnect Private memory Memory P P P P M M M M Interconnect

38 / 55

slide-58
SLIDE 58

Introduction: Types of distributed systems High performance distributed computing

Distributed shared memory systems

Observation Multiprocessors are relatively easy to program in comparison to multicomputers, yet have problems when increasing the number of processors (or cores). Solution: Try to implement a shared-memory model on top of a multicomputer. Example through virtual-memory techniques Map all main-memory pages (from different processors) into one single virtual address space. If process at processor A addresses a page P located at processor B, the OS at A traps and fetches P from B, just as it would if P had been located on local disk. Problem Performance of distributed shared memory could never compete with that of multiprocessors, and failed to meet the expectations of programmers. It has been widely abandoned by now.

39 / 55

slide-59
SLIDE 59

Introduction: Types of distributed systems High performance distributed computing

Cluster computing

Essentially a group of high-end systems connected through a LAN Homogeneous: same OS, near-identical hardware Single managing node

Local OS Local OS Local OS Local OS Standard network Component

  • f

parallel application Component

  • f

parallel application Component

  • f

parallel application Parallel libs Management application High-speed network Remote access network Master node Compute node Compute node Compute node

Cluster computing 40 / 55

slide-60
SLIDE 60

Introduction: Types of distributed systems High performance distributed computing

Grid computing

The next step: lots of nodes from everywhere Heterogeneous Dispersed across several organizations Can easily span a wide-area network Note To allow for collaborations, grids generally use virtual organizations. In essence, this is a grouping of users (or better: their IDs) that will allow for authorization on resource allocation.

Grid computing 41 / 55

slide-61
SLIDE 61

Introduction: Types of distributed systems High performance distributed computing

Cloud computing

Application Infrastructure Computation (VM) torage (block ) , s , file Hardware Platforms Software framework (Java/Python/.Net) Storage ( ) databases Infrastructure aa Svc Platform aa Svc Software

aa Svc

MS Azure Google App engine Amazon S3 Amazon EC2 Datacenters CPU, memory, disk, bandwidth Web services, multimedia, business apps Google docs Gmail YouTube, Flickr

Cloud computing 42 / 55

slide-62
SLIDE 62

Introduction: Types of distributed systems High performance distributed computing

Cloud computing

Make a distinction between four layers Hardware: Processors, routers, power and cooling systems. Customers normally never get to see these. Infrastructure: Deploys virtualization techniques. Evolves around allocating and managing virtual storage devices and virtual servers. Platform: Provides higher-level abstractions for storage and such. Example: Amazon S3 storage system offers an API for (locally created) files to be organized and stored in so-called buckets. Application: Actual applications, such as office suites (text processors, spreadsheet applications, presentation applications). Comparable to the suite of apps shipped with OSes.

Cloud computing 43 / 55

slide-63
SLIDE 63

Introduction: Types of distributed systems Distributed information systems

Integrating applications

Situation Organizations confronted with many networked applications, but achieving interoperability was painful. Basic approach A networked application is one that runs on a server making its services available to remote clients. Simple integration: clients combine requests for (different) applications; send that off; collect responses, and present a coherent result to the user. Next step Allow direct application-to-application communication, leading to Enterprise Application Integration.

44 / 55

slide-64
SLIDE 64

Introduction: Types of distributed systems Distributed information systems

Example EAI: (nested) transactions

Transaction

Primitive Description BEGIN TRANSACTION Mark the start of a transaction END TRANSACTION Terminate the transaction and try to commit ABORT TRANSACTION Kill the transaction and restore the old values READ Read data from a file, a table, or otherwise WRITE Write data to a file, a table, or otherwise

Issue: all-or-nothing

Airline database Hotel database Subtransaction Subtransaction Nested transaction Two different (independent) databases

Atomic: happens indivisibly (seemingly) Consistent: does not violate system invariants Isolated: not mutual interference Durable: commit means changes are permanent

Distributed transaction processing 45 / 55

slide-65
SLIDE 65

Introduction: Types of distributed systems Distributed information systems

TPM: Transaction Processing Monitor

TP monitor Server Server Server Client application Requests Reply Request Request Request Reply Reply Reply Transaction

Observation In many cases, the data involved in a transaction is distributed across several

  • servers. A TP Monitor is responsible for coordinating the execution of a

transaction.

Distributed transaction processing 46 / 55

slide-66
SLIDE 66

Introduction: Types of distributed systems Distributed information systems

Middleware and EAI

Server-side application Server-side application Server-side application Client application Client application Communication middleware

Middleware offers communication facilities for integration Remote Procedure Call (RPC): Requests are sent through local procedure call, packaged as message, processed, responded through message, and result returned as return from call. Message Oriented Middleware (MOM): Messages are sent to logical contact point (published), and forwarded to subscribed applications.

Enterprise application integration 47 / 55

slide-67
SLIDE 67

Introduction: Types of distributed systems Distributed information systems

How to integrate applications

File transfer: Technically simple, but not flexible: Figure out file format and layout Figure out file management Update propagation, and update notifications. Shared database: Much more flexible, but still requires common data scheme next to risk of bottleneck. Remote procedure call: Effective when execution of a series of actions is needed. Messaging: RPCs require caller and callee to be up and running at the same

  • time. Messaging allows decoupling in time and space.

Enterprise application integration 48 / 55

slide-68
SLIDE 68

Introduction: Types of distributed systems Pervasive systems

Distributed pervasive systems

Observation Emerging next-generation of distributed systems in which nodes are small, mobile, and often embedded in a larger system, characterized by the fact that the system naturally blends into the user’s environment. Three (overlapping) subtypes

49 / 55

slide-69
SLIDE 69

Introduction: Types of distributed systems Pervasive systems

Distributed pervasive systems

Observation Emerging next-generation of distributed systems in which nodes are small, mobile, and often embedded in a larger system, characterized by the fact that the system naturally blends into the user’s environment. Three (overlapping) subtypes Ubiquitous computing systems: pervasive and continuously present, i.e., there is a continuous interaction between system and user.

49 / 55

slide-70
SLIDE 70

Introduction: Types of distributed systems Pervasive systems

Distributed pervasive systems

Observation Emerging next-generation of distributed systems in which nodes are small, mobile, and often embedded in a larger system, characterized by the fact that the system naturally blends into the user’s environment. Three (overlapping) subtypes Ubiquitous computing systems: pervasive and continuously present, i.e., there is a continuous interaction between system and user. Mobile computing systems: pervasive, but emphasis is on the fact that devices are inherently mobile.

49 / 55

slide-71
SLIDE 71

Introduction: Types of distributed systems Pervasive systems

Distributed pervasive systems

Observation Emerging next-generation of distributed systems in which nodes are small, mobile, and often embedded in a larger system, characterized by the fact that the system naturally blends into the user’s environment. Three (overlapping) subtypes Ubiquitous computing systems: pervasive and continuously present, i.e., there is a continuous interaction between system and user. Mobile computing systems: pervasive, but emphasis is on the fact that devices are inherently mobile. Sensor (and actuator) networks: pervasive, with emphasis on the actual (collaborative) sensing and actuation of the environment.

49 / 55

slide-72
SLIDE 72

Introduction: Types of distributed systems Pervasive systems

Ubiquitous systems

Core elements

1

(Distribution) Devices are networked, distributed, and accessible in a transparent manner

2

(Interaction) Interaction between users and devices is highly unobtrusive

3

(Context awareness) The system is aware of a user’s context in order to

  • ptimize interaction

4

(Autonomy) Devices operate autonomously without human intervention, and are thus highly self-managed

5

(Intelligence) The system as a whole can handle a wide range of dynamic actions and interactions

Ubiquitous computing systems 50 / 55

slide-73
SLIDE 73

Introduction: Types of distributed systems Pervasive systems

Mobile computing

Distinctive features A myriad of different mobile devices (smartphones, tablets, GPS devices, remote controls, active badges. Mobile implies that a device’s location is expected to change over time ⇒ change of local services, reachability, etc. Keyword: discovery. Communication may become more difficult: no stable route, but also perhaps no guaranteed connectivity ⇒ disruption-tolerant networking.

Mobile computing systems 51 / 55

slide-74
SLIDE 74

Introduction: Types of distributed systems Pervasive systems

Sensor networks

Characteristics The nodes to which sensors are attached are: Many (10s-1000s) Simple (small memory/compute/communication capacity) Often battery-powered (or even battery-less)

Sensor networks 52 / 55

slide-75
SLIDE 75

Introduction: Types of distributed systems Pervasive systems

Sensor networks as distributed databases

Two extremes

Operator's site Sensor network Sensor data is sent directly to operator Operator's site Sensor network Query Sensors send only answers Each sensor can process and store data

Sensor networks 53 / 55

slide-76
SLIDE 76

Introduction: Types of distributed systems Pervasive systems

Duty-cycled networks

Issue Many sensor networks need to operate on a strict energy budget: introduce duty cycles Definition A node is active during Tactive time units, and then suspended for Tsuspended units, to become active again. Duty cycle τ: τ = Tactive Tactive +Tsuspended Typical duty cycles are 10−30%, but can also be lower than 1%.

Sensor networks 54 / 55

slide-77
SLIDE 77

Introduction: Types of distributed systems Pervasive systems

Keeping duty-cycled networks in sync

Issue If duty cycles are low, sensor nodes may not wake up at the same time anymore and become permanently disconnected: they are active during different, nonoverlapping time slots. Solution Each node A adopts a cluster ID CA, being a number. Let a node send a join message during its suspended period. When A receives a join message from B and CA < CB, it sends a join message to its neighbors (in cluster CA) before joining B. When CA > CB it sends a join message to B during B’s active period. Note Once a join message reaches a whole cluster, merging two clusters is very fast. Merging means: re-adjust clocks.

Sensor networks 55 / 55