Hjem Personlig finansiering Administrere data i NoSQL - dummies

Administrere data i NoSQL - dummies

Innholdsfortegnelse:

Video: How to Install MongoDB on Windows 10 2025

Video: How to Install MongoDB on Windows 10 2025
Anonim

Når du administrerer nøklene riktig, er du klar til å designe hvordan du lagrer data med NoSQL og sørger for at den er trygg og alltid tilgjengelig for arbeidet du må gjøre.

Datatyper i nøkkelverdi butikker

Nøkkelverdier butikker fungerer vanligvis som & ldquo; bøtter og rdquo; for binære data. Noen databaser gir sterk intern datatype og jevn skjema støtte. Andre gir rett og slett praktiske hjelpefunksjoner i sine klientdrivere for serialisering av vanlige applikasjonsdatastrukturer til en nøkkelverdibutikk. Eksempler er kart, lister og sorterte sett.

Oracle NoSQL kan operere i to moduser:

  • Enkel binær butikk

  • Strukturert Avro-skjema støtte

Et Avro-skjema er relatert til et relationsdatabaseskema - håndheve et meget strenkt sett av formatregler for JavaScript Object Notation (JSON) data lagret i databasen, som illustrert her:

{brukernavn: & ldquo; afowler & rdquo;, sessionid: 13452673, siden: 1408318745, tema: & ldquo; bluesky & rdquo;}

Du definerer et Avro-skjema ved hjelp av et JSON-dokument. Dette er et eksempel på Avro-skjemaet for de lagrede dataene som er vist tidligere:

{& ldquo; typen & rdquo;: & ldquo; record & rdquo;, & ldquo; namespace & rdquo;: & ldquo; com. eksempel & rdquo;, & ldquo; navnet & rdquo;: & ldquo; UserSession & rdquo;, & ldquo; feltene & rdquo;: [{& ldquo; navnet & rdquo;: & ldquo; brukernavn & rdquo;, & ldquo; typen & rdquo;: [& ldquo; string & rdquo;, & rdquo; null & rdquo;]}, {& ldquo; navnet & rdquo;: & ldquo; sessionid & rdquo;, & ldquo; typen & rdquo;: & ldquo; int & rdquo;}, {& ldquo; navnet & rdquo;: & ldquo; siden & rdquo;, & ldquo; typen & rdquo;: & ldquo; lang & rdquo;}, {& ldquo; navnet & rdquo;: & ldquo; Temaet & rdquo;, & ldquo; typen & rdquo;: [& ldquo; string & rdquo;, & rdquo; null & rdquo;]}]}

Et Avro-skjema gir svært sterk innskriving i databasen for når skjemaet er viktig. I det forrige eksempelet ser du strengdata, en numerisk sesjons-id, en dato (millisekunder, siden Unix-tidepunktet, som et langt heltall) og en tilpassingsinnstilling for temaet som skal brukes på nettstedet.

Merk også at typen brukernavn og tema har to alternativer - streng og null, slik at du instruerer Oracle NoSQL om at nullverdier er tillatt. Du kan ha forlatt temaet som en streng og gitt en ekstra konfigurasjonsparameter for & ldquo; Standard & rdquo;: & ldquo; bluesky & rdquo;.

Andre NoSQL-databaser gir sekundære indekser på en hvilken som helst vilkårlig egenskap med en verdi som har JSON-innhold. Riak gir for eksempel sekundære indekser basert på dokumentpartisjonering - i utgangspunktet er en kjent egenskap i et JSON-dokument indeksert med en type.Dette gjør det mulig for utvalgsspørsmål (mindre enn eller høyere enn) i tillegg til enkle like og ikke like sammenligninger. Riak klarer å gi utvalgsspørsmål uten et strenge skjema - bare enkel indeksdefinisjon. Hvis dataene er der, blir det lagt til indeksen.

Replikere data

Lagring av flere kopier av de samme dataene i andre servere, eller til og med rack av servere, bidrar til å sikre tilgjengeligheten av data hvis en server mislykkes. Serverfeil skjer hovedsakelig i samme klynge.

Du kan bruke replikaer to hovedveier:

  • Master-slave: Alle leser og skriver skjer med mesteren. Slaver tar over og mottar forespørsler bare hvis mesteren mislykkes.

Master-slave replikering brukes vanligvis på ACID-kompatible nøkkelverdier. For å aktivere maksimal konsistens, skrives primærbutikken til og alle replikas oppdateres før transaksjonen fullføres. Denne mekanismen kalles en tofase-commit og skaper ekstra nettverk og behandlingstid på replikene.

  • Master-master: Leser og skriver kan skje på alle noder som styrer en nøkkel. Det er ikke noe konsept om en & ldquo; primære & rdquo; partisjon eier.

Master-master-replikene er vanligvis etter hvert konsekvente, idet klyngen utfører en automatisk operasjon for å bestemme den nyeste verdien for en nøkkel og fjerne eldre, foreldede verdier.

I de fleste nøkkelverdier, skjer dette sakte - på lesetid. Riak er unntaket her fordi det har en anti-entropitjeneste som ser etter konsistens under normal drift.

Versjonsdata

For å aktivere automatisk konfliktløsning trenger du en mekanisme for å indikere den nyeste versjonen av data. Til slutt konsekvent nøkkelverdibutikker oppnår konfliktløsning på forskjellige måter.

Riak bruker en vektor-klokke mekanisme for å forutsi hvilken kopi som er den nyeste. Andre nøkkelverdier butikker bruker enkle tidsstempler for å indikere stalenhet. Når konflikter ikke kan løses automatisk, sendes begge kopier av data til klienten. Konfliktende data som sendes til klienten, kan forekomme i følgende situasjon:

  1. Klient 1 skriver til replika A 'Adam: {likes: Cheese}'.

  2. Kopi En kopieringsdata til kopi B.

  3. Klient 1 oppdaterer data på kopi A til 'Adam: {liker: Ost, hater: sollys}'.

    På dette punktet har replika A ikke nok tid til å kopiere de nyeste dataene til replik B.

  4. Klient 2 oppdaterer data på kopi B til 'Adam: {likes: Dogs, hates: kangaroos}'.

    På dette punktet er replik A og replik B i konflikt, og databaseklyngen kan ikke automatisk løse forskjellene.

En alternativ mekanisme er å bruke tidsstempler og stole på at de skal indikere de nyeste dataene. I en slik situasjon er det sunt for applikasjonen å kontrollere at tidsstemplene leser den siste verdien før oppdateringen av verdien.

De kontrollerer -kontrollen og setter -mekanismen, som i utgangspunktet betyr 'Hvis den nyeste versjonen fortsatt er versjon 2, lagrer du min versjon 3'. Denne mekanismen kalles noen ganger read match update (RMU) eller read match write (RMW). Denne mekanismen er standardmekanismen som brukes av Oracle NoSQL, Redis, Riak og Voldemort.

Administrere data i NoSQL - dummies

Redaktørens valg

Hvordan beskrives et datasett statistisk for GEDs vitenskapstest - dummies

Hvordan beskrives et datasett statistisk for GEDs vitenskapstest - dummies

GED Science test vil stille spørsmål relatert til beskrivende statistikk. Du kan ofte oppsummere en samling av data (fra et eksperiment, observasjoner eller undersøkelser, for eksempel) ved å bruke beskrivende statistikk, tall som brukes til å oppsummere og analysere dataene og trekke konklusjoner fra det. Beskrivende statistikk for en samling av data inkluderer følgende: Frekvens: ...

Hvordan forutsi en utgang basert på data eller bevis på GED-vitenskapstesten

Hvordan forutsi en utgang basert på data eller bevis på GED-vitenskapstesten

Bruk av bevis for å forutsi utfall er en nødvendig ferdighet for GED Science-testen. De største fordelene med vitenskapelige studier kan ofte tilskrives det faktum at deres konklusjoner gjør det mulig for folk å forutsi utfall. (Du vil sikkert ønske vitenskap kan hjelpe deg med å forutsi utfallet ditt på prøve!) Du er vitne til vitenskap i handling hver dag ...

Hvordan man måler en forfatters troverdighet for GEDs samfunnsstudietest - dummies

Hvordan man måler en forfatters troverdighet for GEDs samfunnsstudietest - dummies

GED Social Studies test vil stille spørsmål som krever at du bestemmer troverdigheten til en forfatter. Det er ikke alltid lett å vurdere om en forfatter er troverdig basert på informasjonen som er gitt i en skriftlig oversikt og referansen, men du kan hente spor ved å nøye undersøke følgende områder: Forfatterens ...

Redaktørens valg

Hva skjer i QuickBooks 2013 Setup? - dummies

Hva skjer i QuickBooks 2013 Setup? - dummies

Etter at du har installert QuickBooks 2013, kjører du en skjermveiviser for å sette opp QuickBooks for firmaets regnskap. Klart, denne skjermveiviseren kalles QuickBooks Setup. Når du kjører QuickBooks Setup, gir du ganske mye informasjon til QuickBooks. Som en praktisk sak krever oppsettet og oppsettet etter oppsettet at du har ...

Leverandørmenykommandoer i QuickBooks 2013 - dummies

Leverandørmenykommandoer i QuickBooks 2013 - dummies

Når du jobber med betalbar betaling i QuickBooks 2013, har du ofte vil bruke flere av kommandoene på leverandørmenyen. Noen av kommandoene er imidlertid ikke så populære, men du må fortsatt være klar over deres formål. Leverandørssenter i QuickBooks 2013 Vendor Center-vinduet viser en liste over leverandører og detaljerte ...

Kommandoer for leverandørmeny i QuickBooks 2014 - dummies

Kommandoer for leverandørmeny i QuickBooks 2014 - dummies

Når du jobber med betalbar betaling i QuickBooks 2014, har du ofte vil bruke flere av kommandoene på leverandørmenyen. Noen av kommandoene er imidlertid ikke så populære, men du må fortsatt være klar over deres formål. Leverandørssenter Vendor Center-vinduet viser en liste over leverandører og detaljert leverandørinformasjon for ...