【发布时间】:2017-03-31 19:29:27
【问题描述】:
我尝试在具有 512 Mb RAM 的 vps 上启动 odoo。 我使用码头工人。当我用普通的 docker 启动容器时,一切都很好。我这样启动: postgres 容器:
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
没有错误,一切正常。然后我关闭,删除这个容器并尝试用 docker-compose 做同样的事情:
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:
root@ubuntu-512mb-fra1-01:~/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
我试图用谷歌搜索原因,但找不到任何东西。
【问题讨论】:
-
内存错误来自
docker-compose,而不是您的应用程序。也许 512mb 不足以运行 compose 和 postgres。 -
@johnharris85 似乎是对的。我已经在我的机器上运行了你的命令,它运行良好。我认为您只需要为 postgres 提供足够的内存即可使用,或者配置其参数以尝试使用更少的内存(在我看来,这不起作用,512mb 听起来不像 db 实例的足够内存)
-
在我的本地机器上,docker-compose 也可以很好地创建容器。但是我想如果普通的 docker 可以一个一个地创建容器,为什么 docker-compose 不能呢?此外,我后来使用安装的应用程序,添加了一些模块,所以 db 工作正常并且没有收到任何错误。在我通过普通 docker 运行容器之后。
标签: python postgresql python-2.7 docker docker-compose