Dremel: Interactive Analysis of Web-Scale Database Presented by Jian Fang Most parts of these slides are stolen from here: http://bit.ly/HIPzeG
What is Dremel Trillion-record, multi-terabyte datasets at interactive speed Scales to thousands of nodes Fault and straggler tolerant execution Nested data model Complex datasets; normalization is prohibitive Columnar storage and processing Tree architecture (as in web search) Interoperates with Google's data management tools In situ data access (e.g., GFS, Bigtable) MapReduce pipelines
Widely used inside Google Analysis of crawled web documents Tracking install data for applications on Android Market Spam analysis Results of tests run on Google's distributed build system Disk I/O statistics for hundreds of thousands of disks ……
Outline Nested columnar storage Query processing Experiments Observations
Common Storage Layer Google File System Fault tolerance Fast response time Data can be manipulated easily
Rows vs Columns r 1 DocId: 10 Links A Forward: 20 * * Name . . . Language B E Code: 'en-us' * Country: 'us' C D Url: 'http://A' r 1 Name Url: 'http://B' r 1 r 1 r 1 r 2 r 2 r 2 r 2 Read less, cheaper . . . decompression Challenge: preserve structure, reconstruct from a subset of fields
r 1 DocId: 10 Nested Data Model Links Forward: 20 Forward: 40 Forward: 60 Name Language message Document { Code: 'en-us' required int64 DocId; Country: 'us' Language optional group Links { Code: 'en' repeated int64 Backward; Url: 'http://A' Name repeated int64 Forward; Url: 'http://B' } Name Language repeated group Name { Code: 'en-gb' repeated group Language { Country: 'gb' required string Code; r 2 optional string Country; DocId: 20 Links } Backward: 10 optional string Url; Backward: 30 Forward: 80 } Name } Url: 'http://C' 7
Repetition and Definition Levels r 1 DocId: 10 Links Values alone do not convey the Forward: 20 structure of a record Forward: 40 Forward: 60 Repetition levels Name R = 0 Language It tells us at what repeated field in the Code: 'en-us' field’s path the value has repeated Country: 'us' R = 2 Language Example: r1, Name.Language.Code Code: 'en' Url: 'http://A' Repetition level: [0,2,1,1] Name R = 1 Language Code: NULL Url: 'http://B' Name R = 1 Language Code: 'en-gb' Country: 'gb'
Repetition and Definition Levels r 1 Definition Levels DocId: 10 Links Specifying how many fields in a path Forward: 20 Forward: 40 that could be undefined are actually Forward: 60 present in the record Name Example: Name.Language.Country Language Code: 'en-us' Country: 'us' Language Missing Country, Code: 'en' d = 2 Url: 'http://A' Name Missing Language, Url: 'http://B' d = 1 Name Language Code: 'en-gb' Country: 'gb'
Column-striped representation DocId Name.Url Links.Forward Links.Backward value r d value r d value r d value r d 10 0 0 http://A 0 2 20 0 2 NULL 0 1 20 0 0 http://B 1 2 40 1 2 10 0 2 NULL 1 1 60 1 2 30 1 2 http://C 0 2 80 0 2 Name.Language.Code Name.Language.Country value r d value r d en-us 0 2 us 0 3 en 2 2 NULL 2 2 NULL 1 1 NULL 1 1 en-gb 1 2 gb 1 3 NULL 0 1 NULL 0 1
Record Assembly FSM DocId message Document { 0 required int64 DocId; 0 optional group Links { 1 1 Links.Backward Links.Forward repeated int64 Backward; 0 repeated int64 Forward; } 0,1,2 repeated group Name { Name.Language.Code Name.Language.Country repeated group Language { required string Code; 2 optional string Country; Name.Ur } 0,1 1 l optional string Url; } 0 } Transitions labeled with repetition levels
Reading two fields s 1 DocId: 10 Name Language Country: 'us' DocId Language 0 Name Name 1,2 Name.Language.Country Language Country: 'gb' 0 s 2 DocId: 20 Name
Query Processing Optimized for select-project-aggregate Very common class of interactive queries Single scan Within-record and cross-record aggregation Approximations: count(distinct), top-k Joins, temp tables, UDFs/TVFs, etc.
Serving Tree client root server intermediate . . . servers . . . leaf servers (with local . . . storage) storage layer (e.g., GFS)
Example: count() SELECT A, COUNT(B) FROM T SELECT A, SUM(c) 0 GROUP BY A FROM (R 1 1 UNION ALL R 1 10) T = {/gfs/1, /gfs/2, …, /gfs/100000} GROUP BY A R 1 1 R 1 2 SELECT A, COUNT(B) AS c SELECT A, COUNT(B) AS c 1 . . . FROM T 1 1 GROUP BY A FROM T 1 2 GROUP BY A T 1 1 = {/gfs/1, …, /gfs/10000} T 1 2 = {/gfs/10001, …, /gfs/20000} SELECT A, COUNT(B) AS c . . . 3 FROM T 3 1 GROUP BY A T 3 1 = {/gfs/1} Data access ops
Experiments Table Number of Size (unrepl., Number Data Repl. 1 PB of real data name records compressed) of fields center factor (uncompressed, non- 3 × replicated) T1 85 billion 87 TB 270 A 3 × T2 24 billion 13 TB 530 A 100K-800K tablets per table 3 × T3 4 billion 70 TB 1200 A Experiments run during 3 × T4 1+ trillion 105 TB 50 B business hours 2 × T5 1+ trillion 20 TB 30 B
Read from disk "cold" time on local disk, averaged over 30 runs time (sec) ( e ) parse as from records C++ objects 10x speedup using columnar objects ( d ) read + storage decompress records ( c ) parse as from columns columns C++ objects ( b ) assemble 2-4x overhead of records using records ( a ) read + decompress number of fields Table partition: 375 MB (compressed), 300K rows, 125 columns
MapReduce and Dremel Execution Avg # of terms in txtField in 85 billion record table T1 execution time (sec) on 3000 nodes Sawzall program ran on MR: num_recs: table sum of int; num_words: table sum of int; emit num_recs <- 1; emit num_words <- count_words(input.txtField); 87 TB 0.5 TB 0.5 TB SELECT SUM(count_words(txtField)) / COUNT(*) Q1: FROM T1 MR overheads: launch jobs, schedule 0.5M tasks, assemble records
Impact of serving tree depth execution time (sec) (returns 1M records) (returns 100s of records) SELECT country, SUM(item.amount) FROM T2 Q2: GROUP BY country 40 billion nested items SELECT domain, SUM(item.amount) FROM T2 Q3: WHERE domain CONTAINS ’ .net ’ GROUP BY domain
Observations Possible to analyze large disk-resident datasets interactively on commodity hardware 1T records, 1000s of nodes MR can benefit from columnar storage just like a parallel DBMS But record assembly is expensive Interactive SQL and MR can be complementary Parallel DBMSes may benefit from serving tree architecture just like search engines
More Information Big Query: http://code.google.com/apis/bigquery/ Apache Drill: http://incubator.apache.org/drill/index.html Thank You
Recommend
More recommend