Dans le dernier numéro, nous avons expliqué comment conteneuriser les applications Ruby on Rails. Dans ce numéro, nous explorerons comment effectuer les tâches quotidiennes dans des conteneurs.
Exécuter des tâches Rake et des commandes Rails
Exécuter des tâches Rake est facile. Après avoir créé l'image, vous pouvez utiliser docker-compose pour y exécuter des commandes. Par exemple, si vous souhaitez visualiser les itinéraires de votre application :
<code class="language-bash">$ docker-compose run web rails routes</code>
De même, si vous souhaitez créer une base de données, migrer et renseigner les données :
<code class="language-bash">$ docker-compose run web rails db:create db:migrate db:seed</code>
Si vous souhaitez exécuter la suite de tests, vous devez créer une base de données de tests :
<code class="language-bash">$ docker-compose run web rails db:create db:migrate RAILS_ENV=test</code>
Ensuite, exécutez la suite de tests (en supposant que rake exécute rake test par défaut) :
<code class="language-bash">$ docker-compose run web rake</code>
Conseil : Créez des scripts/alias personnalisés
Je cours docker-compose run web rails ...
des centaines de fois par jour, et pour faciliter les choses, j'ai mis ce script dans mon $PATH
:
<code class="language-bash">#!/bin/bash docker-compose run web rails "$@"</code>
Veuillez noter que ce script suppose que votre fichier docker-compose.yml
dispose d'un service Web. Sinon, ça ne marchera pas.
Effectuer d'autres tâches
Jusqu'à présent, toutes les commandes sont très simples et directes, il vous suffit de les exécuter dans le service Web. Alors, que faites-vous de certaines des tâches les plus difficiles, comme le chargement d'une base de données préexistante dans la base de données d'un conteneur ? C'était l'une des tâches qui m'a pris un peu plus de temps à comprendre.
Dans PostgreSQL, il existe deux façons de procéder, selon le format du fichier de dump. Dans le passé, nous devions faire face à des --format=c
dumps et des dumps réguliers.
Supposons que vous ayez un fichier latest.dump
contenant un dump PostgreSQL au format c et que vous souhaitiez le charger dans un conteneur (en cours d'exécution), vous devez d'abord connaître l'ID du conteneur. Vous pouvez le faire en exécutant la commande suivante :
<code class="language-bash">$ docker container ls</code>
ou
<code class="language-bash">$ docker ps</code>
Une fois que vous avez l'ID du conteneur (dans cet exemple, nous utiliserons 80f8041db4b4
), vous pouvez exécuter la commande suivante pour restaurer le dump dans le conteneur :
<code class="language-bash">$ docker exec -i 80f8041db4b4 pg_restore -d app_development -U postgres</code>
Si vous disposez d'un dump régulier (par exemple latest.sql
), vous pouvez le restaurer en utilisant :
<code class="language-bash">$ docker exec -i 80f8041db4b4 psql -d app_development -U postgres</code>
Si vous utilisez docker-compose, les choses deviennent plus faciles :
<code class="language-bash">$ docker-compose exec -T db pg_restore -d app_development -U postgres</code>
Tout est conteneurisé !
J'utilise beaucoup Elastic Beanstalk. Je l'installe généralement en utilisant Homebrew, mais il installe beaucoup de ses propres dépendances telles que Python, SQLite, etc. Je ne veux pas de tout cela sur mon système, d'autant plus que j'ai toujours des problèmes avec la version Python. Au lieu de cela, je le conteneurise : docker-awsebcli
.
Restez à l'écoute pour le prochain numéro !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!