2016-11-17 8 views
5

Я пытаюсь запустить odoo на vps с 512 Мб оперативной памяти. Я использую докер. Когда я запускаю контейнеры с обычным докером, все в порядке. Я запускаю так: Postgres контейнер:Docker-compose MemoryError

docker run -d -e POSTGRES_USER=odoo -e POSTGRES_PASSWORD=odoo --name db postgres 

odoo контейнер:

docker run -p 8069:8069 --name odoo --link db:db -t odoo 

без ошибок, все работает нормально. Тогда я выключение, удалить эти контейнеры и попытаться сделать то же самое с Докером-композом:

app: 
    image: odoo 
    tty: true 
    ports: 
     - "8069:8069" 
    volumes: 
     - ./addons:/mnt/extra-addons:ro,Z 
    links: 
     - db:db 

db: 
    image: postgres 
    environment: 
     POSTGRES_USER: odoo 
     POSTGRES_PASSWORD: odoo 

И когда я запускаю я получаю MemoryError:

[email protected]:~/odoo# docker-compose -f odoo.yml up 
Creating odoo_db_1 
Creating odoo_app_1 
Attaching to odoo_db_1, odoo_app_1 
db_1 | The files belonging to this database system will be owned by user "postgres". 
db_1 | This user must also own the server process. 
db_1 | 
db_1 | The database cluster will be initialized with locale "en_US.utf8". 
db_1 | The default database encoding has accordingly been set to "UTF8". 
db_1 | The default text search configuration will be set to "english". 
db_1 | 
db_1 | Data page checksums are disabled. 
db_1 | 
db_1 | fixing permissions on existing directory /var/lib/postgresql/data ... ok 
db_1 | creating subdirectories ... ok 
db_1 | selecting default max_connections ... 100 
db_1 | selecting default shared_buffers ... 128MB 
db_1 | selecting dynamic shared memory implementation ... posix 
db_1 | creating configuration files ... ok 
Traceback (most recent call last): 
    File "/usr/local/bin/docker-compose", line 9, in <module> 
    load_entry_point('docker-compose==1.9.0', 'console_scripts', 'docker-compose')() 
    File "/usr/local/lib/python2.7/dist-packages/compose/cli/main.py", line 65, in main 
    command() 
    File "/usr/local/lib/python2.7/dist-packages/compose/cli/main.py", line 117, in perform_command 
    handler(command, command_options) 
    File "/usr/local/lib/python2.7/dist-packages/compose/cli/main.py", line 862, in up 
    log_printer.run() 
    File "/usr/local/lib/python2.7/dist-packages/compose/cli/log_printer.py", line 87, in run 
    for line in consume_queue(queue, self.cascade_stop): 
    File "/usr/local/lib/python2.7/dist-packages/compose/cli/log_printer.py", line 229, in consume_queue 
    raise item.exc 
MemoryError 

Я пытался Google причины, но не могла» найти что-нибудь.

+3

Ошибка памяти происходит из 'Докер-compose', а не вашего приложения. Возможно, 512mb недостаточно для запуска compose & postgres. – johnharris85

+1

@ johnharris85 кажется правильным. Я запустил вашу команду на своей машине, и она отлично работала. Я думаю, вам просто нужно предоставить postgres достаточную память для работы или настроить свои параметры, чтобы попытаться работать с меньшим объемом памяти (что не будет работать, на мой взгляд, 512 Мб не кажется достаточным для памяти для экземпляра db) –

+0

На моем локальном компьютере docker-compose также создает контейнеры. Но я думал, что если простой докер может создавать контейнеры один за другим, почему докер-сочинять не может? Кроме того, я работал с установленным приложением позже, добавил некоторые модули, поэтому db работает нормально и не получил никаких ошибок. После того, как я запустил контейнеры с помощью обычного докера. –

ответ

5

Команда, которая запускает буферы json, чтобы она могла разбить ее правильно. Возможно, буферизация использует слишком много памяти.

Вы могли бы попробовать это вместо:

docker-compose -f odoo.yml up -d 

Это будет работать "отделить". Вы можете попробовать запустить docker-compose logs, чтобы просмотреть журналы.