Como posso construir o MongoDB?

10

Parece-me que atualmente há duas maneiras de fazer isso:

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

Eu me conformei com o mongo-nonx86garfo. Instalei as dependências conforme descrito em Instalar o Mongodb no Raspberry Pi e tentei criar o MongoDB usando scons. Mas eu recebo o seguinte erro:

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.

A compilação mongopiserá interrompida exatamente no mesmo arquivo com a mesma mensagem de erro.

Enquanto isso, percebi que meu sistema estava dramaticamente desatualizado. Mas mesmo a atualização para as versões mais recentes não resolveu o problema. Neste ponto, estou assumindo que é realmente um problema de memória livre. Dado que eu só tenho um modelo inicial de 256 MB.

Der Hochstapler
fonte
pode ser um problema de memória - você configurou a divisão de memória? Quanta memória livre você tem antes de executar o gcc?
Abolotnov
@abolotnov: Eu vou responder aqueles assim que minha compilação de mongopiestá completa; D Como eu estou explorando essa avenida agora
Der Hochstapler
@abolotnov: A divisão da memória é 224/32. free -mmostra 177 grátis.
Der Hochstapler
11
O binário Mongodb está no communityrepositório na distro do Arch ARM.
Jivings
@Jivings: Pode valer uma chance de usar o Arch, porque não vou a lugar algum compilá-lo no lançamento do Wheezy.
Der Hochstapler

Respostas:

9

Observe que esta resposta se aplica apenas à versão de 256 MB do Raspberry Pi. A versão de 512 MB deve ter memória livre suficiente para compilar o MongoDB sem ajustes adicionais

Ao ler sobre a situação de pouca memória em geral, encontrei sugestões para simplesmente aumentar o espaço de troca para remediar a situação.

Então, depois de ler a resposta de bearbin , fiquei convencido de que essa poderia ser uma opção válida. No entanto, optei por adicionar espaço de troca sem utilizar o zRAM .

Porque eu nunca consigo lembrar o processo completo para qualquer coisa , eu segui o guia Linux Adicionar um arquivo de permuta - Howto por Nixcraft.

  1. Crie um arquivo de troca / espaço de armazenamento:

    sudo dd if=/dev/zero of=/swapfile1 bs=1024 count=524288
    
  2. Configure o espaço como área de troca:

    sudo mkswap /swapfile1
    
  3. Permita apenas que o root leia / escreva:

    sudo chmod 0600 /swapfile1
    
  4. Ativar área de troca:

    sudo swapon /swapfile1
    

Posteriormente, sconsconcluí com êxito e consegui instalar o MongoDB. Eu usei o mongopigarfo no final.

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
Der Hochstapler
fonte
Eu tive o mesmo problema em um modelo B e esta solução funcionou. Thx
Mircea Nistor,
MUITO OBRIGADO OLIVER. Gostaria de salientar que o Modelo B não tinha memória livre suficiente para mim e que, após seguir este conselho, a instalação funcionou. Você se importaria de alterar sua nota nesta resposta para considerar que duas pessoas com o Modelo B precisavam seguir seus passos?
Matthew Moisen
@MatthewMoisen: Eu também tive esse problema com um modelo B. Mas a minha foi a primeira revisão com 256 MB de RAM. Somente a segunda revisão obteve 512 MB.
Der Hochstapler
1

Eu tenho uma opção que pode funcionar. No entanto, isso provavelmente diminuirá drasticamente seu processo de compilação.

Você precisa configurar o ZRAM no seu Pi. Basicamente, comprime a RAM usada para permitir que você use mais, mas ao custo de mais uso da CPU.

Seguiremos as instruções aqui, mas eu as colocarei no post para facilitar a visualização.

Então, primeiro, você precisa ser root, pois muitos desses comandos requerem root:

sudo su

Em seguida, crie um arquivo chamado /etc/init.d/zramcom o seguinte conteúdo:

#!/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

Se você quiser uma maneira fácil de obtê-lo na Pi: sudo wget http://vps1.berboe.co.uk/zram.sh -O /etc/init.d/zram.

Em seguida, adicione seu script à lista start-at-boot, fazendo:

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

Em seguida, reinicie e tudo deve funcionar.

Após a reinicialização, execute este comando: swapon -s. A saída deve ser algo como isto:

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

Agora, o ZRAM está instalado e se você tentar compilar como fez antes de funcionar.

hifkanotiks
fonte
Obrigado por esta sugestão! Simplesmente adicionei mais espaço de troca sem utilizar o zram por enquanto. Tentando continuar a compilação agora.
Der Hochstapler