您的位置 首页 知识分享

Docker 的开发:第 3 集

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

Docker 的开发:第 3 集

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

运行 Rake 任务和 Rails 命令

运行 Rake 任务非常简单。镜像构建完成后,可使用 -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 Beans。虽然通常使用 Homebrew 安装,但这会安装许多依赖项(例如 Python、SQLite 等)。为了避免这些依赖项(特别是 Python 版本冲突),我将其 Docker 化为 docker-awsebcli。

敬请期待下一集!

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

本文来自网络,不代表甲倪知识立场,转载请注明出处:http://www.spjiani.cn/wp/7873.html

作者: nijia

发表评论

您的电子邮箱地址不会被公开。

联系我们

联系我们

0898-88881688

在线咨询: QQ交谈

邮箱: email@wangzhan.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部