Я использую MongoDB в качестве основного хранилища для данных 1.5Tb + с прошлого года. Все было хорошо, но в последнее время я решил выполнить некоторую карту-сокращение против 14 000 000 документов, и мой экземпляр производства спустился. Пожалуйста, обратите внимание на детали:Сбой MongoDB на карте/Уменьшение
Мой конфиг:
Ubuntu 12.04.5 LTS, MongoDB 2.6.4, LVM (2 HDD, 1.5TB + свободный от 3TB + общего количества), 24 ГБ оперативной памяти (почти все бесплатно)
Монго конфигурации по умолчанию (за исключением LogPath и DBPATH параметров)
Монго войти:
2014-08-28T07:33:41.147+0400 [DataFileSync] flushing mmaps took 16177ms for 777 files 2014-08-28T07:33:44.004+0400 [conn13] M/R: (1/3) Emit Progress: 9920300 2014-08-28T07:33:47.178+0400 [conn13] M/R: (1/3) Emit Progress: 9928100 2014-08-28T07:33:50.004+0400 [conn13] M/R: (1/3) Emit Progress: 9967800 2014-08-28T07:33:53.115+0400 [conn13] M/R: (1/3) Emit Progress: 10007800 2014-08-28T07:33:56.009+0400 [conn13] M/R: (1/3) Emit Progress: 10048800 2014-08-28T07:33:59.050+0400 [conn13] M/R: (1/3) Emit Progress: 10091200 2014-08-28T07:34:02.530+0400 [conn13] M/R: (1/3) Emit Progress: 10102300 2014-08-28T07:34:05.510+0400 [conn13] M/R: (1/3) Emit Progress: 10102400 2014-08-28T07:34:08.932+0400 [conn13] SEVERE: Invalid access at address: 0x7cc8b2fe70b4 2014-08-28T07:34:08.983+0400 [conn13] SEVERE: Got signal: 7 (Bus error). Backtrace:0x11e6111 0x11e54ee 0x11e55df 0x7f5a7031ecb0 0xf29cad 0xf32f28 0xf32770 0x8b601f 0x8b693a 0x982885 0x988485 0x9966d8 0x9a3355 0xa2889a 0xa29ce2 0xa2bea6 0xd5dd6d 0xb9fe62 0xba1440 0x770aef mongod(_ZN5mongo15printStackTraceERSo+0x21) [0x11e6111] mongod() [0x11e54ee] mongod() [0x11e55df] /lib/x86_64-linux-gnu/libpthread.so.0(+0xfcb0) [0x7f5a7031ecb0] mongod(_ZN5mongo16NamespaceDetails5allocEPNS_10CollectionERKNS_10StringDataEi+0x1bd) [0xf29cad] mongod(_ZN5mongo19SimpleRecordStoreV111allocRecordEii+0x68) [0xf32f28] mongod(_ZN5mongo17RecordStoreV1Base12insertRecordEPKcii+0x60) [0xf32770] mongod(_ZN5mongo10Collection15_insertDocumentERKNS_7BSONObjEbPKNS_16PregeneratedKeysE+0x7f) [0x8b601f] mongod(_ZN5mongo10Collection14insertDocumentERKNS_7BSONObjEbPKNS_16PregeneratedKeysE+0x22a) [0x8b693a] mongod(_ZN5mongo2mr5State12_insertToIncERNS_7BSONObjE+0x85) [0x982885] mongod(_ZN5mongo2mr5State14reduceInMemoryEv+0x175) [0x988485] mongod(_ZN5mongo2mr5State35reduceAndSpillInMemoryStateIfNeededEv+0x148) [0x9966d8] mongod(_ZN5mongo2mr16MapReduceCommand3runERKSsRNS_7BSONObjEiRSsRNS_14BSONObjBuilderEb+0xcc5) [0x9a3355] mongod(_ZN5mongo12_execCommandEPNS_7CommandERKSsRNS_7BSONObjEiRSsRNS_14BSONObjBuilderEb+0x3a) [0xa2889a] mongod(_ZN5mongo7Command11execCommandEPS0_RNS_6ClientEiPKcRNS_7BSONObjERNS_14BSONObjBuilderEb+0x1042) [0xa29ce2] mongod(_ZN5mongo12_runCommandsEPKcRNS_7BSONObjERNS_11_BufBuilderINS_16TrivialAllocatorEEERNS_14BSONObjBuilderEbi+0x6c6) [0xa2bea6] mongod(_ZN5mongo11newRunQueryERNS_7MessageERNS_12QueryMessageERNS_5CurOpES1_+0x22ed) [0xd5dd6d] mongod() [0xb9fe62] mongod(_ZN5mongo16assembleResponseERNS_7MessageERNS_10DbResponseERKNS_11HostAndPortE+0x580) [0xba1440] mongod(_ZN5mongo16MyMessageHandler7processERNS_7MessageEPNS_21AbstractMessagingPortEPNS_9LastErrorE+0x9f) [0x770aef]
После моего первого запуска этого сокращения карты я создал db.repairDatabase(), но после второй попытки уменьшить карту (после ремонта) снова произошел один и тот же сбой. Теперь, я понятия не имею, как получить мои m/r сделано
Любые идеи, люди?
Это, безусловно, больше напоминает проблему с оборудованием или, по крайней мере, проблему с файловой системой. Вы можете посмотреть [SERVER-12849] (https://jira.mongodb.org/browse/SERVER-12849) в вопросах Jira. Или поднимите свой собственный билет с более подробной информацией, подобной этому. –
thx для ответа. полностью согласен, похоже на повышение еще одного, но Jira для команды mongo будет иметь дело –
Перед тем, как подать заявку на Jira, я бы искал признаки проблем ввода-вывода или диска, как это было предложено в проблеме сервера, связанной с Neil. [Сигнал 7 (ошибка шины)] (http://en.wikipedia.org/wiki/Bus_error) указывает на неисправность оборудования, поэтому, вероятно, не так много возможностей для изучения с сервера MongoDB. Если у вас проблемы с вводом-выводом, вам может потребоваться заменить аппаратное обеспечение (и, возможно, восстановить из резервной копии, если это повлияло на целостность данных). Восстановление базы данных было бы последним средством (т. Е. Если у вас нет подходящей резервной копии и файлы данных были повреждены). – Stennie