2016-11-17 156 views
5

我嘗試使用512 Mb RAM在vps上啓動odoo。 我使用碼頭。當我用普通碼頭工具啓動容器時,一切都很好。我發動這樣的: 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 

我想谷歌的原因,但couldn」找不到任何東西。

+3

的內存錯誤是從'搬運工-compose',而不是你的應用程序來。也許512MB不足以運行compose&postgres。 – johnharris85

+1

@ johnharris85似乎是正確的。我已經在我的機器上運行了你的命令,它運行良好。我認爲你只需要給postgres足夠的內存來處理,或者配置它的參數來嘗試使用更少的內存(這在我看來是不行的,512mb對於db實例來說聽起來不夠記憶) –

+0

在我的本地機器上,docker-compose也可以創建容器。但我想如果普通碼頭工人可以一個一個地創建容器,爲什麼碼頭工人可以不能?此外,我後來與安裝的應用程序一起工作,添加了一些模塊,所以數據庫工作正常,並沒有收到任何錯誤。我通過普通的docker運行容器之後。 –

回答

5

正在運行的命令會緩衝json,以便它可以正確分割它。緩衝可能會佔用太多內存。

你可以代替試試這個:

docker-compose -f odoo.yml up -d 

這將運行 「分離」。您仍然可以嘗試運行docker-compose logs以查看日誌。