WikiDer > База данных Oracle NoSQL
Эта статья поднимает множество проблем. Пожалуйста помоги Улучши это или обсудите эти вопросы на страница обсуждения. (Узнайте, как и когда удалить эти сообщения-шаблоны) (Узнайте, как и когда удалить этот шаблон сообщения)
|
Разработчики) | Корпорация Oracle |
---|---|
изначальный выпуск | Сентябрь 2011 г. |
Стабильный выпуск | 19.5 / 19 ноября 2019 |
Написано в | Ява |
Доступно в | английский |
Тип | NoSQL |
Лицензия | Лицензия Apache v2 (CE) и проприетарный (EE) |
Интернет сайт | оракул |
База данных Oracle NoSQL (ONDB) - это NoSQL-тип распределен база данных ключ-значение из Корпорация Oracle.[1][2][3][4] Он обеспечивает транзакционную семантику для манипулирования данными, горизонтальную масштабируемость, а также простое администрирование и мониторинг.
Oracle выпустила Oracle Autonomous NoSQL Database Cloud (OANDC) 10 августа 2018 г. OANDC - это управляемая облачная служба для приложений, которым требуются низкие задержки, гибкие модели данных и эластичное масштабирование для динамических рабочих нагрузок.
Разработчики сосредотачиваются на разработке приложений и требованиях к хранилищу данных, а не на управлении внутренними серверами, расширением хранилища, развертыванием кластеров, топологией, установкой / исправлениями / обновлениями программного обеспечения, резервным копированием, операционными системами и доступностью. OANDC масштабируется в соответствии с динамическими рабочими нагрузками приложений и требованиями к пропускной способности.
Пользователи создают таблицы для хранения данных своего приложения и выполнения операций с базой данных. Таблица OANDC похожа на реляционную таблицу с дополнительными свойствами, включая предоставленные единицы записи, единицы чтения и емкость хранения. Пользователи выделяют пропускную способность и емкость хранилища в каждой таблице в соответствии с ожидаемыми рабочими нагрузками. Ресурсы OANDC распределяются и масштабируются в соответствии с требованиями рабочей нагрузки. Счета для пользователей выставляются ежечасно в зависимости от предоставленной мощности.
OANDC поддерживает табличную модель. Каждая строка идентифицируется уникальным ключом и имеет значение произвольной длины, которое интерпретируется приложением. Приложение может манипулировать (вставлять, удалять, обновлять, читать) одной строкой в транзакции. Приложение также может выполнять итеративное нетранзакционное сканирование всех строк в базе данных.
Лицензирование
Корпорация Oracle распространяет базу данных Oracle NoSQL в трех редакциях:
- Версия сообщества Oracle NoSQL Database Server под Лицензия Apache, версия 2.0
- Oracle NoSQL Enterprise Edition по коммерческой лицензии Oracle
- Oracle NoSQL Basic Edition
Oracle NoSQL Database лицензируется с использованием freemium модель: Открытый исходный код доступны версии Oracle NoSQL Community Edition, но конечные пользователи могут приобрести дополнительные функции и поддержку через Oracle Store.[5] При интеграции с другими продуктами Oracle, такими как Oracle Enterprise Manager или Oracle Coherence, то необходимо приобрести Oracle NoSQL Enterprise Edition.
Базовая версия Oracle NoSQL Database,[6] доступен, когда клиент приобретает или приобрел лицензию Oracle Database Enterprise Edition (DBEE) версии 11g или 12c, которую он имеет право загрузить и использовать Oracle NoSQL Database Basic Edition. Поддержка Oracle NoSQL Database Basic Edition будет включена как часть DBEE договор поддержки, если поддержка была куплена.
Драйверы Oracle NoSQL Database,[7] лицензировано в соответствии с Лицензия Apache 2.0, используются как в редакции сообщества, так и в редакции предприятия.[8]
Основные особенности
Архитектура
База данных Oracle NoSQL построена на базе Oracle Berkeley DB Версия Java высокая доступность двигатель хранения. Он добавляет службы для обеспечения распределенного высокодоступного хранилища ключей / значений, подходящего для приложений большого объема, чувствительных к задержкам.[9]
Шардинг и репликация
База данных Oracle NoSQL - это клиент-сервер, сегментированный, ничего не поделено система. Данные в каждом сегменте реплицируются на каждом из узлов, составляющих сегмент. Он предоставляет разработчику приложения простую парадигму «ключ-значение». Главный ключ записи хешируется, чтобы идентифицировать сегмент, которому принадлежит запись. База данных Oracle NoSQL предназначена для поддержки динамического изменения количества сегментов в зависимости от доступности дополнительного оборудования. Если количество шардов изменяется, пары ключ-значение перераспределяются по новому набору шардов динамически, без необходимости выключения и перезапуска системы. Шард состоит из одного выбираемого главного узла для обслуживания запросов на чтение и запись и нескольких реплик (обычно двух или более), которые могут обслуживать запросы на чтение. Реплики обновляются с помощью потоковой репликации. Каждое изменение на главном узле фиксируется локально на диске, а также распространяется на реплики.
Высокая доступность и отказоустойчивость
База данных Oracle NoSQL предоставляет один мастер, несколько реплик репликация базы данных.[10] Транзакционные данные доставляются на все реплики узлов с гибкими политиками надежности для каждой транзакции. В случае сбоя главного узла реплики консенсусное PAXOSавтоматизированный процесс выбора переключения при отказе сводит к минимуму время простоя. Как только отказавший узел восстанавливается, он снова присоединяется к шарду, обновляется и затем становится доступным для обработки запросов на чтение. Таким образом, приложения Oracle NoSQL Database могут выдерживать сбои узлов в сегменте, а также множественные сбои узлов в отдельных сегментах.
Правильное размещение мастеров и реплик на серверном оборудовании (стойках и межкомпонентных коммутаторах) с помощью Oracle NoSQL Database предназначено для увеличения доступности на обычных серверах.
Прозрачная балансировка нагрузки
Драйвер базы данных Oracle NoSQL[11] разделяет данные в реальном времени и равномерно распределяет их по узлам хранения. Он учитывает топологию сети и задержки и направляет операции чтения и записи на наиболее подходящий узел хранения для оптимизации распределения нагрузки и производительности.
Администрирование и системный мониторинг
Доступ к службе администрирования Oracle NoSQL Database можно получить с веб-консоли или Интерфейс командной строки. Эта служба поддерживает такие функции, как возможность настраивать, запускать, останавливать и контролировать узел хранения, не требуя файлов конфигурации, сценариев оболочки или явных операций с базой данных. Это позволяет Расширения управления Java (JMX) или Простой протокол управления сетью (SNMP) агенты, которые будут доступны для мониторинга. Это позволяет клиентам управления запрашивать информацию о состоянии, показателях производительности и рабочих параметрах узла хранения и его управляемых служб.[12]
Эластичная конфигурация
«Эластичность» означает динамическое онлайн-расширение развернутого кластера.[13] Добавление узлов хранения увеличивает емкость, производительность и надежность. База данных Oracle NoSQL включает функцию планирования топологии, с помощью которой администратор может изменять конфигурацию базы данных NoSQL, пока база данных находится в оперативном режиме. Администратор может:
- Увеличение распределения данных: за счет увеличения количества шардов в кластере, что увеличивает пропускную способность записи.
- Увеличьте коэффициент репликации: назначив дополнительные узлы репликации каждому шарду, что повысит пропускную способность чтения и доступность системы.
- Перебалансировать хранилище данных: изменив емкость узлов хранения, можно перебалансировать систему, перераспределив узлы репликации узлам хранения.[14] по мере необходимости.
Администраторы могут перемещать узлы репликации и / или разделы с чрезмерно загруженных узлов на недостаточно используемые узлы хранения или наоборот.
Многозонное развертывание
База данных Oracle NoSQL поддерживает несколько зон для интеллектуального распределения репликации процессов и данных с целью повышения надежности в режимах отказа оборудования, сети и питания. Есть два типа зон: основные зоны, которые содержат узлы, которые могут служить в качестве мастеров или реплик и обычно соединяются быстрыми межсоединениями. Вторичные зоны содержат узлы, которые могут служить только репликами. Вторичные зоны можно использовать для обеспечения доступа для чтения с малой задержкой к данным в удаленном месте или для разгрузки рабочих нагрузок только для чтения, таких как аналитика, создание отчетов и обмен данными, для улучшения управления рабочими нагрузками.
Формат данных JSON
База данных Oracle NoSQL поддерживает Авро[15] сериализация данных, которая обеспечивает компактный формат двоичных данных на основе схемы. Схемы определяются с использованием JSON. База данных Oracle NoSQL поддерживает эволюцию схемы. Настраиваемая интеллектуальная топология. Системные администраторы указывают, сколько емкости доступно на данном узле хранения, что позволяет узлам с более широкими возможностями размещать несколько узлов репликации. Как только система узнает о емкости узлов хранения в конфигурации, она автоматически распределяет узлы репликации. Это предназначено для лучшей балансировки нагрузки, лучшего использования системных ресурсов и минимизации воздействия на систему в случае отказа узла хранения. Умная топология поддерживает дата-центры, гарантируя, что полный набор реплик изначально выделен каждому центру обработки данных.
Онлайн-обновление
Oracle NoSQL Database предоставляет средства для выполнения последовательного обновления, позволяя системному администратору обновлять узлы кластера, пока база данных остается доступной.[16]
Отказоустойчивость
База данных Oracle NoSQL настраивается как C / P или A / P в КЕПКА.[17] В частности, если запись настроена на синхронное выполнение для всех реплик, это C / P в CAP, то есть сбой раздела или узла приводит к недоступности системы для записи. Если репликация выполняется асинхронно и чтение настроено для обслуживания с любой реплики, это A / P в CAP, то есть система всегда доступна, но нет гарантии согласованности.
Возможности базы данных
Табличная модель данных
В версии 3.0 представлена табличная структура данных, которая упрощает моделирование данных приложения за счет использования существующих концепций проектирования схем. Табличная модель располагается поверх распределенной структуры "ключ-значение", унаследовав все ее преимущества и упрощая дизайн приложения, обеспечивая бесшовную интеграцию со знакомыми приложениями на основе SQL.
Вторичный индекс
Индексирование только на основе первичного ключа ограничивает количество путей доступа с малой задержкой. Иногда приложениям требуются пути, не основанные на первичных ключах, для поддержки определенных требований приложения. OND поддерживает вторичный индекс для любого поля значения.[18]
Поддержка больших объектов
API-интерфейсы Oracle NoSQL Database EE Stream позволяют читать и записывать большие объекты (LOB), такие как аудио- и видеофайлы, без необходимости материализовать весь файл в памяти. Это предназначено для уменьшения задержки операций для смешанных рабочих нагрузок с объектами разного размера.[19]
ACID-совместимая транзакция
База данных Oracle NoSQL предоставляет КИСЛОТА совместимые транзакции для полного создания, чтения, обновления и удаления (CRUD) операций, с регулируемой надежностью и гарантиями согласованности транзакций. Последовательность операций может работать как единый атомный unit, если все затронутые записи имеют один и тот же основной путь к ключу.[20]
Интеграция
База данных Oracle NoSQL включает поддержку Ява, C, Python, C # и ОСТАЛЬНЫЕ API. Это позволяет разработчику приложения выполнять операции CRUD. Эти библиотеки включают поддержку Avro, так что разработчики могут сериализовать записи «ключ-значение» и десериализовать записи «ключ-значение» взаимозаменяемо между приложениями C и Java.[21]
Oracle RESTful Services
База данных Oracle NoSQL поддерживает Oracle REST Data Services (ORDS).[22] Это позволяет клиентам создавать приложения на основе REST, которые могут получать доступ к данным в Oracle Database или OND.
GeoJSON
Поддерживает пространственные запросы в соответствии с RFC7946 GeoJSON данные. Поддерживаются пространственные функции и индексация данных GeoJSON.
Apache Hadoop
KVAvroInputFormat и KVInputFormat[23] доступны классы для чтения данных из OND непосредственно в задания Hadoop MapReduce. Одно из применений этого класса - чтение записей базы данных NoSQL в Oracle Loader for Hadoop.[24]
Интеграция с Oracle
Oracle Big Data SQL и Hive
Oracle Big Data SQL - это общий уровень доступа SQL к данным, хранящимся в Hadoop, HDFS, Улей и ОНД. Это позволяет клиентам запрашивать данные Oracle NoSQL из Hive или База данных Oracle. Пользователи могут запускать Уменьшение карты задания по отношению к данным, хранящимся в OND, настроенном для безопасного доступа. Последний выпуск также поддерживает как примитивные, так и сложные типы данных.
База данных Oracle
Oracle NoSQL Database EE поддерживает внешнюю таблицу, позволяет извлекать данные Oracle NoSQL из базы данных Oracle с помощью операторов SQL, таких как Select, Select Count (*) и т. Д. После того, как данные NoSQL представлены через внешние таблицы, можно получить доступ к данным через стандартные драйверы JDBC и / или визуализировать это с помощью инструментов бизнес-аналитики предприятия.
Другие продукты Oracle
Обработка событий Oracle (OEP) обеспечивает доступ для чтения к базе данных Oracle NoSQL через картридж базы данных NoSQL. После настройки картриджа можно использовать запросы CQL. Oracle Semantic Graph включает адаптер Jena для базы данных Oracle NoSQL[25] хранить большие объемы RDF данные (как тройки / четверки). Этот адаптер обеспечивает быстрый доступ к данным графиков, хранящимся в OND, через SPARQL запросы. Интеграция с Oracle Coherence позволяет использовать OND в качестве кеша для Oracle Coherence приложения, позволяющие приложениям напрямую обращаться к кэшированным данным из OND.
Безопасность предприятия
Oracle NoSQL Database EE поддерживает независимую от ОС аутентификацию пользователей на основе пароля на уровне кластера и интеграцию с Oracle Wallet, а также обеспечивает более надежную защиту[26] от несанкционированного доступа к конфиденциальным данным. Кроме того, на уровне сеанса Уровень защищенных гнезд (SSL) шифрование и ограничения сетевых портов улучшают защиту от сетевых вторжений.
Обновления выпуска
OND Version 4.0 - Новые возможности:
- Полнотекстовый поиск - Elastic Search.
- Time-To-Live - эффективное устаревание «просроченных» данных - распространенное требование Интернета вещей.
- SQL Query - язык декларативных запросов.
- Predicate Pushdown - возможность обрабатывать предикаты из Big Data SQL в узлах базы данных NoSQL без передачи данных, которые не соответствуют предикату, для повышения производительности и масштабируемости.
- Импорт / экспорт - Простое резервное копирование / восстановление данных или перемещение данных между хранилищами Oracle NoSQL Database.
Спектакль
Команда Oracle NoSQL Database работала с несколькими ключевыми партнерами Oracle, включая Intel и Cisco,[27] выполнение Yahoo! Тесты облачного обслуживания (YCSB) на различных конфигурациях оборудования и опубликовал его результаты. Например, в 2012 году Oracle сообщила, что Oracle NoSQL Database превысила 1 миллион смешанных операций YCSB в секунду.[28]
Смотрите также
Рекомендации
- ^ «Технический обзор базы данных Oracle NoSQL». www.oracle.com.
- ^ «Тесты производительности базы данных Oracle NoSQL».
- ^ Уэйнер, Питер. «Первый взгляд: база данных Oracle NoSQL».
- ^ Вулф, Александр. "Знаете ли вы NoSQL?".
- ^ «Магазин Oracle».
- ^ «Oracle NoSQL Basic Edition».
- ^ "Загрузки базы данных Oracle NoSQL". www.oracle.com.
- ^ http://docs.oracle.com/cd/NOSQL/html/index.html
- ^ ""Официальный документ Oracle NoSQL Database"" (PDF).
- ^ «Глава 1. Введение в базу данных Oracle NoSQL». docs.oracle.com.
- ^ Интеллектуальные драйверы
- ^ «Администрирование базы данных Oracle NoSQL». www.oracle.com. Получено 2019-04-15.
- ^ «Упругое расширение». www.oracle.com.
- ^ «Узлы хранения».
- ^ "Глава 8. Наручники Avro". docs.oracle.com.
- ^ «Постоянное обновление». www.oracle.com.
- ^ Абади, Даниэль (4 октября 2011 г.). «DBMS Musings: Обзор базы данных Oracle NoSQL».
- ^ «Oracle NoSQL Database 3.0 поддерживает табличную модель данных и вторичное индексирование». InfoQ.
- ^ «Поддержка больших объектов». www.oracle.com.
- ^ «Транзакции базы данных Oracle NoSQL». www.oracle.com.
- ^ "Oracle NoSQL Database API". www.oracle.com.
- ^ Сравнивать:«Обзор (API плагина Oracle REST Data Services)». download.oracle.com. Корпорация Oracle. Получено 2015-11-30.
В этом документе описывается, как разрабатывать и развертывать подключаемые модули, которые интегрируются со средой выполнения Oracle REST Data Services (ORDS).
- ^ "Oracle NoSQL Database API". docs.oracle.com.
- ^ «Использование базы данных Oracle NoSQL с Hadoop». www.oracle.com.
- ^ "Загрузки Oracle Semantic Technologies". www.oracle.com.
- ^ "Oracle NoSQL Database 3.0 повышает безопасность и производительность
- ^ «Центр обработки данных Cisco» (PDF). Cisco.
- ^ «База данных Oracle NoSQL превышает 1 миллион смешанных операций YCSB в секунду» В архиве 2015-05-20 на Wayback Machine