You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
7.4 KiB
103 lines
7.4 KiB
5 years ago
|
= MongoDB
|
||
|
:nofooter:
|
||
|
:toc: right
|
||
|
:toc-title: Πίνακας περιεχομένων
|
||
|
:toclevels: 5
|
||
|
:sectnums:
|
||
|
:data-uri:
|
||
|
:icons: font
|
||
|
|
||
|
{empty} +
|
||
|
|
||
|
toc::[]
|
||
|
|
||
|
[.text-center]
|
||
|
image:./doc_images/mongodb_logo.png[600,600]
|
||
|
|
||
|
{empty} +
|
||
|
|
||
|
== Τι είναι η MongoDB
|
||
|
[.text-justify]
|
||
|
Η MongoDB ή αλλιώς Humongous Database που είναι το πλήρες όνομα της,
|
||
|
είναι μία document-oriented (κειμενοστρεφής) βάση δεδομένων τύπου NoSQL που χρησιμοποιείται για αποθήκευση μεγάλου όγκου δεδομένων.
|
||
|
Σε αντίθεση με τις κλασσικές σχεσιακές βάσης δεδομένων,
|
||
|
που χρησιμοποιούν Πίνακες (tables) η MongoDB χρησιμοποιεί συλλογές (collections) και έγγραφα (documents).
|
||
|
Τα έγγραφα αποτελούνται από ζευγάρια τιμών – κλειδιών (key-values) και αυτά συνθέτουν την βασική μονάδα δεδομένων στην MongoDB.
|
||
|
Οι συλλογές περιέχουν σύνολα εγγράφων και λειτουργιών και είναι η αντιστοίχηση των πινάκων με μία σχεσιακή βάση δεδομένων.
|
||
|
|
||
|
=== Χαρακτηριστικά
|
||
|
Μερικά από τα κύρια χαρακτηριστικά της είναι τα εξής:
|
||
|
[square]
|
||
|
* Κάθε βάση περιέχει collections που με την σειρά τους περιέχουν documents.
|
||
|
Τα documents στο ίδιο collection μπορούν να έχουν διαφορετικό αριθμό πεδίων,
|
||
|
διαφορετικό μέγεθος αλλά και περιεχόμενο μεταξύ τους.
|
||
|
* Τα documents συντάσσονται με την χρήση .json αρχείων και δεν χρειάζεται να έχουν από την αρχή κάποιο καθορισμένο Schema,
|
||
|
αλλά ο κάθε προγραμματιστής μπορεί να δημιουργήσει τα πεδία που θέλει όταν θα τα χρειαστεί.
|
||
|
|
||
|
== Γιατί MongoDB
|
||
|
Μερικοί από τους λόγους που κάποιος θα έπρεπε να αρχίσει να χρησιμοποιεί την MongoDB είναι οι παρακάτω:
|
||
|
|
||
|
[square]
|
||
|
* Document-oriented - Αφού η MongoDB είναι μία βάση δεδομένων τύπου NoSQL, και τα δεδομένα δεν αποθηκεύονται
|
||
|
με σχεσιακό τρόπο αλλά με την χρήση documents της προσφέρει ευελιξία και καλύτερη προσαρμοστικότητα.
|
||
|
* Ad hoc queries – Η MongoDB υποστηρίζει αναζητήσεις σύμφωνα με κάποιο πεδίο, με εύρος τιμών καθώς και με χρήση Regular expression.
|
||
|
Όλα τα queries (ερωτήματα) μπορούν να συνταχθούν έτσι ώστε να επιστρέφουν συγκεκριμένα μέσα από τα documents.
|
||
|
* Indexing – Προσφέρει δυνατότητα δημιουργίας ταξινόμησης από οποιοδήποτε πεδίο ενός document βελτιώνοντας σημαντικά την απόδοση
|
||
|
στις αναζητήσεις.
|
||
|
* Load balancing – Η MongoDB χρησιμοποιεί την μέθοδο του Sharding (κατανομή των δεδομένων σε πολλαπλές μηχανές) για την οριζόντια κλιμάκωση της.
|
||
|
Η MongoDB μπορεί να λειτουργεί σε πολλαπλά instances εξισορροπώντας το φορτίο και/ή αντιγράφοντας δεδομένα.
|
||
|
* Replication - Το replication είναι ένα απο τα ποιο σημαντικά στοιχεία και γι'αυτό αναλύεται περαιτέρω στην συνέχεια.
|
||
|
|
||
|
=== Replication
|
||
|
[.text-justify]
|
||
|
Η MongoDB σε αντίθεση με την MySQL προσφέρει την δυνατότητα, για αυτόματη ανάκαμψη για την περίπτωση που χαθεί η βάση,
|
||
|
χωρίς όμως από την άλλη να χρειάζεται ιδιαίτερες γνώσεις για την εγκαθίδρυση του.
|
||
|
|
||
|
==== Mongo replicas
|
||
|
[.text-justify]
|
||
|
Η διαδικασία με την οποία η MongoDB πραγματοποιεί το replication είναι με την δημιουργία το λιγότερο 2 ακόμα MongoDB instances
|
||
|
(είτε τοπικά είτε μέσω δικτύου),
|
||
|
σύνδεση των instances μεταξύ τους και ορισμός Primary και Secondaries.
|
||
|
|
||
|
[.text-center]
|
||
|
image:./doc_images/Replica-Screenshot.png[375,450]
|
||
|
|
||
|
[.text-justify]
|
||
|
Η πραγματοποίηση αυτής της ομαδοποίησης ονομάζεται Replica set, παρέχει Database redundancy ανάλογο με τον αριθμό των secondary που έχουν προσαρτηθεί στο replica set +
|
||
|
|
||
|
[.text-center]
|
||
|
total_instances – Primary – 1xSecondary=Number of failbacks can occured
|
||
|
|
||
|
[.text-justify]
|
||
|
==== Elections
|
||
|
Τα instances πραγματοποιούν ένα είδους επικοινωνίας μεταξύ τους, που ονομάζεται Heartbeat. Ένα instance στέλνει ανά δύο δευτερόλεπτα,
|
||
|
ένα μήνυμα επιβεβαίωσης σε κάθε άλλο instance και εάν δεν πάρει απάντηση μέσα στα επόμενα 10 τότε μαρκάρει το instance που δεν επέστρεψε
|
||
|
την απάντηση ως μη διαθέσιμο. Εάν το instance που μαρκαρίστηκε ως μην διαθέσιμο ήταν το Primary τότε ξεκινάει η διαδικασία ανάδειξης
|
||
|
καινούργιου Primary μέσα από το πλήθος των Secondary. Η διαδικασία ανάδειξης πραγματοποιείται με “εκλογές” μεταξύ των υπολοίπων.
|
||
|
Τα instance που έχουν δικαίωμα συμμετοχής στις εκλογές είναι τα εξής:
|
||
|
[square]
|
||
|
* Primary
|
||
|
* Secondary
|
||
|
* Startup2
|
||
|
* Recovering
|
||
|
* Arbiter
|
||
|
* Rollback
|
||
|
|
||
|
[.text-center]
|
||
|
image:./doc_images/Election-Screenshot.png[375,450]
|
||
|
|
||
|
[.text-justify]
|
||
|
Κατά την δημιουργία του κάθε instance, έχει αυτομάτως δικαιώματα εκλογής εάν ανήκει σε μία από τις παραπάνω ομάδες.
|
||
|
Για να είναι επιτυχής οι εκλογές πρέπει ο αριθμός από τους συμμετέχοντες για είναι μονός για να μην υπάρχει η πιθανότητα ισοψηφίας,
|
||
|
σε διαφορετική περίπτωση είναι αναγκαία η δημιουργία ενός arbiter.
|
||
|
Ο arbiter δεν αποθηκεύει δεδομένα ούτε δέχεται reads και writes,
|
||
|
αλλά έχει ως μοναδική λειτουργία την δυνατότητα ψήφου σε περίπτωση μονού αριθμού υποψηφίων.
|
||
|
Σε περίπτωση που υπάρχουν πάνω από 7 τέτοια μέλη τότε μόνο τα 7 με την μεγαλύτερη προτεραιότητα μπορούν να συμμετάσχουν.
|
||
|
|
||
|
|
||
|
{empty} +
|
||
|
{empty} +
|
||
|
{empty} +
|
||
|
|
||
|
[.text-center]
|
||
|
[big]*To be continued ....* +
|