МОДИФИКАЦИЯ ДЕРЕВЬЕВ РАЗБОРА ДЛЯ ПАРАЛЛЕЛЬНОГО ИСПОЛНЕНИЯ ЗАПРОСА В СУБД
Основным средством для работы с таблицами, содержащими миллионы строк, является использование какой-либо формы разделения данных и применение алгоритмов для параллельной обработки данных с целью обеспечения приемлемой скорости ответа на пользовательский запрос.
Рассмотрим систему, обеспечивающую работу распределенной СУБД и состоящей из N серверов. Предположим, что пользователь может отправить запрос на языке SQL к любому из N серверов и получить один и тот же ответ от всех серверов (на момент начала исполнения запроса). Такую работу системы можно организовать, к примеру, с использованием одного из методов репликации данных (всей базы, или только части таблиц). В этих условиях возможно создание системы обеспечивающей параллельную обработку SQL запросов, принцип работы которой описан в [1].
Из [2] известно, что схема начальной стадии компиляции запроса состоит из четырех этапов: запрос (текстовое представление) - синтаксический анализатор - препроцессор - генератор логического плана запроса - переписчик логического плана запроса. Дополним эту схему двумя этапами - синтаксический анализатор параллельного запроса и препроцессор параллельного запроса, которые будут предшествовать четырем классическим этапам компиляции. Препроцессор параллельного запроса, в отличие от классической схемы (где он предназначен для замены обозначений деревьями разбора и семантического контроля), в предлагаемой новой схеме модифицирует дерево запроса с целью выделения поддеревьев запроса пригодных для параллельного исполнения. В результате его работы формируется набор новых запросов, обработка которых, в дальнейшем, строится по классической схеме. Преобразования деревьев разбора запроса проводятся препроцессором с использованием заранее известного набора правил, с целью получения эквивалентного запроса. В некоторых случаях после проведения преобразований могут потребоваться дополнительные операции над наборами отношений, возвращаемых запросами.
Под эквивалентностью двух запросов здесь и далее мы будем понимать такие запросы, в результате исполнения которых формируются одинаковые во всех атрибутах кортежей отношения с точностью до порядка следования кортежей, если не задана инструкция сортировки, и с учетом порядка следования в противном случае.
Очевидно, что некоррелированные запросы допускают параллельное исполнение, поэтому все получившиеся подзапросы в дереве разбора запроса могут быть вычислены независимо. Следует заметить, что в общем случае дальнейшее вычисление запроса согласно дереву разбора можно проводить только при получении результатов всех нижестоящих подзапросов и выражений.
Исходя из вышеизложенного замечания, можно сформулировать цели, которые должны достигаться посредством эквивалентных преобразований запросов:
1. Правило преобразования должно из исходного формировать новый запрос, содержащий заранее заданное число некоррелированных подзапросов.
2. Полученные запросы должны обладать приблизительно равной стоимостью исполнения, так как дальнейшее вычисление запроса возможно только после вычисления соответствующих подзапросов, и в случае существенного превышения времени исполнения одного подзапроса над остальными, друге узлы системы (не занятые вычислением подзапроса) могут простаивать. Таким образом, преобразования запроса должно контролировать баланс нагрузки между узлами системы путем соответствующего формирования подзапросов.
3. На верхних уровнях дерева разбора запроса преобразование должно оставлять наиболее «дешевые» операции. Под термином «дешевые» здесь подразумеваются операции, для реализации которых не требуется обработки большого количества записей, так как, к примеру, при их вычислении уже будет невозможно воспользоваться информацией содержащейся в индексах.
4. Преобразование, по возможности, не должно увеличивать объем отношений, получающихся при вычислении подзапросов, для того, чтобы исключить передачу больших объемов данных между узлами системы. Большие объемы таких передач могут серьезно замедлить исполнение запроса и уменьшить выигрыш от параллельного исполнения запроса.
СПИСОК ЛИТЕРАТУРЫ
- М. В. Локшин, О.Я. Кравец. Построение систем для параллельной обработки запросов к СУБД. // Телематика´2004: Труды XI Всероссийской научно-методической конференции (7-10 июня 2004). -СПб:ИТМО. 2004. С. 94-95.
- Гарсиа-Молина Г., Ульман Д., Уидом Д. Системы баз данных. Полный курс. -М. «Вильямс», 2003. - 1088 С.
Статья в формате PDF 132 KB...
24 04 2024 3:15:24
Колючки ежа на самом деле являются измененными волосами...
22 04 2024 22:15:35
Статья в формате PDF 103 KB...
21 04 2024 6:22:36
Статья в формате PDF 105 KB...
20 04 2024 6:18:27
19 04 2024 23:47:40
Статья в формате PDF 129 KB...
18 04 2024 7:38:41
Статья в формате PDF 118 KB...
17 04 2024 15:26:54
16 04 2024 3:22:18
Статья в формате PDF 103 KB...
15 04 2024 22:12:41
Статья в формате PDF 173 KB...
14 04 2024 22:20:10
Статья в формате PDF 110 KB...
13 04 2024 1:59:29
Статья в формате PDF 133 KB...
12 04 2024 7:32:17
Статья в формате PDF 253 KB...
10 04 2024 16:59:40
Изучены видовой состав и экобиоморфы лишайников, проведена комплексная оценка роли экологических факторов в развитии лишайникового покрова карстовых воронок на территории Северо-Западного Кавказа. ...
09 04 2024 0:13:58
Анализ собственных и опубликованных материалов в отечественной и зарубежной литературе приводит к выводу о возможности организма рыб противостоять негативному влиянию экзотоксикантов. Реальной основой сопротивляемости организма является биокатализ. В этих процессах изменение активности ферментов следует рассматривать в качестве первичной реакции биологически активных веществ, направленной на детоксикацию чужеродных соединений. ...
08 04 2024 14:22:50
Статья в формате PDF 181 KB...
07 04 2024 3:38:13
Данная статья посвящена проблеме эвтаназии, которая рассматривается автором в контексте философско-антропологических воззрений таких представителей русской религиозной философии, как Ф.М. Достоевский, В.С. Соловьёв, И.А. Ильин. Согласно их учению, действие, направленное на лишение человека жизни, ведёт к разрушению человеческой природы. Исходя из данной идеи, мы можем рассматривать эвтаназию как действие, ведущее к нарушению человеческой природы врача. ...
06 04 2024 17:56:10
Статья в формате PDF 192 KB...
05 04 2024 7:10:35
04 04 2024 15:24:34
Статья в формате PDF 276 KB...
03 04 2024 14:10:49
Статья в формате PDF 142 KB...
02 04 2024 15:26:51
Статья в формате PDF 110 KB...
01 04 2024 20:54:39
Статья в формате PDF 250 KB...
29 03 2024 23:32:47
Статья в формате PDF 120 KB...
28 03 2024 0:14:58
Статья в формате PDF 124 KB...
27 03 2024 6:44:17
Статья в формате PDF 126 KB...
26 03 2024 12:40:54
Статья в формате PDF 226 KB...
25 03 2024 10:42:12
Статья в формате PDF 111 KB...
24 03 2024 17:20:46
Статья в формате PDF 296 KB...
23 03 2024 3:52:51
Статья в формате PDF 107 KB...
22 03 2024 1:48:13
21 03 2024 6:16:41
Статья в формате PDF 132 KB...
20 03 2024 11:43:11
Статья в формате PDF 104 KB...
18 03 2024 0:50:41
Уникальные возможности линейных рекуррентных уравнений первого порядка А(n+1) = aA(n) + b позволяют хаpaктеризовать закономерности изменения различных свойств органических соединений (А) не только в пределах локальных групп гомологов, но и одновременно всех рядов с одинаковыми гомологическими разностями. Более того, рекуррентные соотношения применимы к функциям не только целочисленных (число атомов углерода в молекуле), но и равноотстоящих значений аргументов A(x+Δx) = aA(x) + b, (Δx = const). Этот способ аппроксимации проиллюстрирован на примерах температурных зависимостей растворимости различных веществ в воде и даже времен релаксации в высокочастотных полях. ...
17 03 2024 3:13:43
Статья в формате PDF 129 KB...
16 03 2024 21:22:37
Еще:
Поддержать себя -1 :: Поддержать себя -2 :: Поддержать себя -3 :: Поддержать себя -4 :: Поддержать себя -5 :: Поддержать себя -6 :: Поддержать себя -7 :: Поддержать себя -8 :: Поддержать себя -9 :: Поддержать себя -10 :: Поддержать себя -11 :: Поддержать себя -12 :: Поддержать себя -13 :: Поддержать себя -14 :: Поддержать себя -15 :: Поддержать себя -16 :: Поддержать себя -17 :: Поддержать себя -18 :: Поддержать себя -19 :: Поддержать себя -20 :: Поддержать себя -21 :: Поддержать себя -22 :: Поддержать себя -23 :: Поддержать себя -24 :: Поддержать себя -25 :: Поддержать себя -26 :: Поддержать себя -27 :: Поддержать себя -28 :: Поддержать себя -29 :: Поддержать себя -30 :: Поддержать себя -31 :: Поддержать себя -32 :: Поддержать себя -33 :: Поддержать себя -34 :: Поддержать себя -35 :: Поддержать себя -36 :: Поддержать себя -37 :: Поддержать себя -38 ::