સ્કેલ પર, નિષ્ફળતા અનિવાર્ય છે — સર્વર્સ ક્રેશ થાય છે, નેટવર્ક્સ નિષ્ફળ થાય છે, ડિપેન્ડેન્સીઝ અનુપલબ્ધ બની જાય છે. નિષ્ફળતા માટે ડિઝાઇન કરવાનો અર્થ એવી સિસ્ટમ્સ બનાવવો કે જે નિષ્ફળતાને સહન કરે છે અને તેમાંથી સુંદર રીતે પુનরુદ્ધાર કરે છે એમ માનવાને બદલે કે બધું કામ કરે છે. આ વિશ્વસનીય સિસ્ટમ્સ માટે આવશ્યક છે.
નિષ્ફળતા માટે ડિઝાઇન કરો (માનસિકતા)
ASSUME things WILL fail → at scale, failures are NORMAL, not exceptional:
→ servers crash, networks partition, disks fail, dependencies go down, traffic spikes
→ design systems to EXPECT and HANDLE failures gracefully (not assume everything works)
→ "everything fails all the time" → build resilience in.
