Próbuję uruchomić ODOO na vps z 512 Mb RAM. Używam dockera. Kiedy uruchamiam kontenery z prostym dokiem, wszystko jest w porządku. I uruchomić tak: postgres pojemnik: pojemnikDocker-compose MemoryError
docker run -d -e POSTGRES_USER=odoo -e POSTGRES_PASSWORD=odoo --name db postgres
odoo: fine
docker run -p 8069:8069 --name odoo --link db:db -t odoo
żadnych błędów, wszystko działa. Potem zamknąć, usunąć ten pojemników i spróbować zrobić to samo z 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
I kiedy uruchomić dostaję 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
Próbowałem google powód, ale mogłem” znaleźć coś.
Błąd pamięci pochodzi z 'Döcker-compose', a nie aplikacji. Może 512 MB nie wystarcza do uruchomienia funkcji compose & postgres. – johnharris85
@ johnharris85 wydaje się mieć rację. Uruchomiłem twoje polecenie na moim komputerze i działało dobrze. Myślę, że wystarczy dać postgresowi wystarczającą ilość pamięci do pracy lub skonfigurować jego parametry, aby spróbować pracować z mniejszą ilością pamięci (co nie zadziała, moim zdaniem, wynosi 512 MB, nie brzmi jak wystarczająca pamięć dla instancji db) –
Na moim lokalnym komputerze doker-compose tworzy również kontenery. Ale myślałem, że jeśli zwykły doker może tworzyć pojemniki jeden po drugim, dlaczego doker-komponować przechyłki? Ponadto, pracowałem później z zainstalowaną aplikacją, dodałem kilka modułów, więc db działa dobrze i nie dostał żadnych błędów. Po uruchomieniu kontenerów przez zwykły doker. –