Hem Personliga finanser Höghastighetsnyckelåtkomst med NoSQL-dummies

Höghastighetsnyckelåtkomst med NoSQL-dummies

Innehållsförteckning:

Anonim

Viktiga butiker i NoSQL handlar om hastighet. Du kan använda olika tekniker för att maximera hastigheten, från cachningsdata, att ha flera kopior av data eller använda de mest lämpliga lagringsstrukturerna.

Cache-data i minnet

Eftersom data är lättåtkomligt när det är lagrat i RAM (RAM), väljer du en nyckelvärdesbutik som cachar data i RAM, kan du snabbt öka tillgången till data, om än till priset högre serverkostnader.

Ofta är det emellertid värt att göra. Du kan enkelt beräkna vilken procentandel av din lagrade data som begärs ofta. Om du vet att fem procent vanligtvis begärs några minuter, ta sedan fem procent av din datastorlek och lägg till det numret som ledigt RAM-utrymme över dina databasservrar.

Tänk på att operativsystemet, andra applikationer och databasservern också har minneskrav.

Replikera data till slavar

I nyckelvärdesbutiker lagras en viss nyckel på en av servrarna i klustret. Denna process heter nyckelpartitionering . Det betyder att om den här nyckeln ständigt begärs kommer den här noden att få större delen av förfrågningarna. Denna nod kommer därför att vara långsammare än din genomsnittliga begäran om hastighet, vilket kan påverka kvaliteten på tjänsten till dina användare.

För att undvika denna situation stöder vissa viktiga butiker att lägga till skrivskyddade repliker, även kallade slavar. Redis, Riak och Aerospike är bra exempel. Replikering tillåter att nyckeln sparas flera gånger på flera servrar, vilket ökar svarhastigheten men på bekostnad av mer hårdvara.

Några viktiga butiker garanterar att replikerna av nyckeln alltid har samma värde som mastern. Denna garanti kallas att vara helt konsekvent. Om en uppdatering händer på huvudservern som håller nyckeln, är alla replikor garanterade att de är aktuella.

Inte alla viktiga butiker garanterar denna status (Riak, till exempel), så om det är viktigt att vara uppdaterad till millisekunden, välj sedan en databas vars replikor är helt konsekventa (till exempel Aerospike).

Datamodellering i nyckelvärdesbutiker

Många viktiga värdebutiker stöder endast grundläggande strukturer för sina värdetyper, och lämnar applikationsprogrammeraren för att tolka data. Enkelt datatypstöd innehåller vanligtvis strängar, heltal, JSON och binära värden.

För många användningsfall fungerar det bra, men ibland är en lite mer granulär tillgång till data användbar.Redis stöder till exempel följande data värde typer:

  • String

  • Lista

  • Ange

  • Sorterat set

  • Hash-kartor

  • Bitraderingar

  • Hyperlog-loggar

Sorterade uppsättningar kan fråga efter matchande värden - precis som att fråga om ett index av värden sorterade efter datum, vilket är mycket användbart för att söka efter en delmängd typad data.

Användning av data

Redis innehåller åtgärder för att öka och minska nyckelvärdena direkt, utan att behöva göra en stegvis modifieringsuppdatering (RMU). Du kan göra det inom en enda transaktion för att säkerställa att ingen annan applikation ändrar värdet under en uppdatering. Dessa datatypsspecifika åtgärder inkluderar att lägga till och ta bort objekt till listor och uppsättningar också.

Du kan även tillhandahålla autofullständig funktionalitet i ett användares användargränssnitt med hjälp av kommandot Redis ZRANGEBYLEX. Detta kommando hämtar en uppsättning nycklar som delvis matchar en sträng. Så om du skulle skriva "NoSQL for" i sökfältet för en applikation som byggdes på Redis så skulle du se förslaget "NoSQL For Dummies. "

Utvärdera Redis

Redis är stolt över att vara en mycket lätt men snabbt snabb viktiga butik. Det var ursprungligen utformat för att vara en värdehanteringsbutik i minnet, men har nu skivbaserad datalagring.

Du kan använda Redis för att skydda data genom att aktivera AOF-fil (lägg till endast fil) och instruera Redis att tvinga data till disk på varje fråga (känd som tvångs fsync-spolning ). AOF gör det långsammare att skriva, förstås, men det ger en högre grad av hållbarhet för data. Var dock medveten om att det fortfarande är möjligt att förlora upp till en sekund av kommandon.

Redis har nyligen bara lagt till stöd för kluster. Faktum är att Rediss klustringsstöd faktiskt ligger i beta-testfasen vid tidpunkten för detta skrivande. Lyckligtvis använder Redis en gemensam-ingenting-klustermodell, med mästare för särskilda nycklar och slavar som aldrig direkt skrivs till av en klient; bara mästaren gör det. Att tillhandahålla delat-ingenting-gruppering bör göra det lättare för Redis att implementera tillförlitlig gruppering än vad det gäller databaser som tillåter att skriva till alla replikor.

Om du vill ha ett mycket höghastighetsminskningsskikt framför en annan databas - MongoDB eller Riak används vanligtvis med Redis - utvärdera sedan Redis som ett alternativ. Eftersom stöd för kluster och data hållbarhet utvecklas, kan Redis kanske övervinna andra backend-databaser.

Höghastighetsnyckelåtkomst med NoSQL-dummies

Redaktörens val

Vad är en Java-karta? - dummies

Vad är en Java-karta? - dummies

Arrays och specialiserade listor gör det möjligt att utföra en fantastisk uppsättning uppgifter med Java. Det finns dock situationer där en Java-applikation behöver något som är mer relaterat till en databas, utan att egentligen ha allt databasbagage (som att behöva köpa en separat applikation). Till exempel kanske du vill kunna ...

Några få saker om Java Math - dummies

Några få saker om Java Math - dummies

Tro det eller inte, datorer - även de mest kraftfulla - Ha vissa begränsningar när det gäller att utföra matematiska beräkningar. Dessa begränsningar är vanligtvis obetydliga, men ibland slår de sig och biter på dig. Här är de saker du behöver se upp för när du gör matte i Java. Helhetsflöde Det grundläggande problemet ...

Vad är recursion i Java Programmering? - dummies

Vad är recursion i Java Programmering? - dummies

Rekursion är en grundläggande programmeringsteknik som du kan använda i Java, där en metod kallar sig för att lösa ett problem. En metod som använder denna teknik är rekursiv. Många programmeringsproblem kan lösas endast genom rekursion, och vissa problem som kan lösas med andra tekniker löses bättre genom rekursion. En av ...

Redaktörens val

4 Måste-inkludera i din blogg sidobardesign - dummies

4 Måste-inkludera i din blogg sidobardesign - dummies

Din bloggens sidofält är viktig fastighet som bör innehålla de element du vill ha mest. När du utformar din blogg sidofält kan du dra från en nästan oändlig lista över sidospårelement. Genom att välja noggrant vad som ska inkluderas (och vad som inte ska inkluderas) kan du ställa in din blogg från andra.

5 Användbara Wordpress Plugins - dummies

5 Användbara Wordpress Plugins - dummies

Om du bloggar på en självhävd plattform med WordPress-programvara, är det dags att anpassa din blogg med plug-ins - programvara som kan "anslutas" till din befintliga WordPress bloggprogramvara. Plug-ins gör det möjligt för dig att göra allt från funktionsbildspel i dina blogginlägg för att ansluta sociala medier till din webbplats. Här är fem användbara ...

7 Sätt att erövra Writer's Block som en Blogger - dummies

7 Sätt att erövra Writer's Block som en Blogger - dummies

Varje bloggare möter författarens block i ett tid eller annan. Om du är den typ av bloggare som sköter innehåll varje dag, kan författarens block vara stäverande. Kan du inte ta en paus för att få ditt skrivande mojo tillbaka? Prova en (eller flera) av dessa sju sätt att slå författarens block för att få dig tillbaka ...

Redaktörens val

10 Stora elektronikkomponentkällor - dummies

10 Stora elektronikkomponentkällor - dummies

Letar du efter några bra källor till dina elektroniska delar? Denna lista ger dig några fleråriga favoriter, både inom och utanför Nordamerika. Denna lista är inte uttömmande. Du hittar bokstavligen tusentals specialutbud för ny och begagnad elektronik. Plus, Amazon och eBay ger virtuella marknadsplatser för alla sorters säljare - ...

Elektronik Basics: Resistance - dummies

Elektronik Basics: Resistance - dummies

I elektronikvärlden är motståndet inte meningslöst. Faktum är att motstånd kan vara mycket användbart. Utan motstånd skulle elektronik inte vara möjligt. Elektronik handlar om att manipulera strömmen av ström, och ett av de mest grundläggande sätten att manipulera strömmen är att minska det genom resistans. Utan motstånd strömmar strömmen oreglerad och där ...

Digital elektronik: Så här installerar du BASIC Stamp Editor och Anslut till Stämpeldummorna

Digital elektronik: Så här installerar du BASIC Stamp Editor och Anslut till Stämpeldummorna

För att berätta för BASIC Stamp vad du vill göra i ditt digitala elektronikprojekt måste du programmera det. BASIC Stamp Windows Editor är den programvara som du använder på din dator för att skapa program som kan laddas ner till en BASIC Stamp-mikrokontroller. Denna programvara är tillgänglig gratis från Parallax webbplats. ...