Docker 的开发:第 3 集(开发.Docker...)

wufei1232025-01-16python2

docker 的开发:第 3 集

本篇是 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 集的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。