Understanding graceful degradation through an example
Here is an example of a system that handles a system degradation graciously.
This architecture diagram (Figure 4.1) illustrates how a resilient system can handle a user requesting a file, with the ability to return the file from a cache if the underlying system fails or the file doesn’t exist anymore:
data:image/s3,"s3://crabby-images/1cb1e/1cb1ec41c8112c86054a9a9c74a300d2ff833071" alt="Figure 4.1 – Logical architecture diagram showing a decision being made to return a cached file when the target file server is unavailable"
Figure 4.1 – Logical architecture diagram showing a decision being made to return a cached file when the target file server is unavailable
The following diagram (Figure 4.2) shows a simplified example sequence of actions that take place within the system when a user requests a file during a file server failure:
data:image/s3,"s3://crabby-images/4e338/4e3381142a2343aec7b586607de8737569c0e3ad" alt="Figure 4.2 – Sequence diagram showing an example sequence of actions that could take place when a user requests a file during a file server failure"
Figure 4.2 – Sequence diagram showing an example sequence of actions that could take place when a user requests a file during a file server failure
Let’s walk through the details of what is happening here:
- The user sends a request...