Hem Personliga finanser Hantera nycklar i NoSQL - dummies

Hantera nycklar i NoSQL - dummies

Innehållsförteckning:

Video: Web Programming - Computer Science for Business Leaders 2016 2024

Video: Web Programming - Computer Science for Business Leaders 2016 2024
Anonim

Viktiga butiks snabbläsare beror på användningen av väldefinierade tangenter. Dessa nycklar är vanligtvis hashed, vilket ger en nyckelvärdesbutik ett mycket förutsägbart sätt att bestämma vilken delning (och därmed server) data finns på. En viss server hanterar en eller flera partitioner.

Med en bra nyckel kan du unikt identifiera den enskilda posten som svarar på en fråga utan att behöva titta på några värden inom den här posten. En dålig nyckel kommer att kräva att din ansökningskod tolkar din post för att avgöra om det faktiskt matchar frågan.

Om du inte utformar din nyckel bra kan du sluta med en server som har en oproportionerligt tungare belastning än de andra, vilket leder till dålig prestanda. Med den aktuella systemtiden som en nyckel trycker du till exempel all ny data på sista noden i klustret, vilket leder till ett mardrömscenario för ombalansering.

Partitionering

Partition design är viktigt eftersom vissa viktiga butiker, till exempel Oracle NoSQL, inte tillåter att antalet partitioner ändras när ett kluster skapats. Deras distribution över servrar kan dock ändras. Så börja med ett stort antal partitioner som du kan sprida ut i framtiden.

Ett exempel på partitionering är Voldemorts konsekventa hashing-strategi, som visat. Här ser du samma partitioner spridas över tre servrar i början och sedan över fyra servrar senare. Antalet partitioner är desamma, men deras fördelning är annorlunda över servrar. Detsamma gäller för deras replikor.

Åtkomst till data på partitioner

Viktiga butiker är mycket distribuerade utan någon enda felpunkt. Det betyder att det inte finns något behov av en masterkoordineringskod för att hålla reda på servrar inom ett kluster. Klusterhantering görs automatiskt av ett chattprotokoll mellan noder i servern.

Du kan använda ett knep i klientdrivrutinen för att klara maximal prestanda utifrån att hämta och lagra nycklar och värden. Klientdrivrutinen håller reda på vilka servrar som håller några olika knappar. Så klientdrivrutinen vet alltid vilken server som ska prata med.

De flesta databaser, inklusive NoSQL, skickar en förfrågan till alla medlemmar i ett kluster. Det klustret accepterar antingen skrivet internt eller skickar det ett under huven till rätt nod. Denna inställning innebär en extra nätverksresa mellan noder är möjlig, vilket kan lägga till latens.

För att undvika upptäckt latens, behåller de flesta viktiga butiks klientdrivrutiner en metadatarlista över nuvarande noder i ett kluster och vilken partitionsnyckel som varierar mellan varje nodhantering.På så sätt kan klientdrivrutinen kontakta den korrekta servern, vilket gör operationerna snabbare.

Om en ny nod läggs till i ett kluster och metadata är föråldrade informerar klustret klientdrivrutinen, som sedan hämtar de senaste klustermetadataen innan den skickas tillbaka till önskad nod. På så sätt upprätthålls maximal genomströmning med ett minimum av overhead under utveckling. En annan fördel är att det inte finns något behov av en lastbalansering för att skicka frågor till nästa tillgängliga eller minst upptagna server - endast en server (eller läs repliksserver) får någonsin en kundförfrågan, så det finns inget behov av belastningsbalansering.

Hantera nycklar i NoSQL - dummies

Redaktörens val

Jewish Funeral Traditions - dummies

Jewish Funeral Traditions - dummies

Judiska begravningar sker vanligen i en synagoge, begravningshem eller på en kyrkogård. Med tradition är judiska begravningar enkla (symboliserar tron ​​att människor är alla lika i döden), men de varierar mycket och har ingen uppsättning liturgi. Att skicka blommor till ett begravnings- eller sorgshem är starkt avskräckt i judendomen. Inte bara kommer ...

Identifiera komplicerade grävande dummies

Identifiera komplicerade grävande dummies

Komplicerat roende är det tekniska namnet som sorgproffs ger till en sorgprocess som sitter fast vid något tillfälle , vilket gör det omöjligt för de förlorade att framgångsrikt starta eller avsluta sorgprocessen. Komplicerat sorg är ofta ett tecken på olösta problem i förhållandet mellan de förlorade och den avlidne som gör det ...

Redaktörens val

Hur man ställer in kartkontroller i Main_iPad. Storyboard i din iOS App - dummies

Hur man ställer in kartkontroller i Main_iPad. Storyboard i din iOS App - dummies

När du har en anpassad vy för MapController i din iOS-app, måste du berätta för iPad-storyboardet att du laddar in din anpassade vy i stället för en UIViewController. Följ dessa steg: Välj Projekt navigator genom att välja Main_iPad. storyboard och välj sedan View Controller i View Controller - Map Scene i dokumentutskriften. ...

Hur man roterar objekt i din iOS-app - dummies

Hur man roterar objekt i din iOS-app - dummies

Här hittar du hur man rotera en vy (i så fall vrid bilen runt) i din iOS-app. För att göra det uppdaterar du den roterande kodstuben du startade med och ersätter den med den fetstilta koden. - (void) rotera {CGAffineTransform transform = CGAffineTransformMakeRotation (M_PI); void (^ animation) () = ^ () {self. bil. transformera = transformera; ...

Hur man ställer in en WeatherController i Main_iPad. storyboard-fil för din iOS-app - dummies

Hur man ställer in en WeatherController i Main_iPad. storyboard-fil för din iOS-app - dummies

Bör du lägga till en ny anpassad vykontroll till din iOS-app innan du fortsätter till dessa steg. Du behöver fortfarande berätta för storyboardet att du vill att den ska ladda den nya anpassade vykontrollen istället för en UIViewController. Följ dessa steg:

Redaktörens val

Spara en grafisk stil i Adobe CS5 Illustrator - dummies

Spara en grafisk stil i Adobe CS5 Illustrator - dummies

Adobe Creative Suite 5 (Adobe CS5) Illustrator tillåter Du sparar en grafisk stil. En grafisk stil är en kombination av alla inställningar du väljer för ett visst filter eller en effekt i Utseendepanelen. Genom att spara informationen i en grafisk stil lagras du dessa attribut så att du snabbt och enkelt kan tillämpa ...

Välj som ett transformationsverktyg i Adobe CS5 Illustrator - dummies

Välj som ett transformationsverktyg i Adobe CS5 Illustrator - dummies

I Adobe Creative Suite 5 (Adobe CS5 ) Illustratör du kan använda markeringsverktyget för att skala och rotera ett valt objekt. Dra begränsningsboxens handtag för att ändra storlek på objektet, eller flytta dig utanför ett handtag och sedan, när markören ändras till en flippig pil (en böjd pil med pilhuvud i båda ändarna), dra till ...

Objekttransformation i Adobe CS5 Illustrator - dummies

Objekttransformation i Adobe CS5 Illustrator - dummies

Verktygen Rotate, Reflect, Scale och Shear i Adobe Creative Suite 5 (Adobe CS5) Illustrator använder alla samma grundläggande steg för att utföra transformationer. Här är fem sätt att transformera ett objekt: en för en godtycklig omvandling och fyra andra för exakta omvandlingar baserat på en numerisk mängd som du anger. Vilkårlig omvandlingsmetod Eftersom detta ...