Können nicht rake db:create im Dockerfile mit docker-Komponieren
Ich habe eine Dockerfile
und docker-compose.yml
wie in der tutorial außer ich fange an mit einer vorhandenen app.
Meine docker-compose.yml
aussieht:
db:
image: postgres
ports:
- "5432"
web:
build: .
command: bundle exec rails s -p 3000 -b '0.0.0.0'
volumes:
- .:/myapp
ports:
- "3030:3030"
links:
- db
sowie Dockerfile
:
FROM ruby:2.1.4
RUN apt-get update -qq && apt-get install -y build-essential libpq-dev nodejs
RUN mkdir /myapp
WORKDIR /myapp
ADD Gemfile /myapp/Gemfile
RUN bundle install
ADD . /myapp
# RUN bundle exec rake db:create
# RUN bundle exec rake db:migrate
# RUN bundle exec rake db:seed
sowie database.yml
development:
adapter: postgresql
encoding: utf8
database: myapp_development
host: db
pool: 5
username: postgres
password:
Wie Sie sehen können, habe ich kommentiert RUN bundle exec rake db:create
weil ich einen Fehler empfangen:
could not translate host name "db" to address: Name or service not known
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/postgresql_adapter.rb:1222:in `initialize'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/postgresql_adapter.rb:1222:in `new'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/postgresql_adapter.rb:1222:in `connect'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/postgresql_adapter.rb:324:in `initialize'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/postgresql_adapter.rb:28:in `new'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/postgresql_adapter.rb:28:in `postgresql_connection'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:315:in `new_connection'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:325:in `checkout_new_connection'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:247:in `block (2 levels) in checkout'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:242:in `loop'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:242:in `block in checkout'
/usr/local/lib/ruby/2.1.0/monitor.rb:211:in `mon_synchronize'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:239:in `checkout'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:102:in `block in connection'
/usr/local/lib/ruby/2.1.0/monitor.rb:211:in `mon_synchronize'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:101:in `connection'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_pool.rb:410:in `retrieve_connection'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_specification.rb:171:in `retrieve_connection'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/connection_adapters/abstract/connection_specification.rb:145:in `connection'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/railties/databases.rake:144:in `rescue in create_database'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/railties/databases.rake:85:in `create_database'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/railties/databases.rake:62:in `block (3 levels) in <top (required)>'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/railties/databases.rake:62:in `each'
/usr/local/bundle/gems/activerecord-3.2.21/lib/active_record/railties/databases.rake:62:in `block (2 levels) in <top (required)>'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/task.rb:240:in `call'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/task.rb:240:in `block in execute'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/task.rb:235:in `each'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/task.rb:235:in `execute'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/task.rb:179:in `block in invoke_with_call_chain'
/usr/local/lib/ruby/2.1.0/monitor.rb:211:in `mon_synchronize'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/task.rb:172:in `invoke_with_call_chain'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/task.rb:165:in `invoke'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:150:in `invoke_task'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:106:in `block (2 levels) in top_level'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:106:in `each'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:106:in `block in top_level'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:115:in `run_with_threads'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:100:in `top_level'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:78:in `block in run'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:176:in `standard_exception_handling'
/usr/local/bundle/gems/rake-10.4.2/lib/rake/application.rb:75:in `run'
/usr/local/bundle/gems/rake-10.4.2/bin/rake:33:in `<top (required)>'
/usr/local/bundle/bin/rake:16:in `load'
/usr/local/bundle/bin/rake:16:in `<main>'
Couldn't create database for {"adapter"=>"postgresql", "encoding"=>"utf8", "database"=>"myapp_development", "host"=>"db", "pool"=>5, "username"=>"postgres", "password"=>nil}
Stattdessen musste ich docker-compose build
dann docker-compose run web rake db:create
etc.
Warum kann ich nicht die db-Erstellung/migration im Dockerfile. Es wäre so viel clearner. Kann ich das erreichen?
Du musst angemeldet sein, um einen Kommentar abzugeben.
Wenn Ihr
web
Bild aufgebaut ist (nach den Anweisungen desDockerfile
), es nicht über eine Verbindung zu einemdb
container.Den webserver und die Datenbank Bilder sind independents und die Behälter sind verknüpft, wenn Sie starten Sie (nach den Definitionen der
docker-compose.yml
- Datei).Können Sie keine Verbindung zu einem container, der während der image-Erstellung, weil es würde durchbrechen den Grundsatz, dass ein Bild erstellen müssen reproduzierbar. Ebenso können Sie keine montieren Sie ein volume aus der host-Maschine, während ein Bild erstellen keine.
Den
docker-compose run web rake db:create
Befehl, den Sie benutzen, ist eine korrekte Weise, auf initalize der Datenbank.Alternativ könnten Sie starten die Container in der Regel mit
docker-compose
, und verwenden Sie dann diedocker exec
Befehl ausführenrake db:create
imweb
container.run rake db:setup
? und starten Sie den Container?rake db:setup
sollte nur einmal durchgeführt werden. Sie nicht brauchen, um es auszuführen jedes mal, wenn Sie starten Sie den Behälter.docker-compose run web rake db:create
beim Neustart den Container? docs.docker.com/compose/rails/#restart-the-application/var/lib/postgresql/data
: github.com/docker-library/postgres/blob/.... Also keine Notwendigkeit zum ausführen von Migrationen beim starten der Container.docker-compose rm
Möchten Sie vielleicht zu montieren
/tmp/db
in Ihren postgres-container/var/lib/postgresql/data
.Durch, dass die DB synchronisiert werden, um Ihre Gastgeber und das nächste mal neu gestartet/neu erstellen die app diese DB wird automatisch initialisiert werden. Taten so laufen
docker-compose run web rake db:create
nur einmal, wenn Sie setup-Projekt wie würden Sie nativ und von da an weiter mit nurdocker-compose run web rake db:create
etc.Ich Frage mich wirklich, warum Sie nicht schrieb, dass in der Dokumentation verlinkt. Ich öffnete eine PR, um das hinzuzufügen.