Re[5]: Выбор NoSQL
От: Иль  
Дата: 11.05.16 10:49
Оценка:
Здравствуйте, Alex.Che, Вы писали:

AC>монопольный режим используют только неучи, которые не умеют правильно выставить уровень изоляции транзакции для модификации метаданных.


Это всё уже без меня. При работе с Постгресом умения "правильно выставить уровень изоляции транзакции для модификации метаданных" не требуется
Отредактировано 11.05.2016 10:50 Иль . Предыдущая версия .
Re[6]: Выбор NoSQL
От: Alex.Che  
Дата: 11.05.16 10:54
Оценка: +1 :))) :)
> При работе с Постгресом умения "правильно выставить уровень изоляции транзакции для модификации метаданных" не требуется

а многие пользователи MS SQL вообще уверены, что "не используют транзакции"
Posted via RSDN NNTP Server 2.1 beta
Re: Выбор NoSQL
От: Anton Batenev Россия https://github.com/abbat
Дата: 11.05.16 13:05
Оценка: 14 (1)
Здравствуйте, Blazkowicz, Вы писали:

B> Правильно ли я понимаю, что такие решения как HBase являются полностью in-memory решениями?


Нет. HBase — это для обработки данных с петабайтными объемами, для которых никакой памяти не хватит.

B> То есть, их вообще нет смысла использовать при отсутствии кластера в десяток серверов?


Да. Практически все NoSQL решения не имеют смысла в рамках одного сервера. Для HBase/Mongo тебе их нужно будет минимум 3.

B> Совсем забыл ещё один важный вопрос. Есть ли у NoSQL какие-либо преимущества в maintenance? Ну, там бэкапы. Расширение пространства и т.п.


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

P.S. Вот только для хранения блобов NoSQL наверное лишен смысла.
... в первом классе мне говорили, что нужно делиться, а теперь говорят, что это незаконно ...
Re: Выбор NoSQL
От: gandjustas Россия http://blog.gandjustas.ru/
Дата: 11.05.16 13:40
Оценка: 24 (2) +1
Здравствуйте, Blazkowicz, Вы писали:

B>Привет,


B> Начальник хочет поэкспериментировать с NoSQL на одном из проектов. Не столько для пользы проекта, а чтобы получить опыт для будущих решений, так как с RDBMS уже много чего накушались.

B>Обзорно читал про NoSQL, но никогда вплотную не использовал. Потратил ещё пару дней на ознакомление, но каждый раз, когда начинаю читать про конкретное решение, возникает ощущение что это не то что нужно.
B>Ткните, пальцем в алгоритм выбора.
Так ты опиши что нужно.
Иначе алгоритм выбора простой — используй нормальную РСУБД (Postgres, MS SQL, остальное не рекоменду ибо дорого для стартапа).
NoSQL помогают только в частных случаях, в общем случае их лучше не использовать.

B>Проект уже в каком-то виде использует свой примитивный NoSQL. Пользователи загружают свои данные в систему. Система строит отчет и хранить его в виде сериализованного объекта в файле в облаке.

B>Новая задача требует собирать некоторые данные пользователей и хранить их другим объектом. Вроде как обычное Key-Value выходит.
B>Сервис публичный. Есть риск что данных станет очень много. Поэтому пихать много всего в MySQL не охота.
B>Транзакции особо не нужны. Нужно хранить достаточно жирные объекты до 10Мб, а в будущем может и больше.
Это все оценочные суждения, при приведи конкретику. Начни с объема данных в количестве строк\объектов, нарисуй связи в логической структуре данных, расскажи какие запросы будут идти в базу.

B>Для каких задач можно получить преимущества от Graph или Column oriented хранилищ?

Графовые базы кроме получения объекта по ключу умеют делать обход графа на уровне движка. И говорят это быстрее чем CTE\connect by в РСУБД.
Column oriented нужны для быстрого получения агрегатов на большом объеме. Это нечто среднее между OLAP и OLTP. Подробнее можешь почитать как работает clustered columnstore в MS SQL, принципы в column-oriented те же.


B>Правильно ли я понимаю, что такие решения как HBase являются полностью in-memory решениями? То есть, их вообще нет смысла использовать при отсутствии кластера в десяток серверов?

По сути да.

B>Что вообще почитать обзорного?

http://kkovacs.eu/cassandra-vs-mongodb-vs-couchdb-vs-redis
Re[2]: Выбор NoSQL
От: gandjustas Россия http://blog.gandjustas.ru/
Дата: 11.05.16 13:43
Оценка: +1
Здравствуйте, Blazkowicz, Вы писали:

B>Совсем забыл ещё один важный вопрос. Есть ли у NoSQL какие-либо преимущества в maintenance? Ну, там бэкапы. Расширение пространства и т.п.


Скорее наоборот. С бекапами у NoSQL обычно проблема, обслуживание часто требует остановки сервиса.
Re: Выбор NoSQL
От: Слава  
Дата: 11.05.16 13:51
Оценка:
Здравствуйте, Blazkowicz, Вы писали:

B>Привет,


B>...


B>Спасибо


Обзорного не порекомендую, но скажу что например в яндексе кассандра используется как хранилище для конфигураций датацентов, там стоят чудовищной мощности серверы, сцепленные в кольцо по 10 штук, все это работает устойчиво. То есть, по зрелости кассандра вполне подходит.
Re: Выбор NoSQL
От: zubactik  
Дата: 11.05.16 14:17
Оценка:
Можно попробовать мультимодальную СУБД ArangoDB. Мы сейчас на проектах с ней играемся.
Re[2]: Выбор NoSQL
От: Blazkowicz Россия  
Дата: 11.05.16 14:27
Оценка:
Здравствуйте, Anton Batenev, Вы писали:

AB>P.S. Вот только для хранения блобов NoSQL наверное лишен смысла.

Это не блобы. На самом деле всю структуру можно разложить в реляционную. Блобы, тут как попытка примитивного NoSQL — держать данные одного юзера единым целым.
Re[3]: Выбор NoSQL
От: Dym On Россия  
Дата: 11.05.16 15:25
Оценка: 7 (1) +1
B>Ну, я о том же. Сейчас примерно такая реализация и существует.
B>Смысл перехода на другое хранилище в том, что это не тупо блобы. Это вполне себе конкретные одинаковые структуры данных.
B>Иногда возникает желание что-то типовое из них всех вытащить и посчитать. Можно долго.
В порядке бреда: одинаковые структуры можно хранить как микро бд, например, SQLite, а сами файлы sqlite в РСУБД (в полях типа bfile) с некоторыми метаданными для поиска.
Ну опять же от задачи зависит, это может быть удобно, когда требуется получить эту структуру, с ней атомарно поработать и положить обратно.

Это, конечно, не NoSQL, но как решение может и сработать.
Счастье — это Glück!
Re[2]: Выбор NoSQL
От: paucity  
Дата: 11.05.16 15:48
Оценка:
Здравствуйте, Дельгядо Филипп, Вы писали:

ДФ>Обычное key-value — это монга.


Серьезно? Монго — key-value?
Многие и рады были бы испытать когнитивный диссонанс, но нечем.
Re[2]: Выбор NoSQL
От: Pzz Россия https://github.com/alexpevzner
Дата: 11.05.16 16:24
Оценка:
Здравствуйте, Alex.Che, Вы писали:

>> Начальник хочет поэкспериментировать с NoSQL на одном из проектов.


AC>научная организация?


Это вполне осмысленное действие, потратить некоторое разумное количество ресурсов на приобретение нового опыта.
Re[7]: Выбор NoSQL
От: Иль  
Дата: 11.05.16 16:29
Оценка: :)
Здравствуйте, Alex.Che, Вы писали:

>> При работе с Постгресом умения "правильно выставить уровень изоляции транзакции для модификации метаданных" не требуется


AC>а многие пользователи MS SQL вообще уверены, что "не используют транзакции"


По-моему это наблюдение в пользу MS SQL. Не нужны тебе транзакции — ты о них и не задумываешься. Хотя в СУБД они есть, ждут своего часа.
А вот если тебе транзакции в каком-то конкретном (начальном) случае не нужны, но ты, несмотря на это, не можешь ничего даже элементарного сделать пока не разберёшься с уровнями изоляции, то место такой базе, на мой скромный взгляд — ...
Re[3]: Выбор NoSQL
От: Anton Batenev Россия https://github.com/abbat
Дата: 11.05.16 18:35
Оценка: 7 (1)
Здравствуйте, Blazkowicz, Вы писали:

B> AB>P.S. Вот только для хранения блобов NoSQL наверное лишен смысла.

B> Это не блобы. На самом деле всю структуру можно разложить в реляционную. Блобы, тут как попытка примитивного NoSQL — держать данные одного юзера единым целым.

Тогда, если данные так легко раскладываются, я бы посоветовал взять MongoDB и просто попробовать. Она элементарно устанавливается и почти не требует никакой настройки / обслуживания, работа с ней проста и незатейлива. К тому моменту, когда ты столкнешься с ее особенностями, у тебя уже будет представление о том что это такое и с чем это едят — как раз тот самый случай, когда "фигак-фигак и в production" имеет позитивную составляющую.
Бэкапимся на Яндекс.Диск
Re: Выбор NoSQL
От: WinnieJayClay Финляндия  
Дата: 11.05.16 18:51
Оценка: 7 (1) :)
В мире есть только одна очень серъезная бесплатная NoSQL база данных, называется Cassandra. Она настолько серъезная что Riak и прочие даже рядом не стояли, она написана на java и используется также компанией Microsoft.

Посмотрите на пользователей
http://www.planetcassandra.org/companies/
http://www.datastax.com/customers

Она также используется в финансовом мире банками для очень важных данных, много виде здесь:
https://www.youtube.com/user/PlanetCassandra
Re[3]: Выбор NoSQL
От: Cyberax Марс  
Дата: 12.05.16 07:38
Оценка: +1 -1 :))
Здравствуйте, gandjustas, Вы писали:

B>>Совсем забыл ещё один важный вопрос. Есть ли у NoSQL какие-либо преимущества в maintenance? Ну, там бэкапы. Расширение пространства и т.п.

G>Скорее наоборот. С бекапами у NoSQL обычно проблема, обслуживание часто требует остановки сервиса.
ЩИТО?
Sapienti sat!
Re[8]: Выбор NoSQL
От: Alex.Che  
Дата: 12.05.16 08:03
Оценка:
> По-моему это наблюдение в пользу MS SQL. Не нужны тебе транзакции — ты о них и не задумываешься. Хотя в СУБД они есть, ждут своего часа.

очень интересный взгляд на вещи.
особенно про то, что "они ждут своего часа".
умилительно.
Posted via RSDN NNTP Server 2.1 beta
Re[4]: Выбор NoSQL
От: gandjustas Россия http://blog.gandjustas.ru/
Дата: 12.05.16 08:46
Оценка: +1
Здравствуйте, Cyberax, Вы писали:

C>Здравствуйте, gandjustas, Вы писали:


B>>>Совсем забыл ещё один важный вопрос. Есть ли у NoSQL какие-либо преимущества в maintenance? Ну, там бэкапы. Расширение пространства и т.п.

G>>Скорее наоборот. С бекапами у NoSQL обычно проблема, обслуживание часто требует остановки сервиса.
C>ЩИТО?

Напомни какая NoSQL база может делать дифференциальный бекап и Point In Time restore на базе в минимум в 200гб?
Сколько монге надо времени на сбор индексов после рестора 100 гб базы?
Re[9]: Выбор NoSQL
От: Иль  
Дата: 12.05.16 09:50
Оценка:
Здравствуйте, Alex.Che, Вы писали:

>> По-моему это наблюдение в пользу MS SQL. Не нужны тебе транзакции — ты о них и не задумываешься. Хотя в СУБД они есть, ждут своего часа.


AC>очень интересный взгляд на вещи.

AC>особенно про то, что "они ждут своего часа".
AC>умилительно.

Нет, ну на Firebird-Delphi это, конечно, не распространяется. Там ждать нечего и неоткуда.
Re[10]: Выбор NoSQL
От: Alex.Che  
Дата: 12.05.16 09:56
Оценка:
ещё одно подтверждение тому, как пагубно влияет чтение "Thinking In Java" на неокрепший мозг...
Posted via RSDN NNTP Server 2.1 beta
Re[11]: Выбор NoSQL
От: Иль  
Дата: 12.05.16 10:08
Оценка: :)
Не понял. Зачем читать "Thinking in java" когда ты бог выставления уровней изоляции в Firebird?

Это избыточно.
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.