Lect ure # 10 ADVANCED DATABASE SYSTEMS Storage Models & Data - - PowerPoint PPT Presentation

lect ure 10 advanced database
SMART_READER_LITE
LIVE PREVIEW

Lect ure # 10 ADVANCED DATABASE SYSTEMS Storage Models & Data - - PowerPoint PPT Presentation

Lect ure # 10 ADVANCED DATABASE SYSTEMS Storage Models & Data Layout @ Andy_Pavlo // 15- 721 // Spring 2018 3 Type Representation In-Memory Data Layout Storage Models System Catalogs CMU 15-721 (Spring 2018) 4 DATA O RGAN IZATIO N


slide-1
SLIDE 1

Storage Models & Data Layout

@ Andy_Pavlo // 15- 721 // Spring 2018

ADVANCED DATABASE SYSTEMS Lect ure # 10

slide-2
SLIDE 2
slide-3
SLIDE 3
slide-4
SLIDE 4

CMU 15-721 (Spring 2018)

Type Representation In-Memory Data Layout Storage Models System Catalogs

3

slide-5
SLIDE 5

CMU 15-721 (Spring 2018)

DATA O RGAN IZATIO N

4

Fixed-Length Data Blocks Index

Block Id + Offset

Variable-Length Data Blocks

slide-6
SLIDE 6

CMU 15-721 (Spring 2018)

DATA O RGAN IZATIO N

One can think of an in-memory database as just a large array of bytes.

→ The schema tells the DBMS how to convert the bytes into the appropriate type. → Each tuple is prefixed with a header that contains its meta-data.

Storing tuples with as fixed-length data makes it easy to compute the starting point of any tuple. Mapping virtual memory pages to database pages.

5

slide-7
SLIDE 7

CMU 15-721 (Spring 2018)

M EM O RY PAGES

OS maps physical pages to virtual memory pages. The CPU's MMU maintains a TLB that contains the physical address of a virtual memory page.

→ The TLB resides in the CPU caches. → It can't obviously store every possible every possible entry for a large memory machine.

When you allocate a block of memory, the allocator keeps that it aligned to page boundaries.

6

slide-8
SLIDE 8

CMU 15-721 (Spring 2018)

TRAN SPAREN T H UGE PAGES

Maintain larger pages automatically (2MB to 1GB)

→ Each page has to be a contiguous blocks of memory. → Greatly reduces the # of TLB entries

With THP, the OS will to reorganize pages in the background to keep things compact.

→ Split larger pages into smaller pages. → Combine smaller pages into larger pages. → Can cause the DBMS process to stall on memory access.

Almost every DBMS says to disable this feature:

→ Oracle, MemSQL, NuoDB, MongoDB, Sybase IQ

7

Source: Alexandr Nikitin

slide-9
SLIDE 9

CMU 15-721 (Spring 2018)

DATA REPRESEN TATIO N

INTEGER/BIGINT/SMALLINT/TINYINT

→ C/C++ Representation

FLOAT/REAL vs. NUMERIC/DECIMAL

→ IEEE-754 Standard / Fixed-point Decimals

VARCHAR/VARBINARY/TEXT/BLOB

→ Pointer to other location if type is ≥64-bits → Header with length and address to next location (if segmented), followed by data bytes.

TIME/DATE/TIMESTAMP

→ 32/64-bit integer of (micro)seconds since Unix epoch

8

slide-10
SLIDE 10

CMU 15-721 (Spring 2018)

VARIABLE PRECISIO N N UM BERS

Inexact, variable-precision numeric type that uses the “native” C/C++ types. Store directly as specified by IEEE-754. Typically faster than arbitrary precision numbers.

→ Example: FLOAT, REAL/DOUBLE

9

slide-11
SLIDE 11

CMU 15-721 (Spring 2018)

VARIABLE PRECISIO N N UM BERS

10

#include <stdio.h> int main(int argc, char* argv[]) { float x = 0.1; float y = 0.2; printf("x+y = %.20f\n", x+y); printf("0.3 = %.20f\n", 0.3); }

Rounding Example

x+y = 0.30000001192092895508 0.3 = 0.29999999999999998890

Output

slide-12
SLIDE 12

CMU 15-721 (Spring 2018)

FIXED PRECISIO N N UM BERS

Numeric data types with arbitrary precision and

  • scale. Used when round errors are unacceptable.

→ Example: NUMERIC, DECIMAL

Typically stored in a exact, variable-length binary representation with additional meta-data.

→ Like a VARCHAR but not stored as a string

Demo…

11

slide-13
SLIDE 13

CMU 15-721 (Spring 2018)

PO STGRES: N UM ERIC

12

typedef unsigned char NumericDigit; typedef struct { int ndigits; int weight; int scale; int sign; NumericDigit *digits; } numeric;

# of Digits Weight of 1st Digit Scale Factor Positive/Negative/NaN Digit Storage

slide-14
SLIDE 14

CMU 15-721 (Spring 2018)

PO STGRES: N UM ERIC

12

typedef unsigned char NumericDigit; typedef struct { int ndigits; int weight; int scale; int sign; NumericDigit *digits; } numeric;

# of Digits Weight of 1st Digit Scale Factor Positive/Negative/NaN Digit Storage

slide-15
SLIDE 15

CMU 15-721 (Spring 2018)

PO STGRES: N UM ERIC

12

typedef unsigned char NumericDigit; typedef struct { int ndigits; int weight; int scale; int sign; NumericDigit *digits; } numeric;

# of Digits Weight of 1st Digit Scale Factor Positive/Negative/NaN Digit Storage

slide-16
SLIDE 16

CMU 15-721 (Spring 2018)

DATA LAYO UT

13

CREATE TABLE AndySux ( id INT PRIMARY KEY, value BIGINT ); header id value

char[]

slide-17
SLIDE 17

CMU 15-721 (Spring 2018)

DATA LAYO UT

13

CREATE TABLE AndySux ( id INT PRIMARY KEY, value BIGINT ); header id value

char[]

reinterpret_cast<int32_t*>(address)

slide-18
SLIDE 18

CMU 15-721 (Spring 2018)

VARIABLE- LEN GTH FIELDS

14

CREATE TABLE AndySux ( value VARCHAR(1024) ); header 64-BIT POINTER

char[]

Variable-Length Data Blocks

Andy has the worst hygiene that I have ever seen. I hate LENGTH NEXT him so much. LENGTH NEXT

INSERT INTO AndySux VALUES ("Andy has the worst hygiene that I have ever

  • seen. I hate him so much.");
slide-19
SLIDE 19

CMU 15-721 (Spring 2018)

VARIABLE- LEN GTH FIELDS

14

CREATE TABLE AndySux ( value VARCHAR(1024) ); header 64-BIT POINTER

char[]

Variable-Length Data Blocks

Andy|64-BIT POINTER Andy has the worst hygiene that I have ever seen. I hate LENGTH NEXT him so much. LENGTH NEXT

INSERT INTO AndySux VALUES ("Andy has the worst hygiene that I have ever

  • seen. I hate him so much.");
slide-20
SLIDE 20

CMU 15-721 (Spring 2018)

N ULL DATA TYPES

Choice #1: Special Values

→ Designate a value to represent NULL for a particular data type (e.g., INT32_MIN).

Choice #2: Null Column Bitmap Header

→ Store a bitmap in the tuple header that specifies what attributes are null.

Choice #3: Per Attribute Null Flag

→ Store a flag that marks that a value is null. → Have to use more space than just a single bit because this messes up with word alignment.

15

slide-21
SLIDE 21

CMU 15-721 (Spring 2018)

N ULL DATA TYPES

Choice #1: Special Values

→ Designate a value to represent NULL for a particular data type (e.g., INT32_MIN).

Choice #2: Null Column Bitmap Header

→ Store a bitmap in the tuple header that specifies what attributes are null.

Choice #3: Per Attribute Null Flag

→ Store a flag that marks that a value is null. → Have to use more space than just a single bit because this messes up with word alignment.

15

slide-22
SLIDE 22

CMU 15-721 (Spring 2018)

DISCLAIM ER

The truth is that you only need to worry about word-alignment for cache lines (e.g., 64 bytes). I’m going to show you the basic idea using 64-bit words since it’s easier to see…

16

slide-23
SLIDE 23

CMU 15-721 (Spring 2018)

WO RD- ALIGN ED TUPLES

All attributes in a tuple must be word aligned to enable the CPU to access it without any unexpected behavior or additional work.

17

CREATE TABLE AndySux ( id INT PRIMARY KEY, cdate TIMESTAMP, color CHAR(2), zipcode INT ); 64-bit Word 64-bit Word 64-bit Word 64-bit Word

char[]

slide-24
SLIDE 24

CMU 15-721 (Spring 2018)

WO RD- ALIGN ED TUPLES

All attributes in a tuple must be word aligned to enable the CPU to access it without any unexpected behavior or additional work.

17

CREATE TABLE AndySux ( id INT PRIMARY KEY, cdate TIMESTAMP, color CHAR(2), zipcode INT ); 32-bits 64-bit Word 64-bit Word 64-bit Word 64-bit Word id

char[]

slide-25
SLIDE 25

CMU 15-721 (Spring 2018)

WO RD- ALIGN ED TUPLES

All attributes in a tuple must be word aligned to enable the CPU to access it without any unexpected behavior or additional work.

17

CREATE TABLE AndySux ( id INT PRIMARY KEY, cdate TIMESTAMP, color CHAR(2), zipcode INT ); 32-bits 64-bits 64-bit Word 64-bit Word 64-bit Word 64-bit Word id cdate

char[]

slide-26
SLIDE 26

CMU 15-721 (Spring 2018)

WO RD- ALIGN ED TUPLES

All attributes in a tuple must be word aligned to enable the CPU to access it without any unexpected behavior or additional work.

17

CREATE TABLE AndySux ( id INT PRIMARY KEY, cdate TIMESTAMP, color CHAR(2), zipcode INT ); 32-bits 64-bits 16-bits 64-bit Word 64-bit Word 64-bit Word 64-bit Word id cdate c

char[]

slide-27
SLIDE 27

CMU 15-721 (Spring 2018)

WO RD- ALIGN ED TUPLES

All attributes in a tuple must be word aligned to enable the CPU to access it without any unexpected behavior or additional work.

17

CREATE TABLE AndySux ( id INT PRIMARY KEY, cdate TIMESTAMP, color CHAR(2), zipcode INT ); 32-bits 64-bits 16-bits 32-bits 64-bit Word 64-bit Word 64-bit Word 64-bit Word id cdate c zipc

char[]

slide-28
SLIDE 28

CMU 15-721 (Spring 2018)

WO RD- ALIGN ED TUPLES

All attributes in a tuple must be word aligned to enable the CPU to access it without any unexpected behavior or additional work.

17

CREATE TABLE AndySux ( id INT PRIMARY KEY, cdate TIMESTAMP, color CHAR(2), zipcode INT ); 32-bits 64-bits 16-bits 32-bits 64-bit Word 64-bit Word 64-bit Word 64-bit Word id cdate c zipc

char[]

slide-29
SLIDE 29

CMU 15-721 (Spring 2018)

WO RD- ALIGN ED TUPLES

If the CPU fetches a 64-bit value that is not word- aligned, it has three choices: →Execute two reads to load the appropriate parts

  • f the data word and reassemble them.

→Read some unexpected combination of bytes assembled into a 64-bit word. →Throw an exception

18

Source: Levente Kurusa

slide-30
SLIDE 30

CMU 15-721 (Spring 2018)

CREATE TABLE AndySux ( id INT PRIMARY KEY, cdate TIMESTAMP, color CHAR(2), zipcode INT );

WO RD- ALIGN ED TUPLES

All attributes in a tuple must be word aligned to enable the CPU to access it without any unexpected behavior or additional work.

19

64-bit Word 64-bit Word 64-bit Word 64-bit Word id cdate c zipc

00000000 00000000 00000000 00000000 0000 0000 0000 0000

char[]

32-bits 64-bits 16-bits 32-bits

slide-31
SLIDE 31

CMU 15-721 (Spring 2018)

STO RAGE M O DELS

N-ary Storage Model (NSM) Decomposition Storage Model (DSM) Hybrid Storage Model

20

slide-32
SLIDE 32

CMU 15-721 (Spring 2018)

N- ARY STO RAGE M O DEL (N SM )

The DBMS stores all of the attributes for a single tuple contiguously. Ideal for OLTP workloads where txns tend to

  • perate only on an individual entity and insert-

heavy workloads. Use the tuple-at-a-time iterator model.

21

slide-33
SLIDE 33

CMU 15-721 (Spring 2018)

N SM PH YSICAL STO RAGE

Choice #1: Heap-Organized Tables

→ Tuples are stored in blocks called a heap. → The heap does not necessarily define an order.

Choice #2: Index-Organized Tables

→ Tuples are stored in the primary key index itself. → Not quite the same as a clustered index.

22

slide-34
SLIDE 34

CMU 15-721 (Spring 2018)

N- ARY STO RAGE M O DEL (N SM )

Advantages

→ Fast inserts, updates, and deletes. → Good for queries that need the entire tuple. → Can use index-oriented physical storage.

Disadvantages

→ Not good for scanning large portions of the table and/or a subset of the attributes.

23

slide-35
SLIDE 35

CMU 15-721 (Spring 2018)

DECO M PO SITIO N STO RAGE M O DEL (DSM )

The DBMS stores a single attribute for all tuples contiguously in a block of data.

→ Sometimes also called vertical partitioning.

Ideal for OLAP workloads where read-only queries perform large scans over a subset of the table’s attributes. Use the vector-at-a-time iterator model.

24

slide-36
SLIDE 36

CMU 15-721 (Spring 2018)

DECO M PO SITIO N STO RAGE M O DEL (DSM )

1970s: Cantor DBMS 1980s: DSM Proposal 1990s: SybaseIQ (in-memory only) 2000s: Vertica, Vectorwise, MonetDB 2010s: “The Big Three” Cloudera Impala, Amazon Redshift, SAP HANA, MemSQL

25

slide-37
SLIDE 37

CMU 15-721 (Spring 2018)

TUPLE IDEN TIFICATIO N

Choice #1: Fixed-length Offsets

→ Each value is the same length for an attribute.

Choice #2: Embedded Tuple Ids

→ Each value is stored with its tuple id in a column.

26

Offsets

1 2 3

A B C D

Embedded Ids

A

1 2 3

B

1 2 3

C

1 2 3

D

1 2 3

slide-38
SLIDE 38

CMU 15-721 (Spring 2018)

DECO M PO SITIO N STO RAGE M O DEL (DSM )

Advantages

→ Reduces the amount wasted work because the DBMS

  • nly reads the data that it needs.

→ Better compression.

Disadvantages

→ Slow for point queries, inserts, updates, and deletes because of tuple splitting/stitching.

27

slide-39
SLIDE 39

CMU 15-721 (Spring 2018)

O BSERVATIO N

Data is “hot” when first entered into database

→ A newly inserted tuple is more likely to be updated again the near future.

As a tuple ages, it is updated less frequently.

→ At some point, a tuple is only accessed in read-only queries along with other tuples.

What if we want to use this data to make decisions that affect new txns?

28

slide-40
SLIDE 40

CMU 15-721 (Spring 2018)

BIFURCATED EN VIRO N M EN T

29

Extract Transform Load OLAP Data Warehouse OLTP Data Silos

slide-41
SLIDE 41

CMU 15-721 (Spring 2018)

H YBRID STO RAGE M O DEL

Single logical database instance that uses different storage models for hot and cold data. Store new data in NSM for fast OLTP Migrate data to DSM for more efficient OLAP

30

slide-42
SLIDE 42

CMU 15-721 (Spring 2018)

H YBRID STO RAGE M O DEL

Choice #1: Separate Execution Engines

→ Use separate execution engines that are optimized for either NSM or DSM databases.

Choice #2: Single, Flexible Architecture

→ Use single execution engine that is able to efficiently

  • perate on both NSM and DSM databases.

31

slide-43
SLIDE 43

CMU 15-721 (Spring 2018)

SEPARATE EXECUTIO N EN GIN ES

Run separate “internal” DBMSs that each only

  • perate on DSM or NSM data.

→ Need to combine query results from both engines to appear as a single logical database to the application. → Have to use a synchronization method (e.g., 2PC) if a txn spans execution engines.

Two approaches to do this:

→ Fractured Mirrors (Oracle, IBM) → Delta Store (SAP HANA)

32

slide-44
SLIDE 44

CMU 15-721 (Spring 2018)

FRACTURED M IRRO RS

Store a second copy of the database in a DSM layout that is automatically updated.

→ All updates are first entered in NSM then eventually copied into DSM mirror.

33

A CASE FOR FRACTURED MIRRORS

VLDB 2002

OLTP Updates OLAP Queries NSM (Primary) DSM (Mirror)

slide-45
SLIDE 45

CMU 15-721 (Spring 2018)

DELTA STO RE

Stage updates to the database in an NSM table. A background thread migrates updates from delta store and applies them to DSM data.

34

Delta Store DSM Historical Data OLTP Updates

slide-46
SLIDE 46

CMU 15-721 (Spring 2018)

CATEGO RIZIN G DATA

Choice #1: Manual Approach

→ DBA specifies what tables should be stored as DSM.

Choice #2: Off-line Approach

→ DBMS monitors access logs offline and then makes decision about what data to move to DSM.

Choice #3: On-line Approach

→ DBMS tracks access patterns at runtime and then makes decision about what data to move to DSM.

35

slide-47
SLIDE 47

CMU 15-721 (Spring 2018)

PELOTO N ADAPTIVE STO RAGE

Employ a single execution engine architecture that is able to operate on both NSM and DSM data.

→ Don’t need to store two copies of the database. → Don’t need to sync multiple database segments.

Note that a DBMS can still use the delta-store approach with this single-engine architecture.

36

BRIDGING THE ARCHIPELAGO BETWEEN ROW- STORES AND COLUMN- STORES FOR HYBRID WORKLOADS SIGMOD 2016

slide-48
SLIDE 48

CMU 15-721 (Spring 2018)

PELOTO N ADAPTIVE STO RAGE

37

Original Data

SELECT AVG(B) FROM AndySux WHERE C = “yyy” UPDATE AndySux SET A = 123, B = 456, C = 789 WHERE D = “xxx”

A B C D

slide-49
SLIDE 49

CMU 15-721 (Spring 2018)

PELOTO N ADAPTIVE STO RAGE

37

Original Data

SELECT AVG(B) FROM AndySux WHERE C = “yyy” UPDATE AndySux SET A = 123, B = 456, C = 789 WHERE D = “xxx”

A B C D

Cold Hot

slide-50
SLIDE 50

CMU 15-721 (Spring 2018)

PELOTO N ADAPTIVE STO RAGE

37

Original Data Adapted Data

SELECT AVG(B) FROM AndySux WHERE C = “yyy” UPDATE AndySux SET A = 123, B = 456, C = 789 WHERE D = “xxx”

A B C D A B C D A B C D

Cold Hot

slide-51
SLIDE 51

CMU 15-721 (Spring 2018)

TILE ARCH ITECTURE

Introduce an indirection layer that abstracts the true layout of tuples from query operators.

38

Tile Group A Tile Group B

A B C D

Tile #1 Tile #2 Tile #3 Tile #4

slide-52
SLIDE 52

CMU 15-721 (Spring 2018)

TILE ARCH ITECTURE

Introduce an indirection layer that abstracts the true layout of tuples from query operators.

38

A B C D

Tile #1 Tile #2 Tile #3 Tile #4

H

+ + + + +

Tile Group Header

slide-53
SLIDE 53

CMU 15-721 (Spring 2018)

AS AS

γ

s

TILE ARCH ITECTURE

Introduce an indirection layer that abstracts the true layout of tuples from query operators.

38

A B C D H

+ + + + +

SELECT AVG(B) FROM AndySux WHERE C = “yyy”

1 2

B

1 2 3

slide-54
SLIDE 54

CMU 15-721 (Spring 2018)

AS AS

γ

s

TILE ARCH ITECTURE

Introduce an indirection layer that abstracts the true layout of tuples from query operators.

38

A B C D H

+ + + + +

SELECT AVG(B) FROM AndySux WHERE C = “yyy”

1 2

B

1 2 3

slide-55
SLIDE 55

CMU 15-721 (Spring 2018)

PELOTO N ADAPTIVE STO RAGE

39

400 800 1200 1600

Row Layout Column Layout Adaptive Layout Sep-15

Scan Insert Scan Insert Scan Insert Scan Insert Scan Insert Scan Insert

Execution Time (ms)

Sep-16 Sep-17 Sep-18 Sep-19 Sep-20

slide-56
SLIDE 56

CMU 15-721 (Spring 2018)

PARTIN G TH O UGH TS

A flexible architecture that supports a hybrid storage model is the next major trend in DBMSs

→ This will enable relational DBMSs to support all database workloads except for matrices in machine learning.

40