Skip to content

Project4

Yeonguk Go edited this page Oct 8, 2021 · 3 revisions

Project4 Design

Index

  1. Project4์˜ ์š”๊ตฌ์‚ฌํ•ญ
  2. JOIN operation ๊ตฌํ˜„
  3. ๊ทธ ์™ธ ๋ณ€๊ฒฝ์‚ฌํ•ญ
  4. TODO


1. Project4์˜ ์š”๊ตฌ์‚ฌํ•ญ

์ตœ๋Œ€์˜ ๋ฉ”๋ชจ๋ฆฌ ์‚ฌ์šฉ์„ ์œ ์ง€ํ•˜๋ฉฐ (์ถ”๊ฐ€์ ์ธ ๋ฉ”๋ชจ๋ฆฌ ํ• ๋‹น/์‚ฌ์šฉ์„ ํ•˜์ง€ ์•Š์œผ๋ฉฐ) JOIN operation์„ ๊ตฌํ˜„

  1. int join_table(int table_id_1, int table_id_2, char* pathname) ํ•จ์ˆ˜๋ฅผ API service๋กœ ์ œ๊ณต
  2. 2๊ฐœ table์„ natural join
  3. ์ฃผ์–ด์ง„ pathname์˜ ํŒŒ์ผ๋กœ ๊ฒฐ๊ณผ๋ฅผ ์ถœ๋ ฅ
  4. ๊ฒฐ๊ณผ๋Š” key์— ๋”ฐ๋ผ ์˜ค๋ฆ„์ฐจ์ˆœ ์ •๋ ฌ๋˜์–ด์žˆ์„ ๊ฒƒ
  5. ๊ตฌํ˜„ํ•œ ํ•จ์ˆ˜๊ฐ€ ์„ฑ๊ณต ๋ฐ˜ํ™˜ ์‹œ ๊ฒฐ๊ณผ๊ฐ€ write ์™„๋ฃŒ๋˜์–ด ์žˆ์„ ๊ฒƒ


2. JOIN operation ๊ตฌํ˜„

๊ฐœ์š”

  • JOIN operation์ด ์กด์žฌํ•  relational set operator layer๋ฅผ ์ถ”๊ฐ€ํ•˜์˜€์œผ๋ฉฐ, API layer์˜ join_table ํ•จ์ˆ˜(wrapper function)๊ฐ€ ํ˜ธ์ถœํ•  rso_join_table ํ•จ์ˆ˜๋ฅผ relational set operator layer์— ๊ตฌํ˜„ํ•˜์˜€๋‹ค. ํ•˜์œ„ layer์—์„œ ๊ตฌํ˜„๋œ API๋“ค์˜ wrapper function์„ ํ•ด๋‹น layer์— ์ถ”๊ฐ€ํ•˜์˜€์œผ๋ฉฐ, ํ•ด๋‹น layer์—์„œ buffer๋ฅผ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด index manager์— buffer manager ํ•จ์ˆ˜ ์ผ๋ถ€์˜ wrapper function์„ ์ถ”๊ฐ€ํ•˜์˜€๋‹ค. ์ž์„ธํ•œ ๋‚ด์šฉ์€ Layer ๊ตฌ์กฐ ๋ณ€๊ฒฝ ์ฐธ๊ณ 
  • ํ•ด๋‹น layer์˜ rso_join_table ํ•จ์ˆ˜๊ฐ€ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•œ find_leftmost_leaf ํ•จ์ˆ˜๋ฅผ index manager์— ์ถ”๊ฐ€ ๊ตฌํ˜„ํ•˜์˜€๋‹ค.
  • ํ•ด๋‹น layer์˜ rso_join_table ํ•จ์ˆ˜๊ฐ€ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•œ advance ํ•จ์ˆ˜๋ฅผ ํ•ด๋‹น layer์— ๊ตฌํ˜„ํ•˜์˜€๋‹ค.
  • JOIN operation์„ ๊ตฌํ˜„ํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š”, Block Nested Loops Join, Index Nested Loops Join, Sort-Merge Join, Hash Join ๋“ฑ์„ ๊ณ ๋ คํ•ด๋ณผ ์ˆ˜ ์žˆ๋‹ค. ํ˜„์žฌ DB๋Š” B+Tree๋กœ ๋ชจ๋“  record๊ฐ€ key์— ๋”ฐ๋ผ ์ •๋ ฌ๋œ ์ƒํƒœ์ด๊ณ , ์ถœ๋ ฅํ•  ๊ฒฐ๊ณผ๊ฐ€ key์— ๋”ฐ๋ผ ์˜ค๋ฆ„์ฐจ์ˆœ ์ •๋ ฌ๋˜์–ด์•ผ ํ•˜๋ฏ€๋กœ, ์ •๋ ฌ๋œ ์ž…๋ ฅ ์‹œ ์ •๋ ฌ ์ž‘์—…์„ passํ•  ์ˆ˜ ์žˆ๊ณ  ์ •๋ ฌ๋œ ๊ฒฐ๊ณผ๋ฅผ ์ถœ๋ ฅํ•˜๋Š” Sort-Merge Join์„ ์„ ํƒํ•˜์˜€๋‹ค.
  • ์ด์— ๋”ฐ๋ผ, ๊ฐ•์˜์ž๋ฃŒ(lecture11 16slide)์—์„œ ์ œ์‹œ๋œ pseudo code๋ฅผ ์ฐธ๊ณ ํ•˜์˜€์œผ๋‚˜, ํ˜„์žฌ DB๋Š” key์˜ ์ค‘๋ณต์„ ํ—ˆ์šฉํ•˜์ง€ ์•Š์œผ๋ฏ€๋กœ ๋ณด๋‹ค ๋‹จ์ˆœํ•˜๊ฒŒ ๊ตฌํ˜„์ด ๊ฐ€๋Šฅํ•˜๋‹ค.

rso_join_table ํ•จ์ˆ˜

int rso_join_table(int table_id_1, int table_id_2, char* pathname);
  • relational set operator layer์— ๊ตฌํ˜„
  • 2๊ฐœ table์˜ id๋ฅผ ์ž…๋ ฅ๋ฐ›์•„์„œ natural join์„ ์ˆ˜ํ–‰ํ•˜๊ณ , ๊ทธ ๊ฒฐ๊ณผ๋ฅผ ์ž…๋ ฅ๋ฐ›์€ pathname์˜ ํŒŒ์ผ์— ์ €์žฅํ•œ ํ›„, ์„ฑ๊ณต ์—ฌ๋ถ€๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค. (์„ฑ๊ณต : 0, ์‹คํŒจ : non-zero value)
  • key์˜ ์ค‘๋ณต์„ ๊ฐ€์ •ํ•œ ๊ธฐ์กด Sort-Merge Join๊ณผ ๋‹ฌ๋ฆฌ, ์ค‘๋ณต key block์˜ start point๋ฅผ ์ €์žฅํ•ด๊ฐ€๋ฉฐ ๋Œ์•„๊ฐˆ ํ•„์š”๊ฐ€ ์—†๊ณ , ๊ฐ table์—์„œ page๋ฅผ 1๊ฐœ์”ฉ readํ•ด๊ฐ€๋ฉฐ ์ˆ˜ํ–‰์ด ๊ฐ€๋Šฅํ•˜๋‹ค.
  • ๊ตฌ์ฒด์ ์ธ ๊ตฌํ˜„๊ณผ ๊ทธ ์ˆœ์„œ๋Š” ์•„๋ž˜์™€ ๊ฐ™๋‹ค.
    1. ์ธ์ž๋กœ ๋ฐ›์€ pathname์„ ๊ฐ€์ง€๋Š” file์„ (๋ฎ์–ด)์“ฐ๊ธฐ ์ „์šฉ์œผ๋กœ openํ•œ๋‹ค. ์‹คํŒจ ์‹œ -1์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
    2. ๊ฐ table์˜ header page๋ฅผ requestํ•˜๊ณ , find_leftmost_leaf ํ•จ์ˆ˜๋ฅผ callํ•˜์—ฌ ๊ฐ table์˜ leftmost leaf page๋ฅผ ์ฐพ๋Š”๋‹ค. request ์‹คํŒจ ์‹œ -2๋ฅผ ๋ฐ˜ํ™˜, find_leftmost_leaf ์‹คํŒจ ์‹œ(table์ด ๋น„์—ˆ์„ ์‹œ) -3์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
    3. ๊ฐ table์˜ ์ฒซ record๋ถ€ํ„ฐ key๋ฅผ ์„œ๋กœ ๋น„๊ตํ•˜๋ฉฐ ํ•œ ์ชฝ์ด ์ž‘์œผ๋ฉด ์ž‘์€ ์ชฝ์„ advance, ๊ฐ™์œผ๋ฉด ์ถœ๋ ฅ ํ›„ ๋‘˜ ๋‹ค advanceํ•˜๋Š” ๊ฒƒ์„ ๋‘˜ ์ค‘ 1๊ฐœ ์ด์ƒ table์—์„œ advance๊ฐ€ ๋ถˆ๊ฐ€๋Šฅํ•  ๋•Œ ๋งˆ์ง€๋ง‰ record๋ฅผ ์ฒ˜๋ฆฌํ•  ๋•Œ๊นŒ์ง€ ๋ฐ˜๋ณตํ•œ๋‹ค.
    4. ๊ตฌํ˜„ํ•œ ํ•จ์ˆ˜๊ฐ€ ์„ฑ๊ณต์„ ๋ฐ˜ํ™˜ํ•˜๊ธฐ ์ด์ „์— ํŒŒ์ผ write๊ฐ€ ์™„๋ฃŒ๋˜์–ด์•ผ ํ•˜๋ฏ€๋กœ, fsync ํ•จ์ˆ˜๋ฅผ callํ•˜์—ฌ ์‹ค์ œ disk write์ด ์ˆ˜ํ–‰๋˜๋„๋ก ํ•œ๋‹ค.
    5. ์š”์ฒญํ•˜์—ฌ ํ˜„์žฌ ์‚ฌ์šฉ ์ค‘์ด๋˜ page๋ฅผ ๋ชจ๋‘ releaseํ•˜๊ณ  file์„ ๋‹ซ๋Š”๋‹ค.
    6. 0(์„ฑ๊ณต)์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.

find_leftmost_leaf ํ•จ์ˆ˜

buffer_block_t* find_leftmost_leaf(buffer_block_t *header_buffer);
  • index manager layer์— ๊ตฌํ˜„
  • ํŠน์ • table์˜ header page (buffer block ํฌ์ธํ„ฐ)๋ฅผ ์ž…๋ ฅ๋ฐ›๊ณ  ํ•ด๋‹น table์˜ leftmost leaf page๋ฅผ ํƒ์ƒ‰ํ•˜์—ฌ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
  • ํ˜„์žฌ record์˜ key๋Š” ์ž๋ฃŒํ˜•์œผ๋กœ int64_t๋ฅผ ์‚ฌ์šฉํ•˜๋ฏ€๋กœ index_find_leaf ํ•จ์ˆ˜์— ํ•ด๋‹น ์ž๋ฃŒํ˜•์˜ ์ตœ์†Ÿ๊ฐ’์„ key๋กœ ์ž…๋ ฅํ•˜์—ฌ ๋™์ผํ•œ ๊ธฐ๋Šฅ์„ ์ˆ˜ํ–‰ํ•  ์ˆ˜ ์žˆ๋‹ค. ํ•˜์ง€๋งŒ key์— ๋”ฐ๋ฅธ ํƒ์ƒ‰ ์ž‘์—… ์—†์ด ์ˆ˜ํ–‰ํ•˜๋„๋ก ์ถ”๊ฐ€์ ์ธ ํ•จ์ˆ˜๋ฅผ ๊ตฌํ˜„ํ•˜์˜€๋‹ค.
  • ๊ตฌ์ฒด์ ์ธ ๊ตฌํ˜„๊ณผ ๊ทธ ์ˆœ์„œ๋Š” ์•„๋ž˜์™€ ๊ฐ™๋‹ค.
    1. ํ˜„์žฌ table์ด empty์ด๋ฉด NULL์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
    2. root page์—์„œ ์‹œ์ž‘ํ•˜์—ฌ leaf page์— ์ด๋ฅผ ๋•Œ๊นŒ์ง€ ๊ฐ internal page์—์„œ leftmost child page, ์ฆ‰ one more page์˜ ํƒ์ƒ‰์„ ๋ฐ˜๋ณตํ•œ๋‹ค.
    3. ํ•ด๋‹น page์˜ buffer block ํฌ์ธํ„ฐ๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค.

advance ํ•จ์ˆ˜

int advance(int *idx, buffer_block_t **cur_buf, page_t **cur_page);
  • relational set operator layer์— ๊ตฌํ˜„
  • ํŠน์ • page์—์„œ ํ˜„์žฌ ํ™•์ธํ•œ record์˜ ๋‹ค์Œ record๋กœ advanceํ•˜๊ณ  ์„ฑ๊ณต ์—ฌ๋ถ€๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค. ์ด๋ฅผ ์œ„ํ•ด ํ•ด๋‹น page buffer์™€ ๊ทธ ์•ˆ์˜ frame ํฌ์ธํ„ฐ์˜ ์ฃผ์†Œ(caller์—์„œ ํ•ด๋‹น ํฌ์ธํ„ฐ๋“ค์„ ์ €์žฅํ•œ ํฌ์ธํ„ฐ ๋ณ€์ˆ˜๋“ค์˜ ์ฃผ์†Œ), ํ•ด๋‹น page์—์„œ ํ˜„์žฌ ํ™•์ธํ•œ record์˜ index๊ฐ’์˜ ์ฃผ์†Œ(caller์—์„œ ํ•ด๋‹น ๊ฐ’์„ ์ €์žฅํ•œ ๋ณ€์ˆ˜์˜ ์ฃผ์†Œ)๋ฅผ ์ธ์ž๋กœ ๋ฐ›๋Š”๋‹ค.
  • ๊ตฌ์ฒด์ ์ธ ๊ตฌํ˜„๊ณผ ๊ทธ ์ˆœ์„œ๋Š” ์•„๋ž˜์™€ ๊ฐ™๋‹ค.
    1. ํ˜„์žฌ ํ™•์ธํ•œ record์˜ index๊ฐ€ ํ•ด๋‹น page์˜ key ๊ฐฏ์ˆ˜ - 1, ์ฆ‰ ํ•ด๋‹น page์˜ ๋งˆ์ง€๋ง‰ record์˜ index๋ณด๋‹ค ์ž‘์œผ๋ฉด index ๊ฐ’์„ 1 ์ฆ๊ฐ€์‹œํ‚จ๋‹ค.
    • ๊ทธ๋ ‡์ง€ ์•Š๋‹ค๋ฉด, ํ˜„์žฌ buffer๋ฅผ releaseํ•˜๊ณ  right sibling page buffer๋ฅผ requestํ•œ ํ›„ index์„ 0์œผ๋กœ ์ดˆ๊ธฐํ™”ํ•œ๋‹ค. ์ฆ‰ ๋‹ค์Œ page๋กœ ๋„˜์–ด๊ฐ„๋‹ค. right sibling page number๊ฐ€ 0, ์ฆ‰ ํ˜„์žฌ page๊ฐ€ ๋งˆ์ง€๋ง‰ page์ผ ๊ฒฝ์šฐ -1(advance ์‹คํŒจ)์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
    1. 0(์„ฑ๊ณต)์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.


3. ๊ทธ ์™ธ ๋ณ€๊ฒฝ์‚ฌํ•ญ


1. Layer ๊ตฌ์กฐ ๋ณ€๊ฒฝ

  • ๊ณผ์ œ์—์„œ ์š”๊ตฌ๋œ JOIN operation์„ ๊ตฌํ˜„ํ•˜๊ธฐ ์œ„ํ•˜์—ฌ API layer์™€ index manager layer ์‚ฌ์ด์— relational set operator layer๋ฅผ ์ถ”๊ฐ€ํ•˜์˜€๋‹ค.
  • ์ด์— ๋”ฐ๋ผ, API layer์˜ ๊ฐ ํ•จ์ˆ˜๊ฐ€ index manager ์†Œ์† ํ•จ์ˆ˜๊ฐ€ ์•„๋‹Œ relational set operator ์†Œ์† ํ•จ์ˆ˜์˜ wrapper function์œผ๋กœ ์ˆ˜์ •๋˜์—ˆ๋‹ค. ๋˜ํ•œ join_table ํ•จ์ˆ˜๊ฐ€ ์ถ”๊ฐ€๋˜์—ˆ๋‹ค.
  • API layer์˜ join_table ํ•จ์ˆ˜(wrapper function)๊ฐ€ ํ˜ธ์ถœํ•  rso_join_table ํ•จ์ˆ˜๋ฅผ relational set operator layer์— ๊ตฌํ˜„ํ•˜์˜€์œผ๋ฉฐ, ํ•˜์œ„ layer์—์„œ ๊ตฌํ˜„๋œ API๋“ค์˜ wrapper function์„ ํ•ด๋‹น layer์— ์ถ”๊ฐ€ํ•˜์˜€๋‹ค.
  • relational set operator layer์—์„œ buffer๋ฅผ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด buffer_request_page์™€ buffer_release_page ํ•จ์ˆ˜์˜ wrapper function์„ index manager layer์— ์ถ”๊ฐ€ํ•˜์˜€๋‹ค.

2. buffer์—์„œ shutdown_db ๋ฐ close_table ์ˆ˜์ • (debugging)

project3์—์„œ๋Š” ์ œ์ถœ์ผ๊นŒ์ง€ ๋ฏธ์ฒ˜ ๋ฐœ๊ฒฌํ•˜์ง€ ๋ชปํ•œ, ์—ฌ๋Ÿฌ table์„ closeํ•  ๋•Œ ๋น„์ •์ƒ์ ์œผ๋กœ ์ž‘๋™ํ•˜๋Š” ๋ฌธ์ œ๊ฐ€ ์žˆ์—ˆ๋‹ค.
buffer_close_table ํ•จ์ˆ˜์˜ ๋์—์„œ, ํ•ด๋‹น table ๊ตฌ์กฐ์ฒด๋ฅผ buf_tables ๋ฐฐ์—ด์—์„œ ์ œ๊ฑฐํ•  ๋•Œ, ํ•œ ์นธ์”ฉ ๋‹น๊ธฐ๊ธฐ ์œ„ํ•ด

for(i = table_index;  i < table_num - 1; i++) {
    buf_tables[i] = buf_tables[i - 1];
}

์œ„์™€ ๊ฐ™์ด ๊ตฌํ˜„ํ•˜์˜€๋Š”๋ฐ, +๋กœ ์ ์–ด์•ผ ํ•  ๋ถ€๋ถ„์„ -๋กœ ์ ์€ ์˜คํƒ€๊ฐ€ ์žˆ์–ด์„œ ์ •์ƒ์ ์œผ๋กœ ์ˆ˜ํ–‰๋˜์ง€ ์•Š์•˜๋‹ค.

for(i = table_index;  i < table_num - 1; i++) {
    buf_tables[i] = buf_tables[i + 1];
}

์œ„์™€ ๊ฐ™์ด ๊ตฌํ˜„ํ•ด์•ผ ํ–ˆ๋‹ค.
๋˜ํ•œ, buffer_shutdown_db ํ•จ์ˆ˜์—์„œ

for(i = 0; i < table_num; i++) {
    result += buffer_close_table(buf_tables[i].table_id);
}

์œ„์™€ ๊ฐ™์ด ๋ชจ๋“  table์˜ close๋ฅผ ์ˆ˜ํ–‰ํ•˜๋„๋ก ๊ตฌํ˜„ํ–ˆ๋Š”๋ฐ,
buffer_close_table์€ buf_tables ๋ฐฐ์—ด์„ ์•ž์œผ๋กœ ๋ฐ€์ฐฉ์‹œํ‚ค๋ฉฐ ์ˆ˜ํ–‰๋˜๊ธฐ์— buf_tables[i]๊ฐ€ ์•„๋‹Œ buf_tables[0]์„ ์—ฐ์†์ ์œผ๋กœ ์ œ๊ฑฐํ•ด์•ผ ํ•˜๊ณ ,
buffer_close_table์€ table_num์„ ๊ฐ์†Œ์‹œํ‚ค๋ฏ€๋กœ ์ด๋ฅผ ๋ฏธ๋ฆฌ ๋ณต์‚ฌํ•ด๋‘” ํ›„ ํ•ด๋‹น ๊ฐ’์œผ๋กœ ๋ฐ˜๋ณต๋ฌธ์„ ์ˆ˜ํ–‰ํ•˜์—ฌ,

repeat = table_num;
for(i = 0; i < repeat; i++) {
    result += buffer_close_table(buf_tables[0].table_id);
}

์œ„์™€ ๊ฐ™์ด ๊ตฌํ˜„ํ•ด์•ผ ํ–ˆ๋‹ค.
ํ•ด๋‹น ๋ถ€๋ถ„์„ ์ˆ˜์ •ํ•˜์˜€๋‹ค.


3. buffer์—์„œ pin์˜ ๊ธฐ๋Šฅ ์ˆ˜์ •

  • project 3์—์„œ๋Š” buffer block์˜ pin์ด evict ๋ฐฉ์ง€ ์™ธ์—๋„ lock ๊ธฐ๋Šฅ๋„ ์ˆ˜ํ–‰ํ•˜๋Š” ๊ฒƒ์œผ๋กœ ์˜คํ•ดํ•˜์—ฌ, pin์ด ๊ฝ‚ํžŒ page๋ฅผ ์ค‘๋ณต์œผ๋กœ read/writeํ•  ์ˆ˜ ์—†๋„๋ก ๊ตฌํ˜„ํ•˜์˜€๋‹ค.
  • lock์— ๊ด€ํ•ด ์ˆ˜์—…์„ ๋“ค์œผ๋ฉฐ ์˜คํ•ดํ–ˆ์Œ์„ ๊นจ๋‹ฌ์•˜๊ณ , ํ˜„์žฌ ๊ตฌํ˜„์„ ์œ ์ง€ํ•  ๊ฒฝ์šฐ ์ค‘๋ณต read๊ฐ€ ๋ถˆ๊ฐ€๋Šฅํ•ด์„œ ๋™์ผํ•œ table์„ joinํ•  ์ˆ˜ ์—†์Œ์„ ํ™•์ธํ–ˆ๋‹ค. ๋”ฐ๋ผ์„œ lock ๊ธฐ๋Šฅ์„ ์ˆ˜ํ–‰ํ•˜๋„๋ก ๊ตฌํ˜„ํ•œ ๋ถ€๋ถ„์„ ์ œ๊ฑฐํ•˜์˜€๋‹ค.
    • request ์‹œ pin์ด ๊ฝ‚ํ˜€ ์žˆ์œผ๋ฉด ์‹คํŒจ๋ฅผ ๋ฐ˜ํ™˜ํ•˜๊ณ , pin์ด ์—†์œผ๋ฉด in_pinned ๊ฐ’์„ 1๋กœ ๋ณ€๊ฒฝํ•˜๋˜ ๊ฒƒ์„, pinned ์—ฌ๋ถ€ ํ™•์ธ ์—†์ด ํ•ด๋‹น ๊ฐ’์„ 1 ์ฆ๊ฐ€์‹œํ‚ค๋„๋ก ๋ณ€๊ฒฝํ•˜์˜€๋‹ค.
    • release ์‹œ is_pinned ๊ฐ’์„ 0์œผ๋กœ ์„ค์ •ํ•˜๋˜ ๊ฒƒ์„ ํ•ด๋‹น ๊ฐ’์„ 1 ๊ฐ์†Œ์‹œํ‚ค๋„๋ก ๋ณ€๊ฒฝํ•˜์˜€๋‹ค.

4. buffer์— hash table ์ถ”๊ฐ€

  • project3์—์„œ๋Š” buffer manager๊ฐ€ buffer block์„ ๊ฐ table๋ณ„๋กœ linked list๋กœ ์—ฐ๊ฒฐํ•˜์—ฌ ๊ด€๋ฆฌํ•˜๊ณ , buffer๊ฐ€ ํŠน์ • table ํŠน์ • page์˜ request๋ฅผ ๋ฐ›์œผ๋ฉด ํ•ด๋‹น linked list๋ฅผ ์„ ํ˜•์ ์œผ๋กœ ํƒ์ƒ‰ํ•˜์˜€๋‹ค.
  • ์ด๋Ÿฐ ๊ตฌํ˜„์€ buffer block์˜ ์ˆ˜์— ๋น„๋ก€ํ•˜๊ฒŒ ๋งค request๋งˆ๋‹ค ํƒ์ƒ‰ ์‹œ๊ฐ„์„ ์ฆ๊ฐ€์‹œํ‚จ๋‹ค. ์‹ค์ œ๋กœ 10๋งŒ / 100๋งŒ ๊ฐœ์˜ ์ค‘๋ณต ์—†๋Š” random insert / find / delete๋ฅผ ์ˆ˜ํ–‰ํ•˜์˜€์„ ๋•Œ buffer pool์˜ ํฌ๊ธฐ(์ตœ๋Œ€ buffer block ์ˆ˜)๊ฐ€ 400 > 1000 > 4000๊ฐœ์ธ ์ˆœ์„œ๋กœ ์‹คํ–‰ ์†๋„๊ฐ€ ๋น ๋ฆ„์„, ์ฆ‰ buffer pool์ด ํด์ˆ˜๋ก ์†๋„๊ฐ€ ๋Š๋ ค์ง€๋Š” ๋น„์ •์ƒ์ ์ธ ๊ตฌ์กฐ์ž„์„ ์•Œ ์ˆ˜ ์žˆ์—ˆ๋‹ค.
  • ์ด๋ฅผ ๊ฐœ์„ ํ•˜๊ธฐ ์œ„ํ•ด buffer์— hash table์„ ์ถ”๊ฐ€ํ•˜์˜€๋‹ค.
    • hash๋ฅผ ์ ์šฉํ•˜์ง€๋งŒ table๋ณ„๋กœ ๊ฐ€์ง€๋Š” linked list๋Š” ์œ ์ง€ํ•œ๋‹ค. ์ด๋Š” close_table์—์„œ ์‚ฌ์šฉ๋œ๋‹ค. (์ œ๊ฑฐํ•˜๊ธฐ ์œ„ํ•œ ์ˆ˜๋‹จ ๊ณ ๋ ค ์ค‘)
    • collision์„ ํ•ด๊ฒฐํ•˜๊ธฐ ์œ„ํ•ด separate chaining(open hashing)์„ ์‚ฌ์šฉํ•˜์˜€๋‹ค.
    • hash bucket ๊ตฌ์กฐ์ฒด๋ฅผ ๊ตฌํ˜„ํ•˜๊ณ  ์ด์˜ ๋ฐฐ์—ด์ธ ์ „์—ญ ๋ณ€์ˆ˜๋กœ hash table์„ ๊ตฌ์„ฑํ•˜์˜€๋‹ค. (init_db ํ•จ์ˆ˜์—์„œ ์ž…๋ ฅ๋ฐ›์€ buffer pool์˜ ํฌ๊ธฐ์— ๋”ฐ๋ผ ๋™์ ํ• ๋‹นํ•ด์•ผ ํ•˜๋ฏ€๋กœ ์‹ค์ œ๋กœ ๋ฐฐ์—ด๋กœ ์„ ์–ธํ•œ ๊ฒƒ์€ ์•„๋‹ˆ๊ณ  ๊ตฌ์กฐ์ฒด ํฌ์ธํ„ฐ ์ „์—ญ ๋ณ€์ˆ˜๋ฅผ ์„ ์–ธํ•˜์˜€๋‹ค.)
    • disk์—์„œ ์ฝ์€ ํŽ˜์ด์ง€๋ฅผ buffer์— ์˜ฌ๋ฆฌ๋Š” create_buffer_block ํ•จ์ˆ˜์—์„œ ํ•ด๋‹น buffer block์„ hash table์— ์‚ฝ์ž…ํ•˜๊ธฐ ์œ„ํ•ด insert_to_hash_table ํ•จ์ˆ˜๋ฅผ ์„ ์–ธ/์ •์˜ํ•˜์˜€๋‹ค.
    • buffer block์„ evictํ•˜๋Š” evict_buffer_block ํ•จ์ˆ˜์—์„œ ํ•ด๋‹น buffer block์„ hash table์—์„œ๋„ ์ œ๊ฑฐํ•˜๊ธฐ ์œ„ํ•ด delete_from_hash_table ํ•จ์ˆ˜๋ฅผ ์„ ์–ธ/์ •์˜ํ•˜์˜€๋‹ค.
    • ์ƒ์œ„ layer(index manager)์˜ ์š”์ฒญ์— ๋”ฐ๋ผ buffer ์œ„์˜ ํŠน์ • table์˜ ํŠน์ • page๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” buffer_request_page ํ•จ์ˆ˜์—์„œ ํ•ด๋‹น table id์™€ page number์— ํ•ด๋‹นํ•˜๋Š” buffer block์„ hash table์—์„œ ๋น ๋ฅด๊ฒŒ ํƒ์ƒ‰ํ•˜๊ธฐ ์œ„ํ•ด find_from_hash_table ํ•จ์ˆ˜๋ฅผ ์„ ์–ธ/์ •์˜ํ•˜์˜€๋‹ค. (hash table์„ ์ถ”๊ฐ€ํ•œ ๋ชฉ์ )
  • buffer_init_db ํ•จ์ˆ˜์—์„œ buffer pool(buffer_block์˜ ๋ฐฐ์—ด)์„ ๋™์ ํ• ๋‹นํ•œ ์ดํ›„, ๊ฐ™์€ ๊ฐœ์ˆ˜์˜ hash_bucket ๋ฐฐ์—ด์„ ๋™์ ํ• ๋‹นํ•˜์—ฌ hash table์„ ์ƒ์„ฑํ•œ๋‹ค.
  • ๋™์ผํ•˜๊ฒŒ buffer_shutdown_db ํ•จ์ˆ˜์—์„œ buffer pool์„ freeํ•œ ์ดํ›„ hash_table์„ freeํ•œ๋‹ค. separate chaining์œผ๋กœ ์ถ”๊ฐ€ ํ• ๋‹น๋œ ์˜์—ญ์€, buffer_shutdown_db ํ•จ์ˆ˜ ์ดˆ๋ฐ˜์— ๋ชจ๋“  table์„ closeํ•  ๋•Œ, ๊ฐ table์— ์†ํ•˜๋Š” ๋ชจ๋“  buffer block์„ evictํ•˜๋ฉด์„œ ํ•ด์ œ๋˜๊ธฐ ๋•Œ๋ฌธ์— ๊ณ ๋ คํ•˜์ง€ ์•Š์•„๋„ ๋œ๋‹ค.
  • ํ˜„์žฌ ๊ตฌํ˜„์—์„œ ํŠน์ • buffer block์„ ํƒ์ƒ‰ํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š” table id์™€ page number ์ด 2๊ฐœ๊ฐ€ ์‚ฌ์šฉ๋˜๋ฏ€๋กœ, ์ด๋ฅผ 1๊ฐœ์˜ key๋กœ ๋งŒ๋“ค๊ธฐ ์œ„ํ•ด ์ฐจ์„ธํ˜„ ํ•™์ƒ์ด ์ œ์•ˆํ•œ Cantor pairing function์„ ์‚ฌ์šฉํ•˜์˜€๋‹ค. Cantor_pairing_function.png
  • ์ด๋Š” 2๊ฐœ์˜ ์ž…๋ ฅ ๊ฐ’์— ๋”ฐ๋ผ uniqueํ•œ 1๊ฐœ ๊ฐ’์„ ๊ตฌํ•ด์ค€๋‹ค. intํ˜•์˜ table id์™€, uint64_tํ˜•์˜ page number๋กœ ํ•ด๋‹น ์‹์„ ๊ณ„์‚ฐํ•˜๋ฉด, ํ˜„์žฌ uint64_tํ˜•์œผ๋กœ ๋‘” key์—์„œ overflow๊ฐ€ ๋ฐœ์ƒํ•˜๊ณ  ์ค‘๋ณต key๊ฐ€ ์ƒ๊ธธ ์ˆ˜ ์žˆ๋‹ค. ๊ทธ๋Ÿฌ๋‚˜ ์ค‘๋ณต๋œ key๊ฐ€ hash function์„ ๊ฑฐ์ณ hash table์˜ ์ค‘๋ณต index์— ์‚ฝ์ž…๋  ๋•Œ separate chaining์œผ๋กœ collision์€ ํ•ด๊ฒฐ๋˜๋ฉฐ, ์ค‘๋ณต index์—์„œ์˜ ํƒ์ƒ‰์€ ํ•ด๋‹น key๊ฐ€ ์•„๋‹Œ table id์™€ page number๋ฅผ ๊ฐ€์ง€๊ณ  ์ˆ˜ํ–‰ํ•˜๋„๋ก ํ•˜์˜€์œผ๋ฏ€๋กœ ๋ฌธ์ œ๊ฐ€ ๋˜์ง€ ์•Š๋Š”๋‹ค.
  • hash function์„ ๋”ฐ๋กœ ํ•จ์ˆ˜๋กœ ๋งŒ๋“ค์ง€๋Š” ์•Š์•˜์œผ๋ฉฐ ์œ„์˜ 3๊ฐœ hash table ๊ด€๋ จ ํ•จ์ˆ˜์—์„œ ๊ฐ๊ฐ cantor pairing function์œผ๋กœ ๊ตฌํ•œ key๋ฅผ hash size๋กœ modular ์—ฐ์‚ฐ์„ ํ•˜์—ฌ hash ๊ฐ’(ํ•ด๋‹น data๊ฐ€ hash table์— ์ €์žฅ๋  index)์„ ๊ตฌํ•œ๋‹ค.
  • ํ˜„์žฌ ๊ตฌํ˜„์—์„œ๋Š” 64bit ์ปดํ“จํ„ฐ์—์„œ 1๊ฐœ buffer block์ด 4145bytes, 1๊ฐœ hash_bucket์ด 28byte์˜ ํฌ๊ธฐ๋ฅผ ๊ฐ€์ง„๋‹ค. ๋”ฐ๋ผ์„œ n๊ฐœ์˜ buffer block์œผ๋กœ ์ด๋ฃจ์–ด์ง„ buffer pool์ด ์žˆ์„ ๋•Œ ์ด์˜ ํฌ๊ธฐ๋Š” 4145n bytes๊ฐ€ ๋œ๋‹ค.
  • hash table์€ ๋งค์šฐ uniformํ•˜์—ฌ chaining์ด ์—†์„ ๋•Œ 28n bytes, ํ•œ ์œ„์น˜์— ๋ชจ๋“  data๊ฐ€ chaining ๋œ worst case์— 28(2n-1) bytes = (56n-28)bytes์˜ ํฌ๊ธฐ๋ฅผ ๊ฐ€์ง„๋‹ค. ์ด๋Š” buffer pool์˜ ์•ฝ 0.68~1.35% ํฌ๊ธฐ์˜ ๋ฉ”๋ชจ๋ฆฌ ์˜์—ญ์„ ์ถ”๊ฐ€์ ์œผ๋กœ ์‚ฌ์šฉํ•˜๊ฒŒ ๋˜์ง€๋งŒ, ์•„๋ž˜์™€ ๊ฐ™์ด ํƒ์ƒ‰ ์†๋„๋ฅผ ๋น„์•ฝ์ ์œผ๋กœ ํ–ฅ์ƒ์‹œํ‚ค๋ฏ€๋กœ ๊ทธ๋งŒํ•œ ๊ฐ€์น˜๋ฅผ ๊ฐ€์ง„๋‹ค๊ณ  ํŒ๋‹จํ•˜์˜€๋‹ค.
  • ๋‘ ๊ฐ€์ง€ ๋ฐฉ๋ฒ•์˜ ํƒ์ƒ‰ ์†๋„ ์ฐจ์ด๋ฅผ ๋น„๊ตํ•ด๋ณด์•˜๋‹ค. intel i5-6600 CPU(4์ฝ”์–ด)๋ฅผ ๊ฐ€์ง€๋Š” ๋ฐ์Šคํฌํƒ‘ PC์—์„œ VM์— ์„ค์น˜๋œ ubuntu 18.04.3์— CPU 2์ฝ”์–ด, 8GB RAM์„ ์ฃผ๊ณ  ์ˆ˜ํ–‰ํ•˜์˜€๋‹ค. host OS์—์„œ ๋‹ค๋ฅธ ํ”„๋กœ๊ทธ๋žจ์ด ๋™์ž‘ํ•˜๋Š” ๋“ฑ ์™„์ „ํžˆ ํ†ต์ œ๋˜์ง€ ๋ชปํ•œ ํ™˜๊ฒฝ์ด์—ˆ์œผ๋‚˜, ์ˆ˜ํ–‰ ์‹œ๊ฐ„์˜ ์ฐจ์ด๊ฐ€ ์ปค์„œ ์ถฉ๋ถ„ํžˆ ์šฐ์—ด์„ ๊ฐ€๋ฆด ์ˆ˜ ์žˆ์—ˆ๋‹ค. ์ค‘๋ณต๋˜์ง€ ์•Š์€ 10๋งŒ ๊ฐœ record์˜ random order insert / find / delete๋ฅผ testํ•ด๋ณด์•˜๋‹ค. ๊ฐ ์‹œ๊ฐ„์€ ๋ฐ˜๋ณต test๋กœ ๊ตฌํ•œ ์‹œ๊ฐ„๋“ค์˜ ํ‰๊ท ๊ฐ’. (find์™€ delete๋Š” ์ฐพ๊ฑฐ๋‚˜ ์‚ญ์ œํ•˜๋Š” 10๋งŒ ๊ฐœ record๊ฐ€ ๋ชจ๋‘ insert๋œ ์ƒํƒœ์—์„œ ์ˆ˜ํ–‰. insert์™€ delete ํ•จ์ˆ˜๋Š” ์„ฑ๊ณต ์—ฌ๋ถ€์™€ ์„ฑ๊ณตํ•œ count๋ฅผ log๋กœ ์ถœ๋ ฅํ•˜๊ณ , find ํ•จ์ˆ˜๋Š” ์„ฑ๊ณต ์—ฌ๋ถ€์™€ ์„ฑ๊ณตํ•œ count, ์ฐพ์€ key/value๋ฅผ log๋กœ ์ถœ๋ ฅํ•ด๊ฐ€๋ฉฐ testํ•˜์˜€๋‹ค.)
Linear Insert Find Delete
buffer 1๋งŒ 57.0s 56.9s 397.8s
buffer 1์ฒœ 42.3s 6.8s 121.7s
buffer 1๋ฐฑ 47.0s 3.7s 63.9s
buffer 1์‹ญ 50.0s 3.4s 58.3s
Hash Insert Find Delete
buffer 1๋งŒ 6.9s 3.2s 3.9s
buffer 1์ฒœ 24.1s 3.3s 47.1s
buffer 1๋ฐฑ 40.8s 3.3s 53.8s
buffer 1์‹ญ 47.3s 3.7s 56.5s
  • Linear search๋Š” buffer๊ฐ€ ๋Š˜์–ด๋‚ ์ˆ˜๋ก ๋Š๋ ค์ง€์ง€๋งŒ hash๋ฅผ ์‚ฌ์šฉํ–ˆ์„ ๋•Œ๋Š” buffer๊ฐ€ ๋Š˜์–ด๋‚ ์ˆ˜๋ก ๋นจ๋ผ์ง€๋Š” ์ •์ƒ์ ์ธ ์ˆ˜ํ–‰์‹œ๊ฐ„์„ ๋ณด์ด๋ฉฐ, ์ „์ฒด์ ์œผ๋กœ hash์˜ ์ˆ˜ํ–‰์‹œ๊ฐ„์ด ๋น ๋ฆ„์„, ํŠนํžˆ buffer๊ฐ€ ํด์ˆ˜๋ก ์›”๋“ฑํžˆ ๋น ๋ฆ„์„ ๋ณผ ์ˆ˜ ์žˆ๋‹ค.
  • buffer์˜ ์ˆ˜๊ฐ€ ๋งค์šฐ ์ ์„ ๋•Œ๋Š” linear ํƒ์ƒ‰์ด ๋ณ„๋กœ ์˜ค๋ž˜ ๊ฑธ๋ฆฌ์ง€ ์•Š๋Š” ๊ฒƒ์— ๋น„ํ•ด hash table์„ ๊ด€๋ฆฌํ•˜๋Š” ๋ฐ์— ๋“œ๋Š” resource๊ฐ€ ์žˆ์–ด์„œ (์œ„ ํ‘œ์—์„œ buffer 10๊ฐœ์ผ ๋•Œ find ์ˆ˜ํ–‰์‹œ๊ฐ„๊ณผ ๊ฐ™์ด) hash ์‚ฌ์šฉ์ด ๋‹ค์†Œ ๋Š๋ฆฐ ๊ฒฝ์šฐ๋„ ์กด์žฌํ•  ์ˆ˜ ์žˆ์œผ๋‚˜ ๊ทธ ์ฐจ์ด๊ฐ€ buffer๊ฐ€ ํด ๋•Œ linear search๊ฐ€ hash๋ณด๋‹ค ๋Š๋ฆฐ ๊ฒƒ์— ๋น„ํ•ด์„œ๋Š” ํฌ์ง€ ์•Š๊ณ , ์ˆ˜ํ–‰์—๋„ ๋ฌธ์ œ๊ฐ€ ์—†๋‹ค.
  • 100๋งŒ ๊ฐœ record๋ฅผ 10๋งŒ/1์ฒœ ๊ฐœ buffer์—์„œ ์ˆ˜ํ–‰ํ•ด๋ณธ ๊ฒฐ๊ณผ ๋”์šฑ ํฐ ์ฐจ์ด๋ฅผ ํ™•์ธํ•  ์ˆ˜ ์žˆ์—ˆ๋‹ค. ์ˆ˜ํ–‰ ์‹œ๊ฐ„์ด ์˜ค๋ž˜ ๊ฑธ๋ ค์„œ ์—ฌ๋Ÿฌ ๋ฒˆ testํ•˜์—ฌ ํ‰๊ท ๊ฐ’์„ ๋‚ด๋ณด๊ธฐ๊ฐ€ ์–ด๋ ค์›Œ ํ‘œ๋ฅผ ์ฒจ๋ถ€ํ•˜์ง€๋Š” ์•Š์•˜์œผ๋‚˜, data์˜ ์–‘๊ณผ buffer์˜ ํฌ๊ธฐ๊ฐ€ ์ปค์งˆ์ˆ˜๋ก hash ์‚ฌ์šฉ์ด linear search๋ณด๋‹ค ํ›จ์”ฌ ์šฐ์ˆ˜ํ•œ ์„ฑ๋Šฅ์„ ๋ณด์ž„์„ ์•Œ ์ˆ˜ ์žˆ์—ˆ๋‹ค.

5. find ํ•จ์ˆ˜์˜ search ๋ฐฉ์‹ ๋ณ€๊ฒฝ ์‹œ๋„

  • ๊ธฐ์กด index manager์˜ index_find, index_find_leaf ํ•จ์ˆ˜๋Š” ์ฃผ์–ด์ง„ key๋ฅผ ๊ฐ€์ง€๋Š” record๋ฅผ ํƒ์ƒ‰ํ•˜๊ธฐ ์œ„ํ•ด linear search๋ฅผ ์‚ฌ์šฉํ•˜์˜€๋‹ค.
  • ์ฆ‰ ๊ฐ๊ฐ์˜ internal page / leaf page์—์„œ child page / record๋ฅผ ํƒ์ƒ‰ํ•  ๋•Œ ์ œ์ผ ์•ž๋ถ€ํ„ฐ ๋๊นŒ์ง€ key ๊ฐ’์„ ๋น„๊ตํ•ด๋ณด๋ฉฐ ํƒ์ƒ‰ํ•˜์˜€๋‹ค.
  • ์ด๋ฅผ ๊ฐœ์„ ํ•˜๊ธฐ ์œ„ํ•ด binary search์˜ ์ ์šฉ์„ ์‹œ๋„ํ•˜์˜€๋‹ค.
  • ์ œ์ผ ๋งˆ์ง€๋ง‰์— 1๋ฒˆ๋งŒ ์ผ์–ด๋‚˜๋ฉฐ ์ตœ๋Œ€ 31๊ฐœ์˜ key๋ฅผ ๊ฐ€์ง€๋Š” leaf page์—์„œ์˜ ํƒ์ƒ‰๋ณด๋‹ค, ์ตœ๋Œ€ 248๊ฐœ์˜ key๋ฅผ ๊ฐ€์ง€๋Š” internal page์—์„œ์˜ ํƒ์ƒ‰์— ๋จผ์ € ์ ์šฉํ•ด๋ณด๊ธฐ ์œ„ํ•ด index_find_leaf ํ•จ์ˆ˜๋ฅผ ์ˆ˜์ •ํ•˜์—ฌ binary search๋ฅผ ์ ์šฉํ•ด ๋ณด์•˜๋‹ค.
  • ํ•˜์ง€๋งŒ test ๊ฒฐ๊ณผ, ๋‘ ๊ฐ€์ง€ search ๋ฐฉ์‹์„ ์‚ฌ์šฉํ–ˆ์„ ๋•Œ ํ”„๋กœ๊ทธ๋žจ ์ˆ˜ํ–‰ ์‹œ๊ฐ„์—์„œ ์œ ์˜๋ฏธํ•œ ์ฐจ์ด๋ฅผ ๋ณผ ์ˆ˜ ์—†์—ˆ๋‹ค.
  • ๋‹จ์ˆœํ•˜๊ฒŒ ์ƒ๊ฐํ–ˆ์„ ๋•Œ linear search๋Š” O(n), binary search๋Š” O(log n)์˜ ์‹œ๊ฐ„๋ณต์žก๋„๋ฅผ ๊ฐ€์ง€์ง€๋งŒ, ํ˜„์žฌ n์ด ์ตœ๋Œ€ 248๊ฐœ๋กœ ํ•œ์ •๋œ ์ƒํƒœ์—์„œ ์ด์— ๊ณฑํ•ด์ง€๋Š” ์ƒ์ˆ˜์˜ ์ฐจ์ด๊ฐ€ ํฌ๋‹ค๋ฉด ๋‘˜์ด ๋น„์Šทํ•œ ์ˆ˜ํ–‰ ์‹œ๊ฐ„์„ ๊ฐ€์งˆ ์ˆ˜๋„ ์žˆ๊ณ ,
  • ์ „์ฒด ์ˆ˜ํ–‰ ์‹œ๊ฐ„์—์„œ find ํ•จ์ˆ˜์˜ ๋น„์ค‘์ด ์ž‘๋‹ค๋ฉด ํ”„๋กœ๊ทธ๋žจ ์ˆ˜ํ–‰ ์‹œ๊ฐ„์˜ ๋น„๊ต๋กœ ๊ทธ ์ฐจ์ด๋ฅผ ์ฐพ๊ธฐ ์–ด๋ ค์šธ ์ˆ˜๋„ ์žˆ๋‹ค๊ณ  ํŒ๋‹จํ–ˆ๋‹ค.
  • ์ผ๋‹จ์€ linear search๋ฅผ ์œ ์ง€. ์ถ”ํ›„ ๊ณผ์ œ๋ฅผ ์ˆ˜ํ–‰ํ•˜๋ฉด์„œ ๋”์šฑ ๋‹ค์–‘ํ•œ test๋ฅผ ํ•ด๋ณด๊ณ , find ํ•จ์ˆ˜๋‚˜ ํ•ด๋‹น search ์ˆ˜ํ–‰๋ถ€๋ถ„์— ๊ด€ํ•ด์„œ๋งŒ ์ˆ˜ํ–‰ ์‹œ๊ฐ„์„ ์ธก์ •ํ•ด๋ณด๋ฉฐ, ๋ณด๋‹ค ๊ตฌ์ฒด์ ์œผ๋กœ ๋ถ„์„ํ•ด๋ณผ ์˜ˆ์ •.

6. merge์™€ redistribution์˜ ์šฐ์„ ์ˆœ์œ„ ๋ณ€๊ฒฝ ์‹œ๋„

  • ๊ธฐ์กด index manager์—์„œ๋Š”, merge๋ฅผ ์ตœ๋Œ€ํ•œ ์ค„์ด๊ธฐ ์œ„ํ•ด redistribution์„ ์šฐ์„ ์ ์œผ๋กœ ์ˆ˜ํ–‰ํ•˜๊ณ  ์žˆ๋‹ค.
  • redistribution์€ ์˜ฎ๊ธด child page๋“ค์˜ parent page number๋ฅผ ์ˆ˜์ •ํ•ด์ฃผ๊ธฐ ์œ„ํ•ด ๋ชจ๋‘ request/release๋ฅผ ๋ฐ˜๋ณตํ•˜๋ฏ€๋กœ overhead๊ฐ€ ์ปค์„œ merge๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ์ˆ˜ํ–‰ํ•˜๋Š” ๊ฒƒ์ด ๋” ๋น ๋ฅผ ์ˆ˜๋„ ์žˆ๋‹ค๊ณ  ํŒ๋‹จํ•˜์˜€๋‹ค.
  • ์ด์— ๋”ฐ๋ผ, redistribution ์šฐ์„ ๋งŒ์„ ๊ณ ๋ คํ•œ merge ํ•จ์ˆ˜๋ฅผ ์ผ๋ฐ˜์ ์ธ ๊ฒฝ์šฐ์—๋„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋„๋ก ์ˆ˜์ •ํ•œ ํ›„, merge๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ์ˆ˜ํ–‰ํ•˜๋„๋ก ์‹œ๋„ํ•˜์˜€๋‹ค.
  • ํ•˜์ง€๋งŒ test ๊ฒฐ๊ณผ, ์ž‘์€ ๋น„์œจ์ด์ง€๋งŒ ํ‰๊ท ์ ์œผ๋กœ merge๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ์ˆ˜ํ–‰ํ•œ ์ชฝ์ด ์˜คํžˆ๋ ค ๋” ๋Š๋ฆผ์„ ํ™•์ธํ•˜์˜€๋‹ค. ๋˜ํ•œ, redistribution์„ ์šฐ์„ ์ ์œผ๋กœ ์ˆ˜ํ–‰ํ•  ๋•Œ์—, ์ผ๋ฐ˜์ ์ธ ๊ฒฝ์šฐ๋ฅผ ๊ณ ๋ คํ•œ merge ํ•จ์ˆ˜ ์‚ฌ์šฉ๋ณด๋‹ค redistribution ์šฐ์„ ๋งŒ์„ ๊ณ ๋ คํ•œ merge ํ•จ์ˆ˜ ์‚ฌ์šฉ์ด ์กฐ๊ธˆ ๋” ๋น ๋ฆ„๋„ ํ™•์ธํ•˜์˜€๋‹ค.
  • ์ผ๋‹จ์€ ๊ธฐ์กด์˜, redistribution ์šฐ์„  ์ˆ˜ํ–‰๊ณผ ๊ทธ๊ฒƒ๋งŒ์„ ๊ณ ๋ คํ•œ merge ํ•จ์ˆ˜๋ฅผ ์‚ฌ์šฉ. ์ถ”ํ›„ ๊ณผ์ œ๋ฅผ ์ˆ˜ํ–‰ํ•˜๋ฉด์„œ ๋”์šฑ ๋‹ค์–‘ํ•œ test๋ฅผ ํฌํ•จํ•˜์—ฌ ๊ตฌ์ œ์ ์œผ๋กœ ๋ถ„์„ํ•ด๋ณผ ์˜ˆ์ •.

7. index_get_index ํ•จ์ˆ˜๋กœ 3๊ฐœ ํ•จ์ˆ˜ ํ†ตํ•ฉ

  • ๊ธฐ์กด index manager์—๋Š”, index_remove_entry_from_internal ํ•จ์ˆ˜์—์„œ ์‚ฌ์šฉ๋˜๋Š”, ํ˜„์žฌ page buffer ํฌ์ธํ„ฐ์™€ parent page buffer ํฌ์ธํ„ฐ๋ฅผ ์ž…๋ ฅ๋ฐ›์•„ ํ˜„์žฌ page์˜ index๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” index_get_index ํ•จ์ˆ˜๊ฐ€ ์กด์žฌํ•œ๋‹ค.
  • index_insert_into_parent ํ•จ์ˆ˜์—์„œ ์‚ฌ์šฉ๋˜๋˜, parent page buffer ํฌ์ธํ„ฐ์™€ left page์˜ page number๋ฅผ ์ž…๋ ฅ๋ฐ›์•„ left page์˜ index๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” index_get_left_index ํ•จ์ˆ˜๋Š” ์ด์™€ ์‹ค์งˆ์ ์œผ๋กœ ๋™์ผํ•œ ๊ธฐ๋Šฅ์„ ์ˆ˜ํ–‰ํ•˜๊ธฐ์— ์‚ญ์ œํ•˜๊ณ  index_get_index ํ•จ์ˆ˜๋กœ ํ†ตํ•ฉํ•˜์—ฌ ์‚ฌ์šฉํ•˜๋„๋ก ์ˆ˜์ •ํ•˜์˜€๋‹ค. ์ด ๊ณผ์ •์—์„œ, index_get_page ํ•จ์ˆ˜๊ฐ€ ํ˜„์žฌ page buffer ํฌ์ธํ„ฐ๊ฐ€ ์•„๋‹Œ ํ˜„์žฌ page number๋งŒ ์ธ์ž๋กœ ๋ฐ›๊ณ ๋„ ๋™์ž‘ํ•  ์ˆ˜ ์žˆ์Œ์„ ํ™•์ธํ•˜๊ณ  ๊ทธ๋ ‡๊ฒŒ ์ˆ˜์ •ํ•˜์˜€๋‹ค.
  • index_delete_entry ํ•จ์ˆ˜์—์„œ ์‚ฌ์šฉ๋˜๋˜, ํ˜„์žฌ page buffer ํฌ์ธํ„ฐ์™€ parent page buffer ํฌ์ธํ„ฐ๋ฅผ ์ž…๋ ฅ๋ฐ›์•„ ํ˜„์žฌ page์˜ left neighbor page์˜ index๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” index_get_neighbor_index ํ•จ์ˆ˜๋Š” index_get_index ํ•จ์ˆ˜์˜ ๋ฐ˜ํ™˜๊ฐ’์— 1์„ ๋บ€ ๊ฐ’๊ณผ ๋™์ผํ•œ ๋ฐ˜ํ™˜๊ฐ’์„ ๊ฐ€์ง€๋ฏ€๋กœ, ์ด ๋˜ํ•œ ์‚ญ์ œํ•˜๊ณ  index_get_index ํ•จ์ˆ˜๋กœ ํ†ตํ•ฉํ•˜์—ฌ ์‚ฌ์šฉํ•˜๋„๋ก ์ˆ˜์ •ํ•˜์˜€๋‹ค.


4. TODO

1. page ์‚ญ์ œ ์‹œ right sibling page number ์—ฐ๊ฒฐ ๋ฐฉ์‹ ๋ณ€๊ฒฝ

  • ํ˜„์žฌ ํŠน์ • leaf page ์‚ญ์ œ ํ›„ right sibling page number๋ฅผ ์žฌ์—ฐ๊ฒฐํ•ด ์ค„ ๋•Œ, ์‚ญ์ œ๋˜๋Š” page์˜ left page๋ฅผ ์ฐพ๊ธฐ ์œ„ํ•ด table์˜ leftmost leaf page๋ถ€ํ„ฐ ํƒ์ƒ‰ํ•œ๋‹ค.
  • ์ด๋Š” leaf page๊ฐ€ ์ฆ๊ฐ€(record๊ฐ€ ์ฆ๊ฐ€)ํ• ์ˆ˜๋ก ๊ทธ์— ๋น„๋ก€ํ•ด ํƒ์ƒ‰์‹œ๊ฐ„์ด ์ฆ๊ฐ€ํ•˜๋Š” ๋ฌธ์ œ์ ์„ ๊ฐ€์ง€๊ณ  ์žˆ๋‹ค. ๋”ฐ๋ผ์„œ ๊ฐœ์„ ๋ฐฉ์•ˆ์ด ํ•„์š”ํ•˜๋‹ค.

2. LRU list์™€ empty buffer ๊ด€๋ฆฌ ๋ฐฉ๋ฒ• ๋ณ€๊ฒฝ

  • ํ˜„์žฌ ์ƒˆ๋กœ์šด disk page๋ฅผ buffer์— ์˜ฌ๋ฆฌ๊ธฐ ์œ„ํ•ด empty buffer๊ฐ€ ํ•„์š”ํ•  ๋•Œ, buffer pool์„ ์„ ํ˜•์ ์œผ๋กœ ํƒ์ƒ‰ํ•œ๋‹ค. ์ด๋Š” buffer๊ฐ€ ์ปค์งˆ์ˆ˜๋ก, empty page๊ฐ€ ์ ์„์ˆ˜๋ก ํƒ์ƒ‰ ์‹œ๊ฐ„์ด ์ฆ๊ฐ€ํ•˜๋Š” ๋ฌธ์ œ์ ์„ ๊ฐ€์ง„๋‹ค.
  • LRU list์— empty page๋„ ๋„ฃ์–ด์„œ evict๋  ์ชฝ (least recently use๋œ ์ชฝ)์— ๋ชฐ๋ ค์žˆ๋„๋ก ํ•˜๊ฑฐ๋‚˜, ๋”ฐ๋กœ list๋กœ ๊ด€๋ฆฌํ•˜๋Š” ๋“ฑ ๊ฐœ์„ ๋ฐฉ์•ˆ์ด ํ•„์š”ํ•˜๋‹ค.

3. ์—๋Ÿฌ ์ฒดํฌ

  • ํ˜„์žฌ ๊ฐ๊ฐ์˜ ํ•จ์ˆ˜์—์„œ ์—๋Ÿฌ ๋ฐœ์ƒ ์‹œ ๊ทธ์— ๋Œ€ํ•œ ์ ์ ˆํ•œ ์กฐ์น˜ ์—†์ด ๋‹จ์ˆœํžˆ ์Œ์ˆ˜๊ฐ’์„ ๋ฐ˜ํ™˜ํ•˜๋Š” ๋“ฑ ์—๋Ÿฌ ์ฒดํฌ๊ฐ€ ๋ฏธํกํ•œ ์ƒํƒœ์ด๋‹ค.
  • ์ถ”ํ›„ recovery๋ฅผ ์ ์šฉํ•  ๊ฒƒ์„ ๊ณ ๋ คํ•˜๋ฉฐ ํ•จ์ˆ˜๋“ค์˜ ๊ฐ ์œ„์น˜์—์„œ ์—๋Ÿฌ๊ฐ€ ๋ฐœ์ƒํ–ˆ์„ ๋•Œ ํ•ด๋‹น transaction์˜ ์ˆ˜ํ–‰์„ ์ทจ์†Œํ•˜๊ณ  ๊ทธ ์ „ ์ƒํƒœ๋กœ ์˜จ์ „ํžˆ ๋ณต๊ตฌํ•˜๋Š” ๋“ฑ์˜ ์กฐ์น˜๊ฐ€ ํ•„์š”ํ•˜๋‹ค.