Научная статья на тему 'Оценка времени выполнения запроса в параллельной системе баз данных'

Оценка времени выполнения запроса в параллельной системе баз данных Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
335
41
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ПАРАЛЛЕЛЬНЫЕ БАЗЫ ДАННЫХ / ПРЕОБРАЗОВАНИЕ ЛАПЛАСА-СТИЛТЬЕСА / МАТЕМАТИЧЕСКОЕ ОЖИДАНИЕ ВРЕМЕНИ ВЫПОЛНЕНИЯ ЗАПРОСА

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Плужников В. Л.

В статье проводится анализ существующих архитектур параллельных баз данных. Приводится описание методов выполнения запросов в параллельной СУБД. Получено преобразование Лапласа-Стилтьеса времени выполнения запроса в параллельной СУБД. На основе свойств преобразования Лапласа-Стилтьеса выведены выражения для определения математического ожидания времени выполнения запроса для различных архитектур параллельных систем баз данных. Показан практический пример расчета времени выполнения запроса для архитектур SE, SD и SN и проведен анализ зависимости времени выполнения запроса в параллельной СУБД от количества процессоров в заданой архитектуре.

i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Текст научной работы на тему «Оценка времени выполнения запроса в параллельной системе баз данных»

электронное научно-техническое издание

НАУКА и ОБРАЗОВАНИЕ

Эя №ФС 77 - 30569. Государственная регистрация №0421100025.ISSN 1994-04PS_

Оценка времени выполнения запроса в параллельной системе баз данных

# 06, июнь 2011 автор: Плужников В. Л.

УДК 004.657

МТГУ им. Н. Э. Баумана vpluzhnikov@gmail. com

Введение

На сегодняшний день параллельные системы баз данных часто применяются для обработки больших объемов данных. Параллельная обработка разделяет большие задачи для обработки на множество маленьких задач, которые можно выполнять параллельно на нескольких узлах. Результатом такого разбиения, как правило, является уменьшение времени выполнения первичной, большой задачи. Реляционные запросы как нельзя лучше подходят для параллельного выполнения. Они состоят из однородных операций над однородным потоком данных. Каждая операция образует новое отношение (таблицу), так что из операций могут быть составлены высокопараллельные графы потоков данных.

В настоящее время не существует научно обоснованного метода оценки и выбора архитектуры параллельной системы баз данных. Сравнительный анализ архитектурных решений выполняется или на основе экспертных оценок качественных критериев, или на основе результатов тестов для конкретных платформ [1,3,7].

В статье предлагается математический метод оценки и выбора архитектуры параллельных систем баз данных, учитывающий особенности выполнения запросов к базе данных проектируемой системы, а также топологию (структуру) различных архитектурных решений.

Особенности выполнения запроса в параллельной СУБД

Рассмотрим процесс выполнения SQL запросов в параллельной системе управления базами данных [1].

Рис. 1. Обработка запроса в параллельной СУБД.

Общая схема обработки запроса в параллельной СУБД изображена на рис. 1. SQL запрос, в соответствии со схемой выполняется в несколько этапов [2]:

Этап 1. Генерация последовательного плана выполнения SQL запроса.

Этап 2. Тиражирование плана выполнения запроса на все процессоры

системы.

Этап 3. Обработка запроса над фрагментированными таблицами

Этап 4. Слияние полученных данных.

Для организации межпроцессорных обменов в соответствующие места дерева плана запроса СУБД вставляет специальный оператор exchange. Оператор exchange реализуется на основе использования стандартного скобочного шаблона. Оператор exchange имеет два специальных параметра, определяемых пользователем: номер порта обмена и указатель на функцию распределения. Функция распределения для каждого кортежа вычисляет логический номер процессорного узла, на котором данный кортеж должен быть обработан. Параметр "порт обмена" позволяет включать в дерево запроса произвольное количество операторов exchange (для каждого оператора указывается свой уникальный порт обмена).

Рис. 2. Структура оператора exchange.

Структура оператора обмена exchange изображена на рис. 2.

Оператор exchange является составным оператором и включает в себя четыре оператора: gather, scatter, split и merge. Оператор split - это бинарный оператор, который осуществляет разбиение кортежей, поступающих из входного потока, на две группы: свои и чужие. Свои кортежи - это кортежи, которые должны быть обработаны на данном процессорном узле. Эти кортежи направляются в выходной буфер оператора split. Чужие кортежи, то есть кортежи, которые должны быть обработаны на процессорных узлах, отличных от данного, помещаются оператором split в выходной буфер правого дочернего узла, в качестве которого фигурирует оператор scatter. Нульарный оператор scatter извлекает кортежи из своего выходного буфера и пересылает их на соответствующие процессорные узлы. Нульарный оператор gather выполняет перманентное чтение кортежей из указанного порта со всех процессорных узлов, отличных от данного. Оператор merge определяется как бинарный оператор, который забирает кортежи из выходных буферов своих дочерних узлов и помещает их в собственный выходной буфер. На базе данных операций оператор exchange реализует полноценный межпроцессорный обмен записями в параллельной СУБД при обработке запроса методом фрагментарного параллелизма.

Оценка времени выполнения запроса в параллельной системе баз

данных

Наиболее распространенной системой классификации параллельных систем баз данных является система, предложенная Майклом Стоунбрейкером (Michael Stonebraker) [2,3], показанная на рис. 3. Здесь P обозначает процессор, M - модуль оперативной памяти, D - дисковое устройство, N - соединительную сеть. Эта классификация неполная, имеются и другие конфигурации. В частности архитектура SN может быть реализована на основе персональных компьютеров.

M

M

т

M

1

D D

M

г

а) SE

DD

а) SD

Рис. 3. Классификация Стоунбрейкера.

а) SN

Используя подход, предложенный в [4], можно вывести следующее преобразование Лапласа-Стилтьеса (ПЛС) времени выполнения запроса к базе данных с планом ла(об^)):

ф(8) = в(ф"Ь (8)ф2м(8)(\ - Рр (1 - фн (8)))фр (*)) , (1)

где

О = ^/ п - производящая функция числа записей фрагментной таблицы Я., обрабатываемых на одном процессоре, V - общее число записей в таблице Я, п - число процессоров (или персональных компьютеров в кластере),

ф (8) - ПЛС времени чтения блока БД фрагментированной таблицы с диска (с

учетом очереди к дисковому массиву), Ь - число записей таблицы в блоке БД,

Фм (8) - ПЛС времени чтения/сохранения записи фрагментированной таблицы в оперативной памяти (с учетом очереди к шине памяти),

ф^ (8) - ПЛС времени межпроцессорного обмена при передаче результирующей записи по сети N.

фр (8) - ПЛС времени обработки записи в процессоре, который является

неразделяемым ресурсом; будем предполагать, что это время распределено по экспоненциальному закону,

Рб - вероятность, что запись удовлетворяет условию поиска F (эта вероятность рассчитывается по известным формулам [4]) .

Будем считать, что каждое из преобразований Лапласа-Стилтьеса ф^ (8), фм (8) , ф^ (8) соответствует времени пребывания в СМО М/М/1.

Действительно, обработку в ресурсе (дисковом массиве, оперативной памяти, сети) можно описать с помощью модели ремонтника [6], где в качестве приборов выступают процессоры, а в качестве ремонтника - ресурс (шина). При достаточно большом числе процессоров эту модель можно аппроксимировать разомкнутой СМО М/ 0/1 при загрузке ремонтника р < 1.

Обработка записи базы данных в ресурсе разбита на кванты. Для дискового массива - это поиск в кэше файловой системы, обработка запроса адаптером шины сервера, поиск в кэше контроллера дискового массива, поиск в кэше диска, подвод головки к цилиндру, ожидание требуемого сектора, чтение сектора в кэш диска, запись сектора в кэш контроллера дискового массива, запись сектора в кэш файловой системы. Для шины оперативной памяти - это чтение/запись большого количества операндов и

команд, выполняемых в процессоре при обработке записи базы данных. Для шины N - это передача большого числа сообщений протокольной машины.

Известно [5], что СМО М/О/1 с дисциплиной квантования приближается по характеристикам к СМО М/М/1 при малом значении интервала квантования (по крайней мере, это справедливо для распределения числа заявок в СМО и среднего времени пребывания).

Время пребывания в СМО МУМУ1 распределено по экспоненциальному закону. Для Фв (, Фм , Фм (, Фр (б) имеем:

Фв (*) = - ПХ° ^ Т^Г^ = Ф™ & * Фвс &' (2)

/лв (¡в - пЯв + Ьэ) (¡в + Ьэ)

Фм (б) = и - пЯм )(Р-м + *) . ^^ = ФмШ (б) . Фмс (,) , (3)

им (Мм - пЯм + (им +

Ф^^^МЦ .^Ц^М^М, (4)

(им - пЯм + б) (им + б)

Фр (б) = . (5)

¡ир + б

Здесь

п - число процессоров,

Ф-с (б) , Фш (б) - это соответственно ПЛС времени обработки записи и ожидания обработки её в ресурсе.

Обозначения для ¡и и Я введены раньше (см. предыдущий раздел). При этом должно выполняться неравенство

пЯ ,

Р = — < 1. (6)

и

ПЛС времени выполнения запроса к базе данных (см. (1)) для различных конфигураций (см. рис. 3) отличаются присутствием или отсутствием в них ПЛС ФВщг (б) ,

Фмш (б) ,Фш (б) (табл. 1). Всё зависит от того, разделяемый ли в конфигурации ресурс (т.е. возможна к нему очередь) или нет. Если преобразование Лапласа-Стилтьеса отсутствует, то в формулах (2)-(4) оно заменяется единицей (в табл. 2 это отмечено символом '-').

Таблица 1

Наличие (+) или отсутствие (-) ПЛС рDW(S), рмщ@), в формуле (1) для различных

конфигураций

( DW(S) рMW(S) ркщ^)

БЕ + + р N(S) следует заменить на р м^), т.к. нет сети

ББ + - +

SN - - +

Из (1) можно получить математическое ожидание и дисперсию времени выполнения запроса к БД:

м^=-ф (0), (7)

м^2 =ф(2)(0), (8)

о* = м 2 - мI. (9)

Получим теперь выражение для математического ожидания времени выполнения запроса к БД для конфигураций БЕ, ББ и Предположим, что "узким местом" в архитектурах БЕ и ББ является диск (см. табл. 1).

Дифференцируя (1) как сложную функцию в нуле, получим для конфигураций БЕ, ББ и SN соответственно:

V ( 1 + ПР.+1

п иб Им Ир

м$Е = -ф (0) ^ (-- +-^ + —), (10)

V , 1 2 1 Рр — (-+-+ — + —

п Ив— Им Ир Иы

= -ф (0) = ^ (-+ — + — + р^), (11)

V, 12 1 РР — (-+-+-+-^

п Ив Им ИР Иы — пЛы

м$;М =-ф (0) = V (— + — + — + Р „ ), (12)

2

С помощью формул (8) и (9) можно получить выражения для м^2 и ст^т .

Пример расчета времени выполнения запроса в параллельной СУБД

Расчёт математического ожидания (среднего) времени выполнения запроса к таблице в ПСБД был выполнен при следующих значениях характеристик ресурсов.

1. Процессор - IntelXeonE5310. СУБД - Oraclellg. При расчете примера была выполнена автотрассировка запроса: число обработанных записей в таблице - 50000, число процессорных циклов - 3.9-108. Для выбранного процессора в системе приведено значение числа процессорных циклов, выполняемых Oracle в секунду (CPUSPEEDNW) -2.6-109. Поэтому для интенсивности обработки записей в процессоре имеем -цр = 5.3-104/(3.9-108/2.6-109) = 3,5-105.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

2. Внешняя память - RAID10 c Кд=10 дисками 3.5'' SeagateCheetah 15K.6 ST3146356FC; размер блока чередования (stripesize) - QB4=256 Кб; среднее время поиска и чтения блока чередования с диска - tB4 = ^одвода + ^ращения/2 + QWv^re^ = 4 + 4/2 + 256/200 = 7 мс.

Размер блока СУБД - Qbc=16K6; средняя длина записи таблиц А и В - 1З=0.256Кб, размер многоблочного чтения СУБД (переменная СУБД db_fi1e_mu1tib1ock_read_count) -qMB=80. Поэтому для интенсивности чтения записей БД из массива RAID имеем -/uD = Ямб -Qbc/1s/( Гямб -Qbc ^бч/(Кд/2)]4бч)= 0.7-106. Число 2 в этой формуле учитывает

тот факт, что при чтении полосы RAID-массива (т.е. при одновременном чтении блоков чередования с разных дисков) используется половина дисков массива, так как в RAID10 каждый диск из этой половины имеет зеркальную копию.

3. Оперативная память - DDR2-667DPC2- 5300. Расчёты показывают, что интенсивность чтения записей базы данных из ОП равна цм = 5.2-106.

4. Высокоскоростная системная шина: для SD - Para11e1Sysp1exInfiniband12xQDR [8], для SN - ByNet. В обоих случаях узлы соединены по схеме "точка-точка" (т.е. шина является неразделяемым ресурсом) [9] и интенсивность передачи записей по этим шинам равна juN = 50.3-106.

Далее приведены значения остальных параметров: число записей в таблице V=106, вероятность фильтрации записей таблицы?р=0,05.

При расчётах использовались формулы (10)-(12). Для архитектур SE и SD "узким местом" является внешняя память (диск). При вычислениях величину ' nAD' необходимо

разделить на 2, так как при обработке запросов на чтение от разных процессоров может быть использована не только основная, но и зеркальная половина дисков. Для архитектуры SN произведение ' пЛн' необходимо исключить из формулы расчёта математического ожидания (т.е. обнулить ' пЛк' в колонке 6 табл. 3 для строки SN), так как в рассматриваемом примере шина является неразделяемым ресурсом. Графики зависимости математического ожидания времени выполнения соединения двух таблиц от числа процессоров 'п' в параллельной системе баз данных приведены на рис. 4 и 5.

-I-1-1-1-1-1-1-1-1-1-

1 1.2 1.4 1.6 1.8 2 2.2 2.4 2.6 2.8

- ЗВ

---- ЭБ

Рис. 4. Зависимость математического ожидания времени выполнения запроса к таблицам

архитектурах SE, SD от числа процессоров.

Рис. 5. Зависимость математического ожидания времени выполнения запроса к таблицам архитектурах БК от числа процессоров.

Анализ графиков позволяет сделать несколько выводов:

1. Графики для архитектур БЕ и ББ практически совпали. Это объясняется высокими значениями интенсивностей /лм и .

2. При п=2 среднее время выполнения запроса в архитектуре БК в три раза меньше чем для архитектур БЕ и ББ.

4. Для БЕ и ББ при п>2 перегружается дисковая подсистема, и дальнейший рост числа процессоров не имеет смысла. Для архитектуры БК время продолжает уменьшаться с ростом п (здесь нет разделяемых ресурсов). Однако следует иметь в виду, что для снижения времени выполнения запроса с 2 секунд до 1 необходимо увеличить количество процессов с 2 до 4 (см. рис. 4 и рис. 5), а это может оказаться экономически не целесообразным.

Заключение

1. Получены преобразования Лапласа-Стилтьеса (ПЛС) случайного времени выполнения запроса к таблице в параллельной системе баз данных для различных архитектур (SE, SD, SN). Эти преобразования позволяют оценивать не только математические ожидания случайного времени, но моменты более высоких порядков (например, дисперсии).

2. Получены выражения для математических ожиданий времени выполнения запроса для указанных выше вариантов. Рассмотрен практический пример расчета, позволивший сделать ряд нетривиальных выводов.

3. В дальнейшем предполагается использовать аппарат ПЛС для оценки времени выполнения соединения таблиц и аналитических запросов к хранилищу данных, реализованному на основе параллельной системы баз данных и использующему специальные планы соединения таблиц измерений и фактов.

ЛИТЕРАТУРА

1. Соколинский Л. Б., Цымблер М. Л. Лекции по курсу "Параллельные системы баз данных" // pdbs.susu.ru: Практикум по программированию параллельных систем баз данных. Электронный учебный курс. URL. http://pdbs.susu.ru/CourseManual.html (дата обращения: 10.04.2009).

2. Соколинский Л.Б. Обзор архитектур параллельных систем баз данных // Программирование. 2004. № 6. С. 49-63.

3. David Dewitt, Jim Gray. Parallel database systems: the future of high performance database systems // Communications of the ACM. June 1992. Vol. 35, № 6. P.1-26.

4. Григорьев Ю.А., Плутенко А.Д. Теоретические основы анализа процессов доступа к распределённым базам данных. Новосибирск: Наука, 2002. 180 с.

5. Яшков С.Ф. Анализ очередей в ЭВМ. М.: Радио и связь, 1989. 216 с.

6. Авен О.И., Гурин Н.Н., Коган Я.А. Оценка качества и оптимизация вычислительных систем. М.: Наука, 1982. 464 с.

7. TPC-C // www.tpc.org: Transaction Processing Performance Council (TPC). URL. http://www.tpc.org/tpcc/default.asp (дата обращения: 10.04.2009).

8. InfiniBand™ Frequently Asked Questions // www.mellanox.com: Mellanox Technologies. URL. www.mellanox.com/pdf/whitepapers/InfiniBandFAQ_FQ_100.pdf (дата обращения: 26.11.2010).

9. Левин Л. Teradata совершенствует хранилища данных // www.pcweek.ru: PC Week. URL. http://www.pcweek.ru/themes/detail.php?ID=71626 (дата обращения: 26.11.2010)

i Надоели баннеры? Вы всегда можете отключить рекламу.