Cuprins:
- Aveți două opțiuni atunci când se efectuează o partiție de rețea:
- document
- Riak nu este o bază de date compatibilă cu ACID. Configurația sa nu poate fi modificată astfel încât să funcționeze în modul de conformitate ACID. Clienții pot obține date incoerente în timpul operațiunilor normale sau în timpul partițiilor din rețea. Riak tratează consistența absolută pentru o disponibilitate sporită și toleranță la partiție.
Video: HDD EXTERN NU SE VEDE IN WINDOWS 2024
Partiția de cuvinte este folosită pentru două concepte diferite în terenurile NoSQL. O partiție de date este un mecanism care asigură distribuirea uniformă a datelor într-un cluster. Pe de altă parte, o partiție de rețea apare atunci când două părți ale aceluiași grup de baze de date nu pot comunica. În cazul sistemelor foarte complexe, este din ce în ce mai probabil să se întâmple o eșec al unui echipament. Dacă un comutator de rețea între servere dintr-un grup nu reușește, apare un fenomen denumit (în jargonul computerului)
creierul divizat . În acest caz, serverele individuale primesc încă solicitări, dar nu pot comunica între ele.
Partiții tolerante
Aveți două opțiuni atunci când se efectuează o partiție de rețea:
Continuați, la un anumit nivel, să efectuați operații de citire și scriere.
-
"Votează" o parte a partiției și decide să corecteze datele mai târziu când ambele părți pot comunica. Aceasta implică, de obicei, că clusterul votează o replică citită ca noul master pentru fiecare nod lipsă de partiție principală.
-
Mânerele Riak scrie atunci când serverul de partiții primare coboară, folosind un sistem numit
hinted shift
. Când datele sunt replicate inițial, primul nod pentru o anumită partiție cheie este scris la, împreună cu (în mod implicit) două dintre următoarele noduri vecine.
Riak folosește un alt sistem numit
entropie activă
- pentru a atenua această problemă. Acest sistem trage prin valori actualizate și asigură faptul că replicile sunt actualizate la un moment dat, preferabil mai devreme decât mai târziu.Acest lucru ajută la evitarea conflictelor la citire, menținând în același timp o viteză ridicată de ingestie, ceea ce evită o comitere în două faze utilizată de alte baze de date NoSQL cu suport pentru clusterizare master-slave. Dacă se întâmplă un conflict în citire, Riak utilizează citește reparația
pentru a încerca să returneze numai cele mai recente date. În cele din urmă, dar în funcție de setările de consistență și de disponibilitate pe care le utilizați, aplicația client poate fi prezentată cu mai multe versiuni și solicitată să decidă singură. În anumite situații, acest compromis este de dorit, iar multe aplicații pot cunoaște intuitiv, pe baza datelor prezentate, ce versiune să utilizeze și ce versiune să se debarasă. Indexarea secundară
Indicii secundari sunt indicii privind datele specifice dintr-o valoare. Cele mai multe magazine cu valoare cheie părăsesc această indexare până la aplicație. Cu toate acestea, Riak este diferit, folosind o schemă numită
document
- partiție bazată pe care permite indexarea secundară. Partiționarea pe bază de documente presupune că scrieți structuri JSON la baza de date Riak. Apoi puteți seta indexuri pe anumite proprietăți denumite în cadrul acestei structuri JSON, după cum se arată: {"order-id": 5001, "id-client": 1429857, "order-date": "2014-09-24 "," Total ": 134. 24}
Dacă aveți o aplicație care arată comenzile unui client pentru luna precedentă, atunci doriți să interogați toate înregistrările, după cum se arată, în cazul în care ID-ul clientului este o valoare fixă (1429857) iar data comenzii se încadrează într-un anumit interval (începutul și sfârșitul lunii).
În majoritatea magazinelor cu valoare cheie, creați o altă găleată a cărei cheie este numărul de clienți combinat și luna și valoarea este o listă a numelor de ordine. Cu toate acestea, în Riak, pur și simplu adăugați un index secundar atât pe id client (integer), cât și pe data de comandă (data), care necesită spațiu suplimentar de stocare, dar are avantajul de a fi transparent pentru dezvoltatorul de aplicații.
Acești indexuri sunt, de asemenea, actualizați live - ceea ce înseamnă că nu există o întârziere între actualizarea unei valori a documentului în Riak și actualizarea indexurilor. Acest acces viu la date este mai greu de tras decât pare. La urma urmei, dacă indicii sunt incoerenți, nu veți găsi niciodată datele păstrate în mod consecvent!
Evaluarea Riak
Basho, entitatea comercială din spatele Riak, spune că versiunea sa viitoare 2. O bază de date NoSQL are întotdeauna o consistență puternică, o afirmație pe care o fac și alți furnizori NoSQL. Afirmația furnizorilor NoSQL de a avea întotdeauna o consistență puternică este ca și cum ați pretinde că sunteți un vegetarian puternic … cu excepția duminicilor, când aveți carne de vită friptă.
Riak nu este o bază de date compatibilă cu ACID. Configurația sa nu poate fi modificată astfel încât să funcționeze în modul de conformitate ACID. Clienții pot obține date incoerente în timpul operațiunilor normale sau în timpul partițiilor din rețea. Riak tratează consistența absolută pentru o disponibilitate sporită și toleranță la partiție.
Riak-ul care rulează într-un mod puternic de consistență înseamnă că replicile citite sunt actualizate în același timp cu comandantul principal. Aceasta implică o comitere în două faze - în esență, scrierea nodului principal către celelalte noduri înainte de a confirma că scrierea este completă.
La momentul acestei scrieri, modul de consistență puternic al lui Riak nu suportă indici secundari sau tipuri de date complexe (de exemplu, JSON). Sperăm că Basho va remedia această problemă în viitoarele versiuni ale bazei de date.
Riak Search (un motor de căutare rebrandat și integrat Apache Solr utilizează un model de actualizare consistent) poate produce false poziții atunci când se folosește o consistență puternică. Această situație apare deoarece datele pot fi scrise și apoi tranzacția abandonată, dar datele sunt încă folosite pentru indexare - lăsând un rezultat de căutare "fals pozitiv" - rezultatul nu mai este valabil pentru interogarea de căutare.
sentinel
pentru a determina care nod devine un master în condiții de eroare. Acest proces, totuși, nu este foarte disponibil, ceea ce înseamnă că pentru câteva secunde este posibil ca, în timp ce o nouă copie a procesului santinelsă fie adusă online, un nou nod nu poate fi adăugat sau un nou maestru ales. Trebuie să fiți conștienți de această posibilitate în condiții de depășire a stresului de mare stres.
-
nivel în viitoarele versiuni, acesta va deveni cel mai bun produs din clasă.