Download presentation
Presentation is loading. Please wait.
Published byStanley McCarthy Modified over 9 years ago
1
Chapter 2: System Models Architectural Models Fundamental Models
2
Models zArchitectural Models ya high-level view of the distribution of functionality between components and the relationships between them. z Fundamental Models yThese are vertical views or slices, representing some key aspects of distributed systems. yEach fundamental model represents a set of issues that must be addressed in the design of distributed systems yInteraction model, failure model, security model
3
Figure 2.1 Software and hardware service layers in distributed systems
4
Figure 2.2 Clients invoke individual servers
5
Figure 2.3 A distributed application based on peer processes
6
Figure 2.4 A service provided by multiple servers
7
Figure 2.5 Web proxy server
8
Figure 2.6 Web applets
9
Figure 2.7 Thin clients and compute servers Thin Client Application Process Network computer or PC Compute server network
10
Interaction Models zPerformance of Communication Channels yDelay, Loss zUnsynchronized Clocks zSynchronous Model yExecution time bounded yCommunication delay bounded yClock drift bounded yWait the response zAsynchronous Model
11
Figure 2.8 Real-time ordering of events
12
Figure 2.9 Processes and channels
13
Figure 2.10 Omission and arbitrary failures Class of failureAffectsDescription Fail-stopProcessProcess halts and remains halted. Other processes may detect this state. CrashProcessProcess halts and remains halted. Other processes may not be able to detect this state. OmissionChannelA message inserted in an outgoing message buffer never arrives at the other end’s incoming message buffer. Send-omissionProcessA process completes asend, but the message is not put in its outgoing message buffer. Receive-omissionProcessA message is put in a process’s incoming message buffer, but that process does not receive it. Arbitrary (Byzantine) Process or channel Process/channel exhibits arbitrary behaviour: it may send/transmit arbitrary messages at arbitrary times, commit omissions; a process may stop or take an incorrect step.
14
Figure 2.11 Timing failures Class of FailureAffectsDescription ClockProcessProcess’s local clock exceeds the bounds on its rate of drift from real time. PerformanceProcessProcess exceeds the bounds on the interval between two steps. PerformanceChannelA message’s transmission takes longer than the stated bound.
15
Failures zProcesses and communication channels can fail. zThe classification of their failures is useful for the analysis of failures of protocols. zComponents that exhibit Byzantine or arbitrary failures may do anything at any time. zTiming failures occur only in synchronous systems. zMost failures in distributed systems are benign (e.g. omission but not Byzantine failures). zA service may mask the failures of the components from which it is constructed, for example, reliable one-to-one communication may be built by masking omission failures.
16
Figure 2.12 Objects and principals
17
Figure 2.13 The enemy Communication channel Copy of m Process p q m The enemy m’
18
Figure 2.14 Secure channels Principal A Secure channel Process p q Principal B
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.