Docker 的开发:第 3 集(开发.Docker...)
本篇是 Ruby on Rails 应用 Docker 化系列的最终篇章。我们将学习如何在容器中执行日常任务。
运行 Rake 任务和 Rails 命令
运行 Rake 任务非常简单。镜像构建完成后,可使用 docker-compose 在容器内执行命令。例如,查看应用路由:
$ docker-compose run web rails routes
创建数据库、迁移和填充数据:
$ docker-compose run web rails db:create db:migrate db:seed
运行测试套件则需要先创建测试数据库:
$ docker-compose run web rails db:create db:migrate RAILS_ENV=test
然后运行测试套件(假设默认 Rake 任务为 rake test):
$ docker-compose run web rake
小技巧:创建自定义脚本/别名
如果经常执行 docker-compose run web rails ... 命令,可以创建一个脚本并将其添加到 $PATH 中,简化操作:
#!/bin/bash docker-compose run web rails "$@"
注意:此脚本假设 docker-compose.yml 文件包含名为 web 的服务。否则无法正常运行。
执行其他任务
大多数命令都可直接在 web 服务中运行。但对于一些复杂任务(例如将预先存在的数据库加载到容器数据库中)则需要其他方法。
PostgreSQL 有两种加载方法,取决于转储文件的格式(旧版 --format=c 转储和常规转储)。
假设有一个 latest.dump 文件(包含 c 格式的 PostgreSQL 转储),需要将其加载到正在运行的容器中。首先需要获取容器 ID:
$ docker container ls
或
$ docker ps
获得容器 ID 后(例如 80f8041db4b4),使用以下命令恢复转储:
$ docker exec -i 80f8041db4b4 pg_restore -d app_development -U postgres < latest.dump
对于常规转储(例如 latest.sql):
$ docker exec -i 80f8041db4b4 psql -d app_development -U postgres < latest.sql
使用 docker-compose 会更便捷:
$ docker-compose exec -T db pg_restore -d app_development -U postgres < latest.dump
Docker 化一切!
我经常使用 Elastic Beanstalk。虽然通常使用 Homebrew 安装,但这会安装许多依赖项(例如 Python、SQLite 等)。为了避免这些依赖项(特别是 Python 版本冲突),我将其 Docker 化为 docker-awsebcli。
敬请期待下一集!
以上就是Docker 的开发:第 3 集的详细内容,更多请关注知识资源分享宝库其它相关文章!