Βάσεις Δεδομένων ΙΙ 9η διάλεξη

Slides:



Advertisements
Παρόμοιες παρουσιάσεις
Προχωρημένα Θέματα Βάσεων Δεδομένων
Advertisements

Big Data + Data Analytics
Προχωρημένα Θέματα Τεχνολογίας και Εφαρμογών Βάσεων Δεδομένων Ασφάλεια σε Βάσεις Δεδομένων Πάνος Βασιλειάδης Σεπτέμβρης 2003
Λειτουργικά Συστήματα ΙΙ
HTML FTP, E -mail, Gopher Web Pages “Browse the Web” “Program the Web” Η εξέλιξη του Web Τεχνολογία Web Services XML Προγραμματισμός Παρουσίαση T C P/IP.
Μοντέλο Οντοτήτων-Συσχετισμών
 Ιστορία  ACID  CAP Theorem  Eventual consistency και BASE  Enter NoSQL  Χαρακτηριστικά NoSQL βάσεων  NoSQL taxonomy  Ρολόγια Lamport 2.
Σχεσιακό Μοντέλο Δεδομένων
PHP/MYSQL ΠΑΡΟΥΣΙΑΣΗ ΣΤΑ ΠΛΑΙΣΙΑ ΤΟΥ ΜΑΘΗΜΑΤΟΣ ΕΠΟΙΚΟΙΝΩΝΙΑ ΑΝΘΡΩΠΟΥ-ΜΗΧΑΝΗΣ ΤΥΡΟΛΟΓΟΥ ΓΛΥΚΕΡΙΑ ΑΜ 875 ΡΙΖΟΥ ΔΕΣΠΟΙΝΑ ΑΜ 816.
ΕΛΛΗΝΙΚΟ ΑΝΟΙΚΤΟ ΠΑΝΕΠΙΣΤΗΜΙΟ Διασύνδεση Java Εφαρμογών με ΒΔ Π. Φιτσιλής 1.
Ανασκόπηση Σχεδιασμού στο CAN Διονύσης Αθανασόπουλος Βασιλική Δεβελέγκα.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1 Εισαγωγή.
Βάσεις Δεδομένων Ι Ενότητα # 1: Εισαγωγή Σπυρίδων Σιούτας Τμήμα Πληροφορικής.
Μαρία Καρύδα, Επίκουρη Καθηγήτρια Γραφείο B13, Κτήριο Λυμπέρη Ώρες Γραφείου: Δευτέρα, Τρίτη, Τετάρτη 10:00 – 11: 00
Προηγμένες Υπηρεσίες Τηλεκπαίδευσης στο Τ.Ε.Ι. Σερρών Το εκπαιδευτικό υλικό που ακολουθεί αναπτύχθηκε στα πλαίσια του έργου «Προηγμένες Υπηρεσίες Τηλεκπαίδευσης.
Ενότητα 2 : Γεωγραφικά Συστήματα Πληροφοριών- Βασικές Έννοιες (Μέρος 1 ο ) Νικολακόπουλος Κωνσταντίνος, Επίκουρος Καθηγητής Σχολή Θετικών Επιστημών Τμήμα.
Βάσεις Δεδομένων Ενότητα 2: Συστήματα Διαχείρισης Βάσεων Δεδομένων Βασίλης Βουτσινάς Τμήμα: Οργάνωση & Διοίκηση Επιχειρήσεων.
ΤΑΞΙΝΟΜΗΣΗ ΤΩΝ ΠΕΡΙΦΕΡΕΙΩΝ ΜΕ ΒΑΣΗ ΤΟ ΒΑΘΜΟ ΑΝΑΠΤΥΞΗΣ ΑΝΑΠΤΥΓΜΕΝΕΣ ΠΕΡΙΦΕΡΕΙΕΣ Ισόρροπης ανάπτυξης Κορεσμένες ή συμφορημένες - Υψηλό βαθμό ανάπτυξης- Υπερσυγκέντρωση.
Calvin:Fast Distributed Transactions for Partitioned Database System Ηλίας Σπανός Αντωνία Νικολάου Calvin: Fast Distributed Transactions for Partitioned.
Σπουδές και ανεργία των νέων, υπάρχουσα κατάσταση προοπτικές Εισηγητής: Κων/νος Αδριανουπολίτης Εκπαιδευτικός – Ερευνητής Πρόεδρος Ε.Ε.Τ.Ε.Κ.
Πληροφορική Κεφάλαιο 4 ο : Βάσεις Δεδομένων Κλεπετσάνης Παύλος, Επίκουρος Καθηγητής Τμήμα Φαρμακευτικής.
Κοστολόγηση Ενότητα 2: Δομή επιχειρήσεων γραφικών τεχνών και χαρακτηριστικά σύγχρονων τεχνολογιών Δρ. Αναστάσιος Ε. Πολίτης, Αναπληρωτής Καθηγητής Τεχνολογία.
ΔΙΑΔΙΚΑΣΙΕΣ & ΑΝΑΠΤΥΞΗ ΕΞΑΓΩΓΩΝ B2B-B2D Πριν μόλις χρόνια η ανάπτυξη σε ξένες αγορές εξαρτιόταν αποκλειστικά από τις διαδικασίες των εκθέσεων και.
Μάθημα 4 Server side προγραμματισμός Βάσεις δεδομένων PHP.
O.T.S. FORUM Εφαρμογή Διαχείρισης Έργων Εισηγητής: Σιάμμενου Γιούλη.
ΕΡΓΑΣΤΗΡΙΟ IDentifEYE ΠΑΡΟΥΣΙΑΣΗ - ΟΜΑΔΑ ΕΚΠΑΙΔΕΥΤΙΚΩΝ ΕΤΩΝ ΓΙΑ ΠΑΙΔΙΑ 8-11.
Καλώς ήλθατε, μαθητές! Όνομα δασκάλου. Πρόγραμμα τάξης 8:15 - 9:00Το σχολείο ξεκινά, παίρνουμε παρουσίες 9: :00Ανάγνωση και έκθεση 10: :00Ορθογραφία.
Ο ΡΟΛΟΣ ΤΗΣ ΚΑΙΝΟΤΟΜΙΑΣ ΣΤΗΝ ΥΛΟΠΟΙΗΣΗ ΤΗΣ ΝΕΑΣ ΒΙΟΜΗΧΑΝΙΚΗΣ ΠΟΛΙΤΙΚΗΣ
Εισαγωγή στις βάσεις δεδομένων
Βάσεις Δεδομένων και Ευφυή Πληροφοριακά Συστήματα Επιχειρηματικότητας
Σύστημα διαχείρισης αρχείων (file system)
Βάσεις Δεδομένων Ι 4η διάλεξη
Εισαγωγή στις βάσεις δεδομένων - Η ανατομία μιας βάσης δεδομένων
Σχεσιακό Μοντέλο Δεδομένων
ΠΑΝΕΠΙΣΤΗΜΙΟ ΙΩΑΝΝΙΝΩΝ ΑΝΟΙΚΤΑ ΑΚΑΔΗΜΑΪΚΑ ΜΑΘΗΜΑΤΑ
Εισαγωγικά Θέματα Διαχείρισης Δικτύων
Επιμόρφωση Εκπαιδευτικών Μέσης Εκπαίδευσης για τα Νέα Αναλυτικά Προγράμματα Πληροφορικής και Επιστήμης Η/Υ Προγραμματισμός Έτους και Ενότητας (Γ’ Γυμνασίου)
Βάσεις Δεδομένων Ι Εισαγωγή
Διδάσκουσα: Ευαγγελία Πιτουρά
Θερινό Σχολείο, 14 – 20 Ιουλίου 2014
Ασκήσεις Κεφάλαιο 11.
Βάσεις Δεδομένων Ι Επανάληψη
ΠΑΝΕΠΙΣΤΗΜΙΟ ΙΩΑΝΝΙΝΩΝ ΑΝΟΙΚΤΑ ΑΚΑΔΗΜΑΪΚΑ ΜΑΘΗΜΑΤΑ
Βάσεις Δεδομένων Ι 10η διάλεξη
Κεντρο πληροφορησησ ανεργων τησ γ.σ.ε.ε.(κεπεα)
“Κατασκευή εφαρμογής διαχείρισης προγράμματος διδασκαλίας εκπαιδευτικών ιδρυμάτων με έλεγχο της ακεραιότητας, προσπέλασης και ασφάλειας των δεδομένων”
ΥΠΑΣΒΕΣΤΙΑΙΜΙΑ Κυφωνίδης Δημήτριος Διευθυντής Παιδιατρικής Κλινικής.
9 Η Γλώσσα SQL Εισαγωγή – Βασικές Έννοιες Τύποι Δεδομένων
Η Epsilon Net σας καλωσορίζει
Περιγραφή Ενότητας Σκοπός του μαθήματος είναι να κατανοήσουμε την έννοια της όψης της γλώσσας SQL. Χ. Σκουρλάς.
Βάσεις Δεδομένων Εισαγωγή για το Εργαστήριο Δρ. Τιάκας Ελευθέριος
H μεγαλη εκρηξη.
Αρχιτεκτονική Συστημάτων
Μάνος Σατόπουλος Συντάκτης λευκωμάτων και λάτρης των τεχνών
Εισαγωγή στις Βάσεις Δεδομένων
Σχεδιασμός και Ανάπτυξη Διαδικτυακών Εφαρμογών
Όνομα σχολείου Ημερομηνία
Μίγμα Μάρκετινγκ στον Αθλητισμό: Η διανομή στον αθλητικό χώρο
Μία πρακτική εισαγωγή στην χρήση του R
Για μια ευέλικτη, αποδοτική και αποτελεσματική δημόσια διοίκηση)
Εισαγωγή στις Βάσεις Δεδομένων
Κυκλοφοριακή αγωγή Ένα πρόγραμμα για να μάθουμε να κυκλοφορούμε με ασφάλεια. Β΄ Δημοτικού 12ου Δημοτικού Σχολείου Βόλου Υπεύθυνοι προγράμματος : Θωμάς.
Βάσεις Δεδομένων 28/11/2018 Ενότητα Γ6.Μ2 (Βασικά Δομικά Συστατικά Στοιχεία και Κύρια Αντικείμενα μιας Βάσης Δεδομένων ) Ο Δάσκαλος.
ΤΙΤΛΟΣ ΤΗΣ ΕΚΔΗΛΩΣΗΣ ΣΑΣ
Βάσεις Δεδομένων 16/2/2019 Ενότητα Γ6.3 (Δημιουργία και Αποθήκευση Βάσης Δεδομένων και Πίνακα. Καθορισμός Πεδίων του Πίνακα, Τύπων Δεδομένων και Ιδιότητες.
Καλώς ήλθατε, μαθητές! Όνομα δασκάλου.
Ενότητα 1: «Προσανατολισμού» (orientation) - Εισαγωγή Χ. Σκουρλάς
Εφαρμογές ιστού και δημιουργία ιστοσελίδων
Programmable Logic Device PLD. Φύλλο δεδομένων (Data Sheet) των TTL ICs.
Παράδειγμα στόχος Έμπνευση Ενέργειες/εργασίες Πόροι Σκέψεις
Μεταγράφημα παρουσίασης:

Βάσεις Δεδομένων ΙΙ 9η διάλεξη

1 Ασφάλεια

Υποχρεωτικός έλεγχος πρόσβασης Εισαγωγή Ασφάλεια Ακεραιότητα Διαθεσιμότητα Έλεγχος πρόσβασης Προνόμια Υποχρεωτικός έλεγχος πρόσβασης

Έλεγχος πρόσβασης Τρόπος ελέγχου των δεδομένων (και των ενεργειών) στα οποία έχει πρόσβαση ένας χρήστης

Αντικειμενικοί στόχοι Μυστικότητα Ακεραιότητα Διαθεσιμότητα

Μυστικότητα Οι πληροφορίες δεν πρέπει να αποκαλύπτονται σε μη εξουσιοδοτημένους χρήστες

Μόνο εξουσιοδοτημένοι χρήστες μπορούν να τροποποιούν δεδομένα Ακεραιότητα Μόνο εξουσιοδοτημένοι χρήστες μπορούν να τροποποιούν δεδομένα

Διαθεσιμότητα Δε θα πρέπει να απαγορεύεται η πρόσβαση στους εξουσιοδοτημένους χρήστες

Καθορίζει ποιος μπορεί να κάνει τι μέσα σε ένα ΣΔΒΔ Επίτευξη στόχων; Πολιτική ασφαλείας Καθορίζει ποιος μπορεί να κάνει τι μέσα σε ένα ΣΔΒΔ Μηχανισμοί ασφαλείας Επιβάλουν την πολιτική

Διακριτικός έλεγχος πρόσβασης Βασίζεται στις έννοιες των δικαιωμάτων πρόσβασης που ονομάζουμε προνόμια και αντίστοιχα μηχανισμοί που διαχειρίζονται τα προνόμια

Η εντολή REVOKE αφαιρεί τα προνόμια GRANT & REVOKE Η εντολή GRANT δίνει προνόμια στους χρήστες πάνω σε συγκεκριμένους πίνακες ή σε σύνολο πινάκων Η εντολή REVOKE αφαιρεί τα προνόμια

Οι όψεις είναι ένας τρόπος να εξασφαλίσουμε ασφάλεια GRANT & REVOKE on views Οι όψεις είναι ένας τρόπος να εξασφαλίσουμε ασφάλεια Γιατί;

Ασφάλεια σε επίπεδο πεδίου Πως θα μπορούσα να επιτύχω ασφάλεια σε επίπεδο πεδίου ενός πίνακα;

Ιεραρχικό μοντέλο ρόλων χρηστών. Ρόλοι χρηστών Ιεραρχικό μοντέλο ρόλων χρηστών. Κάθε επίπεδο έχει τα δικαιώματα όλων των ρόλων που βρίσκονται σε χαμηλότερο επίπεδο

Στην πραγματικότητα βρίσκουμε πεδίο εφαρμογής στο διαδίκτυο Πεδίο εφαρμογής Στην πραγματικότητα βρίσκουμε πεδίο εφαρμογής στο διαδίκτυο Αναγνώριση χρήστη και εμπιστοσύνη

Κρυπτογράφηση, αποστολή, αποκρυπτογράφηση Τρόπος αντιμετώπισης Κρυπτογράφηση Διαδικασία Μορφοποίηση δεδομένων ώστε αν τα υποκλέψει κανείς να μην τα αναγνωρίζει Κρυπτογράφηση, αποστολή, αποκρυπτογράφηση Αν κάποιος δε γνωρίζει τον τρόπο αποκρυπτογράφησης τότε δε μπορεί να αναγνώσει την πληροφορία

Συμμετρική Κρυπτογράφηση Public-key Κρυπτογράφηση

Υποχρεωτικός έλεγχος πρόσβασης Κάθε αντικείμενο της βάσης δεδομένων ανατίθεται σε μια τάξη ασφαλείας Κάθε υποκείμενο (χρήστης) αναλαμβάνει ένα επίπεδο πρόσβασης – άδεια χρήσης σε μια τάξη

Μοντέλο Bell - LaPadula Αντικείμενα Υποκείμενα Τάξεις ασφαλείας Ιδιότητα απλής ασφάλειας Το υποκείμενο S μπορεί να διαβάσει το αντικείμενο Ο αν και μόνο αν τάξη(S) >= τάξη(Ο) Ιδιότητα -* Το υποκείμενο S μπορεί να γράψει το αντικείμενο Ο αν και μόνο αν τάξη(S) <= τάξη(Ο)

Ο διαχειριστής είναι υπεύθυνος για την εφαρμογή κανόνων ασφαλείας Σύνοψη Τρία είναι τα στοιχεία που μας ενδιαφέρουν: μυστικότητα, ακεραιότητα, διαθεσιμότητα Ο διαχειριστής είναι υπεύθυνος για την εφαρμογή κανόνων ασφαλείας Διακριτικός και υποχρεωτικός έλεγχος πρόσβασης

2 NOSQL

RDBMS Relational Data Base Management System …Codd 70s

Κανόνας ACID Atomic Consistent Isolated Durable

Κατανεμημένα συστήματα Πολλαπλοί υπολογιστές και συστήματα λογισμικού που μπορούν να επικοινωνήσουν μέσα από ένα δίκτυο ώστε να επιτελέσουν μαζί έναν κοινό σκοπό

Αξιοπιστία Επεκτασιμότητα Κατανομή των πόρων Ταχύτητα Γιατί τα χρειάζομαι Αξιοπιστία Επεκτασιμότητα Κατανομή των πόρων Ταχύτητα Ανοιχτά συστήματα Επιδόσεις

Αντιμετώπιση προβλημάτων Λογισμικό Δικτύωση Ασφάλεια Προβλήματα Αντιμετώπιση προβλημάτων Λογισμικό Δικτύωση Ασφάλεια

Scale out (Οριζόντια κλιμάκωση): να προστεθούν επιπλέον συστήματα Κλιμάκωση! Δυνατότητα επέκτασης ενός συστήματος ώστε να καλύπτει κάθε είδους ανάγκες (πόρους) Scale up (Κάθετη κλιμάκωση): να προστεθούν επιπλέον πόροι σε ένα σύστημα για να μπορεί να ανταποκρίνεται καλύτερα Scale out (Οριζόντια κλιμάκωση): να προστεθούν επιπλέον συστήματα

Μη σχεσιακές βάσεις δεδομένων NOSQL NOT ONLY SQL Μη σχεσιακές βάσεις δεδομένων Σχεδιάστηκε για να καλύψει ανάγκες κατανεμημένων αποθηκών δεδομένων που έχουν πολύ μεγάλη κλίμακα δεδομένων αποθήκευσης και βέβαια μεγάλες ανάγκες αλληλεπίδρασης με τα δεδομένα

Γιατί noSQL Η δημιουργία δεδομένων και η κατανάλωση web services, web applications, mobile applications με πρόσβαση σε μεγάλα data είναι μια πραγματικότητα

Γιατί noSQL

Δομημένα και οργανωμένα δεδομένα Σύγκριση RDBMS Δομημένα και οργανωμένα δεδομένα Δομημένα και αυστηρή γλώσσα ερωτημάτων Τα δεδομένα και οι σχέσεις αποθηκεύονται στη ΒΔ DML, DDL Αυστηρή ακεραιότητα δεδομένων. noSQL Not only SQL Δεν υπάρχει δηλωτική γλώσσα ερωτημάτων Δεν υπάρχει προκαθορισμένο σχήμα Τρόποι αποθήκευσης: Key-Value pairs, Column store, document store, Graph DB Ακεραιότητα γεγονότων και όχι δεδομένων CAP Theorem Προέχει υψηλή απόδοση, επεκτασιμότητα, διαθεσιμότητα

Consistency (συνέπεια) Availability (διαθεσιμότητα) Θεώρημα CAP Consistency (συνέπεια) Availability (διαθεσιμότητα) Partitioning [tolerance] (ανεκτικότητα στο διαχωρισμό)

AP: κάποια από τα δεδομένα μπορεί να μην είναι ακριβή Θεώρημα CAP Αν και θεωρητικά όλα πρέπει να ισχύουν, αρκεί να έχω 2 από τα 3 για να έχω ΒΔ CA: single site cluster. Όλοι οι κόμβοι να είναι σε επαφή. Αν χαθεί ένας καταστρέφεται στο σύνολο CP: κάποια δεδομένα μπορεί να είναι απροσπέλαστα, το υπόλοιπο λειτουργεί μια χαρά AP: κάποια από τα δεδομένα μπορεί να μην είναι ακριβή

Θεώρημα CAP

Εύκολη επεκτασιμότητα Κατανεμημένα συστήματα Χαμηλότερο κόστος Στα θετικά… Εύκολη επεκτασιμότητα Κατανεμημένα συστήματα Χαμηλότερο κόστος Ευελιξια (στη μη ύπαρξη δομημένου σχήματος) Δεν υπάρχουν περίπλοκες σχέσεις

Δεν υπάρχει κάποια τυποποίηση (είναι εξ ορισμού fuzzy logic) όμως Δεν υπάρχει κάποια τυποποίηση (είναι εξ ορισμού fuzzy logic) Είναι πολύ περιορισμένος ο τρόπος ερωτημάτων Τι γίνεται αν το σύστημα δεν έχει εν τέλει ακρίβεια;

Δεν υπάρχει κάποια τυποποίηση (είναι εξ ορισμού fuzzy logic) όμως Δεν υπάρχει κάποια τυποποίηση (είναι εξ ορισμού fuzzy logic) Είναι πολύ περιορισμένος ο τρόπος ερωτημάτων Τι γίνεται αν το σύστημα δεν έχει εν τέλει ακρίβεια;

Key-value stores Column-oriented Graph Document oriented Κατηγορίες noSQL Key-value stores Column-oriented Graph Document oriented

Όλοι οι βασικοί τύποι noSQL Key-value Όλοι οι βασικοί τύποι noSQL Μπορούν να διαχειριστούν τεράστιους όγκους δεδομένων Το «κλειδί» είναι ένα μοναδικό αναγνωριστικό και η τιμή μπορεί να είναι οτιδήποτε αδόμητο (string) ή δομημένο (JSON, BLOB, etc) Εμφανίζονται στις περιπτώσεις AP (CAP theorem) Redis, dynamo, ryak

Τα δεδομένα αποθηκεύονται σε στήλες Column oriented Τα δεδομένα αποθηκεύονται σε στήλες Οι τιμές σε μια στήλη αποθηκεύονται σε σειρά (συνεχόμενα) Κάθε στήλη έχει δικό της χώρο αποθήκευσης Έχει τεράστιες δυνατότητες συμπίεσης Έχει υψηλές επιδόσεις σε ερωτήματα συνάθροισης Big Table, Cassandra, SimpleDB, etc

Σχηματικά

Graph Τα δεδομένα αποτελούνται από έναν πεπερασμένο αριθμό από διατεταγμένα ζεύγη που ονομάζονται ακμές και οντότητες που ονομάζονται κόμβοι OrientDB, Neo4J, etc

Αποθηκεύονται σε ομάδες με παραπλήσια δεδομένα MongoDB, CouchDB, etc Document Oriented Συλλογές από έγγραφα Δεν υπάρχει κάποια συνοχή μεταξύ τους απλά κάθε ένα έχει ένα κλειδί και τα περιεχόμενα του εγγράφου είναι η τιμη Αποθηκεύονται σε ομάδες με παραπλήσια δεδομένα MongoDB, CouchDB, etc

3 Κατασκευή ΒΔ

Ας βρούμε τι θα φτιάξουμε Διαδικασία Ας βρούμε τι θα φτιάξουμε

…τι σημαίνει το κάθε ένα στον πίνακα που θα φτιάξω ER Σχέσεις… Πολλά με πολλά Ένα με πολλά Πολλά με ένα …τι σημαίνει το κάθε ένα στον πίνακα που θα φτιάξω

Σχήμα Πίνακες της ΒΔ

Εφαρμογή του συστήματος και εκτέλεση βασικών εντολών Εφαρμογή σε DBMS Εφαρμογή του συστήματος και εκτέλεση βασικών εντολών