Hem Personliga finanser Med Pluggable Storage med NoSQL-dummies

Med Pluggable Storage med NoSQL-dummies

Innehållsförteckning:

Video: Comparing Accumulo, Cassandra, and HBase 2024

Video: Comparing Accumulo, Cassandra, and HBase 2024
Anonim

Det finns tillfällen när du vill ge nyckelvärdesstil höghastighetsåtkomst till data som hålls i en relationsdatabas. Den här databasen kan till exempel vara Berkeley DB (Java Edition för Voldemort) eller MySQL.

Att tillhandahålla nyckeltal som tillgång till data kräver att en nyckelvärdesbutik lagras direkt över en av dessa andra databaser. I grund och botten använder du en annan databas som lagringsskiktet, snarare än en kombination av ett filsystem för lagring och en ingångsrörledning för kopiering av data från en relationsdatabas.

Denna process förenklar att tillhandahålla en höghastighets nyckelvärdesbutik medan du använder en traditionell relationsdatabas för lagring.

Ändra lagringsmotorer

Olika arbetsbelastningar kräver olika lagringsmotorer och prestandaegenskaper. Aerospike är utmärkt för högt intag; Redis är utmärkt för ett stort antal läser. Var och en är byggd kring ett specifikt användningsfall.

Voldemort tar ett annat tillvägagångssätt. I stället för att behandla nyckelfärdighetsbutiken som en separat nivå för datahantering, behandlar Voldemort nyckelfärdighetsbutiken som ett API och lägger till ett minnesminskningsskikt, vilket innebär att du kan ansluta till den bakre änden som ger mest mening för dina speciella behov.

Om du vill ha en enkel disklagringsnivå kan du använda Berkeley DB Java Edition-lagringsenheten. Om du istället vill lagra relationell data kan du använda MySQL som back-end till Voldemort.

Med denna funktion kombinerad med anpassade datatyper kan du använda en enkelvärdesbutiks enkla butik / hämta API för att effektivt dra tillbaka och direkt cache information i en annan backend-butik.

Detta tillvägagångssätt står i motsats till det vanliga sättet att ha separata databaser - en i, t.ex. Oracle för transaktionsdata och en annan i din viktiga butik (Riak, till exempel). Med denna två-tier-strategi måste du utveckla kod för att flytta data från en nivå till den andra för caching. Med Voldemort finns det en kombinerad nivå - din data nivå - så extrakoden är överflödig.

Cachningsdata i minnet

Voldemort har ett inbyggt minne i minnet som minskar belastningen på lagringsmotorn och ökar sökprestanda. Inget behov av att använda ett separat cache-lag, till exempel Redis eller Oracle's Coherence Java-applikationsdata caching-produkt ovanpå.

Möjligheten att tillhandahålla höghastighetslager med cache är varför LinkedIn använder Voldemort för vissa högpresterande användarfall.

Med Voldemort får du det bästa av båda världarna - en lagringsmotor för dina exakta datakrav och en höghastighetsminne i minnet för att minska belastningen på den motorn.Du får också enkelt nyckelvärdesaffärsbutik / hämta semantik ovanpå din lagringsmotor.

Utvärdering av Voldemort

I böckerna Harry Potter höll Lord Voldemort mycket magi i honom, både bra och dåligt, även om han använde det för att terrorisera muggles. Voldemortdatabasen, som det visar sig, kan också lagra stora mängder data, men kan användas till goda av datortillverkare överallt!

Voldemort är fortfarande en produkt i utveckling. Många bitar saknas fortfarande, så det stödjer inte de olika lagringsmotorerna du kan förvänta dig. Detta fokus för Voldemorts utvecklingssamhälle är sannolikt eftersom Voldemort är byggt i Java-programmeringsspråket, vilket kräver att ett Java Native Interface (JNI) -kontakt byggs för integration till de flesta C eller C ++-baserade databaser.

Voldemort har dock en bra integration med serialiseringsramar. Stödda ramar inkluderar Java serialisering, Avro, Sparsamhet och Protocol buffers. Det innebär att de tillhandahållna API-wrapparna matchar den välkända serialiseringsmetoden för varje programmeringsspråk, vilket gör applikationsutvecklingen intuitiv.

Voldemort hanterar inte konsistens såväl som andra system gör. Voldemort använder metoden Read Repair , där inkonsekventa versionsnummer för samma rekord är fasta vid lästid, i stället för att hållas konsekvent vid skrivtiden.

Det finns inte något sekundärt indexerings- eller frågestöd; Voldemort förväntar dig att använda de underliggande lagringsmotorens anläggningar för att klara det användningsfallet. Dessutom har Voldemort inte inbyggda databasutlösare eller en varnings- eller händelsebearbetningsram för att bygga en.

Om du behöver en nyckelvärdesbutik som är mycket tillgänglig, är partitionstolerant, körs i Java och använder olika lagringsbakändar, då kan Voldemort vara för dig.

Med Pluggable Storage med 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 ...