Ssylka

Может ли перенос планировщика Orca в расширение Postgres упростить обновления базы данных?

Переход от интеграции Orca непосредственно в ядро Greengage Database к использованию его как расширения Postgres, направлен на уменьшение внутренней зависимости. Первым шагом стало создание отдельного расширения Orca, подключенного через хук планировщика, что позволило отделить его код от ядра. Для этого потребовалось решение проблем с инициализацией и деинициализацией Orca, которые теперь выполняются отложено, из хука планировщика.
Может ли перенос планировщика Orca в расширение Postgres упростить обновления базы данных?
Изображение носит иллюстративный характер

После отделения Orca от ядра, была проведена работа по исключению зависимостей от компонентов memory protection и explain. Компонент memory protection был переработан с введением новой функции для отслеживания памяти, выделяемой расширениями. Компонент explain был переработан с использованием хука для вывода планов запросов в DXL-формате и добавлена возможность отображения имени используемого планировщика.

Из ядра были также вынесены специальные функции, такие как enable_xform и gp_opt_version, и перенесены в расширение. Параметр GUC optimizer, отвечавший за включение или выключение Orca, был переопределён для управления общим внешним планировщиком. Также была устранена зависимость от расширения pg_hint_plan.

После рефакторинга все исходные файлы Orca, его утилиты и настройки были перемещены в расширение, что обеспечивает динамическое включение и отключение Orca. Это изменение должно упростить будущие обновления PostgreSQL, сделать систему более модульной и гибкой и предоставить возможность использования сторонних планировщиков. При использовании нескольких планировщиков необходимо обеспечить корректный порядок загрузки расширений.


Новое на сайте

18884Знаете ли вы, что приматы появились до вымирания динозавров, и готовы ли проверить свои... 18883Четыреста колец в туманности эмбрион раскрыли тридцатилетнюю тайну звездной эволюции 18882Телескоп Джеймс Уэбб раскрыл тайны сверхэффективной звездной фабрики стрелец B2 18881Математический анализ истинного количества сквозных отверстий в человеческом теле 18880Почему даже элитные суперраспознаватели проваливают тесты на выявление дипфейков без... 18879Шесть легендарных древних городов и столиц империй, местоположение которых до сих пор... 18878Обзор самых необычных медицинских диагнозов и клинических случаев 2025 года 18877Критическая уязвимость CVE-2025-14847 в MongoDB открывает удаленный доступ к памяти... 18876Научное обоснование классификации солнца как желтого карлика класса G2V 18875Как безграничная преданность горным гориллам привела Дайан Фосси к жестокой гибели? 18874Новый родственник спинозавра из Таиланда меняет представления об эволюции хищников Азии 18873Как новая электрохимическая технология позволяет удвоить добычу водорода и снизить... 18872Могут ли ледяные гиганты Уран и Нептун на самом деле оказаться каменными? 18871Внедрение вредоносного кода в расширение Trust Wallet привело к хищению 7 миллионов... 18870Проверка клинического мышления на основе редких медицинских случаев 2025 года