本站资源收集于互联网,不提供软件存储服务,每天免费更新优质的软件以及学习资源!

Docker的开发:第3集

网络教程 app 1℃

Docker的开发第3集

本篇是 Ruby on Rails 应用 Docker 化系列的最终篇章。我们将学习如何在容器中执行日常任务。

运行 Rake 任务和 Rails 命令

运行 Rake 任务非常简单。镜像构建完成后,可使用 docker-pose 在容器内执行命令。例如,查看应用路由:

$ docker-pose run web rails routes

创建数据库、迁移和填充数据:

$ docker-pose run web rails db:create db:migrate db:seed

运行测试套件则需要先创建测试数据库:

$ docker-pose run web rails db:create db:migrate RAILS_ENV=test

然后运行测试套件(假设默认 Rake 任务为 rake test):

$ docker-pose run web rake

小技巧:创建自定义脚本/别名

如果经常执行 docker-pose run web rails … 命令,可以创建一个脚本并将其添加到 $PATH 中,简化操作:

#!/bin/bashdocker-pose run web rails "$@"

注意:此脚本假设 docker-pose.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-pose 会更便捷:

$ docker-pose exec -T db pg_restore -d app_development -U postgres < latest.dump

Docker 化一切!

我经常使用 Elastic Beanstalk。虽然通常使用 Homebrew 安装,但这会安装许多依赖项(例如 Python、SQLite 等)。为了避免这些依赖项(特别是 Python 版本冲突),我将其 Docker 化为 docker-awsebcli。

敬请期待下一集!

以上就是Docker 的开发:第 3 集的详细内容,更多请关注范的资源库其它相关文章!

转载请注明:范的资源库 » Docker的开发:第3集

喜欢 (0)