Як я можу створити MongoDB?


10

Мені здається, що зараз існує два шляхи для цього:

  1. https://github.com/skrabban/mongo-nonx86
  2. https://github.com/RickP/mongopi

Я влаштувався на mongo-nonx86вилку. Я встановив залежності, як описано в Інсталяція Mongodb в Raspberry Pi, і спробував створити MongoDB за допомогою scons. Але я отримую таку помилку:

generate_buildinfo(["build/buildinfo.cpp"], ['\n#include <string>\n#include <boost/version.hpp>\n\n#include "mongo/util/version.h"\n\nnamespace mongo {\n    const char * gitVersion() { return "%(git_version)s"; }\n    std::string sysInfo() { return "%(sys_info)s BOOST_LIB_VERSION=" BOOST_LIB_VERSION ; }\n}  // namespace mongo\n'])
gcc -o build/linux2/normal/third_party/pcre-8.30/pcre_exec.o -c -fPIC -fno-strict-aliasing -Wstrict-aliasing -ggdb -pthread -Wall -Wsign-compare -Wno-unknown-pragmas -Wcast-align -Winvalid-pch -O3 -DBOOST_ALL_NO_LIB -D_SCONS -DMONGO_EXPOSE_MACROS -DSUPPORT_UTF8 -D_FILE_OFFSET_BITS=64 -DJS_C_STRINGS_ARE_UTF8 -DMONGO_HAVE_HEADER_UNISTD_H -DMONGO_HAVE_EXECINFO_BACKTRACE -DHAVE_SYNC_FETCH_AND_ADD -DALIGNMENT_IMPORTANT -DHAVE_BSWAP32 -DHAVE_BSWAP64 -DHAVE_CONFIG_H -Ibuild/linux2/normal/third_party/boost -Isrc/third_party/boost -Ibuild/linux2/normal/third_party/pcre-8.30 -Isrc/third_party/pcre-8.30 -Ibuild/linux2/normal -Isrc -Ibuild/linux2/normal/mongo -Isrc/mongo src/third_party/pcre-8.30/pcre_exec.c
gcc: internal compiler error: Killed (program cc1)
Please submit a full bug report,
with preprocessed source if appropriate.
See <file:///usr/share/doc/gcc-4.6/README.Bugs> for instructions.
scons: *** [build/linux2/normal/third_party/pcre-8.30/pcre_exec.o] Error 4
scons: building terminated because of errors.

Компіляція mongopiзупинятиметься на тому самому файлі з тим самим повідомленням про помилку.

Тим часом я зрозумів, що моя система різко застаріла. Але навіть оновлення до останніх версій не вирішило проблему. На даний момент я припускаю, що це справді проблема із вільною пам’яттю. Враховуючи, що у мене є лише рання модель 256 Мб.


може виникнути проблема пам'яті - ви налаштували розділення пам'яті? Скільки вільної пам’яті у вас перед запуском gcc?
аболотнов

@abolotnov: Я відповім на них, як тільки моя збірка mongopiбуде завершена; D Оскільки я зараз досліджую цей проспект
Der Hochstapler

@abolotnov: розділений об'єм пам'яті становить 224/32. free -mпоказує 177 безкоштовно.
Der Hochstapler

1
Бінарний файл Mongodb знаходиться в communityсховищі дистрибутива Arch ARM.
Стрітення

@Jivings: Можливо, варто зняти, щоб скористатися Arch, тому що я нікуди не збираюся зібрати його на релізі Wheezy.
Der Hochstapler

Відповіді:


9

Зауважте, що ця відповідь стосувалася лише 256-мегабайтної версії Raspberry Pi. Версія 512 Мб повинна мати достатню кількість вільної пам'яті для компіляції MongoDB без додаткових налаштувань

Читаючи про ситуацію з низькою пам'яттю загалом, я знайшов пропозиції просто збільшити обмінний простір, щоб виправити ситуацію.

Отже, прочитавши відповідь ведмедика , я переконався, що це може бути вірним варіантом. Однак я вирішив додати простір під заміну, не використовуючи zRAM .

Тому що я ніколи не можу пригадати весь процес що - або , я пішов за керівництво Linux Додавання файлу підкачки - Howto по Nixcraft.

  1. Створення файлу / місця для зберігання:

    sudo dd if=/dev/zero of=/swapfile1 bs=1024 count=524288
    
  2. Встановіть простір як область підкачки:

    sudo mkswap /swapfile1
    
  3. Дозволити кореня тільки читати / писати:

    sudo chmod 0600 /swapfile1
    
  4. Увімкнути область підкачки:

    sudo swapon /swapfile1
    

Після цього sconsуспішно завершено, і я зміг встановити MongoDB. Я використовував mongopiвиделку врешті-решт.

db level locking enabled: 1
mongod --help for help and startup options
Sun Feb 10 13:05:33
Sun Feb 10 13:05:33 warning: 32-bit servers don't have journaling enabled by default. Please use --journal if you want durability.
Sun Feb 10 13:05:33
Sun Feb 10 13:05:33 [initandlisten] MongoDB starting : pid=2182 port=27017 dbpath=/data/db/ 32-bit host=raspberrypi
Sun Feb 10 13:05:33 [initandlisten]
Sun Feb 10 13:05:33 [initandlisten] ** NOTE: This is a development version (2.1.1) of MongoDB.
Sun Feb 10 13:05:33 [initandlisten] **       Not recommended for production.
Sun Feb 10 13:05:33 [initandlisten]
Sun Feb 10 13:05:33 [initandlisten] ** NOTE: when using MongoDB 32 bit, you are limited to about 2 gigabytes of data
Sun Feb 10 13:05:33 [initandlisten] **       see http://blog.mongodb.org/post/137788967/32-bit-limitations
Sun Feb 10 13:05:33 [initandlisten] **       with --journal, the limit is lower
Sun Feb 10 13:05:33 [initandlisten]
Sun Feb 10 13:05:33 [initandlisten] db version v2.1.1, pdfile version 4.5
Sun Feb 10 13:05:33 [initandlisten] git version: f457ff42ec37f2562d1a5ff06b4d96a861414c94
Sun Feb 10 13:05:33 [initandlisten] build info: Linux raspberrypi 3.2.27+ #250 PREEMPT Thu Oct 18 19:03:02 BST 2012 armv6l BOOST_LIB_VERSION=1_49
Sun Feb 10 13:05:33 [initandlisten] options: {}
Sun Feb 10 13:05:34 [initandlisten] waiting for connections on port 27017
Sun Feb 10 13:05:34 [websvr] admin web console waiting for connections on port 28017

У мене була така ж проблема на моделі B, і це рішення спрацювало. Thx
Мірча Ністор

ДЯКУЄТЕ ТАКІЙ СЛОВА ОЛІВЕР. Я хотів би зазначити, що модель B не мала для мене достатньої вільної пам’яті, і що після виконання цієї поради установка спрацювала. Чи проти ви змінити свою примітку у цій відповіді, щоб врахувати, що двом людям із моделлю B потрібно слідувати вашим крокам?
Меттью Мойсен

@MatthewMoisen: У мене виникла ця проблема і з моделлю B. Але моє було першим переглядом з 256 Мб оперативної пам’яті. Тільки друга редакція отримала 512 Мб.
Der Hochstapler

1

У мене є варіант, який може працювати. Однак це, ймовірно, різко уповільнить ваш процес компіляції.

Вам потрібно налаштувати ZRAM на Pi. В основному, він стискає використану оперативну пам’ять, що дозволяє вам більше використовувати, але ціною більшого використання процесора.

Ми будемо виконувати вказівки тут, але я покладу їх на пост для легкого перегляду.

Отже, спочатку вам потрібно виконати root, оскільки багато цих команд вимагають root:

sudo su

Потім зробіть виклик файла /etc/init.d/zramіз таким вмістом:

#!/bin/bash

### BEGIN INIT INFO
#Provides: zram
#Required-Start:
#Required-Stop:
#Default-Start: 2 3 4 5
#Default-Stop: 0 1 6
#Short-Description: Increased Performance In Linux With zRam (Virtual Swap Compressed in RAM)
#Description: Adapted for Raspian (Rasberry pi) by eXtremeSHOK.com using https://raw.github.com/gionn/etc/master/init.d/zram
### END INIT INFO

start() {
    mem_total_kb=$(grep MemTotal /proc/meminfo | grep -E --only-matching '[[:digit:]]+')

    modprobe zram

    sleep 1
    #only using 50% of system memory, comment the line below to use 100% of system memory
    mem_total_kb=$((mem_total_kb/2))

    echo $((mem_total_kb * 1024)) > /sys/block/zram0/disksize

    mkswap /dev/zram0

    swapon -p 100 /dev/zram0
}

stop() {
    swapoff /dev/zram0
    sleep 1
    rmmod zram
}

case "$1" in
    start)
        start
        ;;
    stop)
        stop
        ;;
    restart)
        stop
        sleep 3
        start
        ;;
    *)
        echo "Usage: $0 {start|stop|restart}"
        RETVAL=1
esac

Якщо ви хочете простий спосіб отримати його на Pi : sudo wget http://vps1.berboe.co.uk/zram.sh -O /etc/init.d/zram.

Потім додайте свій скрипт у список запуску при завантаженні, виконавши:

chmod +x /etc/init.d/zram
update-rc.d zram defaults

Потім перезавантажте і все повинно працювати.

Після перезавантаження, виконайте наступну команду: swapon -s. Вихід повинен бути приблизно таким:

Filename Type Size Used Priority
/var/swap file 524284 0 -1
/dev/zram0 partition 237900 0 100

Тепер, ZRAM встановлений, і якщо ви спробуєте компілювати так, як ви робили раніше, це може спрацювати.


Дякую за цю пропозицію! Я просто додав додатковий простір для обміну, не використовуючи zram. Спробуйте продовжити компіляцію зараз.
Der Hochstapler
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.