Κατανεμημένα συστήματα (πολλοί υπολογιστές που συνεργάζονται μέσω δικτύου) φέρουν σημαντικές προκλήσεις που δεν υπάρχουν σε συστήματα ενός υπολογιστή — αναξιοπιστία δικτύου, μερικές αποτυχίες, συνέπεια, συντονισμός, και άλλα. Η κατανόηση αυτών είναι ουσιώδης για το σχεδιασμό συστημάτων σε μεγάλη κλίμακα.
Γιατί τα κατανεμημένα συστήματα είναι δύσκολα
Multiple machines communicating over a NETWORK introduce fundamental challenges:
→ the NETWORK is unreliable (latency, packet loss, partitions) and not instant
→ PARTIAL FAILURES → some parts fail while others work (vs all-or-nothing on one machine)
→ no shared memory/clock → coordination is hard
→ "the network is reliable" etc. are FALLACIES — distributed systems break these assumptions.
