4 февраля вышла новая версия популярной СУБД PostgreSQL 8.3. Разработчики особо отметили, что, благодаря значительному росту сообщества Postgres, стало возможным значительное расширение функциональных возможностей и улучшение производительности.
Анонсировано добавление следующих функций:
-
TSearch2, передовое средство полнотекстового поиска, было полностью интегрировано в код ядра СУБД, кроме того, был упрощён API для работы с ним. Все это позволит сделать TSearch2 более простым в использовании и более расширяемым для новых языков и словарей;
-
поддержка стандарта SQL/XML, включая новые функции и тип данных XML. Полностью поддерживаются SQL/XML спецификации ANSI SQL:2003. Кроме того, поддерживаются дополнительные функции для экспорта XML-данных;
-
добавлен перечисляемый тип данных (ENUM). PostgreSQL теперь поддерживает ENUM-столбцы с определенным упорядоченным списком альтернатив. Разработчики надеются, что данная возможность упростит миграцию с MySQL;
-
массивы теперь могут быть созданы из объединения разных типов;
-
добавлен новый тип данных - универсальный уникальный идентификатор (UUID). Новый 128-битный тип совместим с большинством основных GUID и UUID генераторов;
-
обновляемые курсоры;
-
возможность переопределения параметров конфигурации сервера (переменных окружения) для определенных функций;
-
автоматическая перепланировка очередей кэша при переопределении таблиц;
-
большое число улучшений в протоколировании событий и сборе статистики;
-
поддержка интерфейса SSPI (Security Service Provider Interface) для авторизации в Windows;
-
поддержка нескольких одновременных процессов autovacuum и иные улучшения autovacuum;
-
дистрибутив полностью может быть скомпилирован MS Visual C++.
Улучшения производительности:
-
запись контрольной точки (checkpoint) может быть распределена в течение более долгого периода для предотвращения пиковых нагрузок на систему ввода/вывода;
-
Heap-Only Tuples (HOT) ускоряет большинства операций UPDATE и DELETE. Многие эксперты называют HOT главнейшим изменением в 8.3. HOT позволяет резко снизить число проблем с базами, в которых данные часто обновляются, уменьшая потребность в vacuum и существенно повышая производительность на некоторых задачах;
-
«интеллектуальная» фоновая запись повышает эффективность работы с диском. Автонастройка bgwriter оценивает сколько буферов должно быть выделено на основе статистики о текущей активности;
-
«ленивое» выделение XID. Позволяет СУБД не выделять идентификатор транзакции на операциях, связанных только с чтением данных, что значительно снижает общую нагрузку и потребность запуске vacuum;
-
Top-N Sorting. Значительно ускоряется нахождение результата при использовании LIMIT;
- и множество других улучшений.
|