首页 > 后端开发 > Python教程 > Docker 的开发:第 3 集

Docker 的开发:第 3 集

Mary-Kate Olsen
发布: 2025-01-10 07:58:41
原创
753 人浏览过

Docker in development: Episode 3

上一期我们讲解了如何将 Ruby on Rails 应用容器化。本期我们将探索如何在容器中执行日常任务。

运行 Rake 任务和 Rails 命令

运行 Rake 任务很简单。构建镜像后,可以使用 docker-compose 在其中运行命令。例如,如果要查看应用程序的路由:

<code class="language-bash">$ docker-compose run web rails routes</code>
登录后复制

同样,如果要创建数据库、迁移和填充数据:

<code class="language-bash">$ docker-compose run web rails db:create db:migrate db:seed</code>
登录后复制

如果要运行测试套件,则必须创建测试数据库:

<code class="language-bash">$ docker-compose run web rails db:create db:migrate RAILS_ENV=test</code>
登录后复制

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

<code class="language-bash">$ docker-compose run web rake</code>
登录后复制

提示:创建自定义脚本/别名

我一天要运行 docker-compose run web rails ... 数百次,为了简化操作,我把这个脚本放在我的 $PATH 中:

<code class="language-bash">#!/bin/bash
docker-compose run web rails "$@"</code>
登录后复制

请注意,此脚本假设您的 docker-compose.yml 文件具有 web 服务。如果没有,则无法运行。

执行其他任务

到目前为止,所有命令都非常简单明了,您只需在 web 服务中运行它们即可。那么,对于一些比较困难的任务,例如将预先存在的数据库加载到容器的数据库中,该如何处理呢?这是我花较长时间才弄清楚的任务之一。

在 PostgreSQL 中,有两种方法可以做到这一点,这取决于转储文件的格式。过去,我们不得不处理 --format=c 转储和常规转储。

假设您有一个包含 c 格式 PostgreSQL 转储的 latest.dump 文件,并且您想将其加载到(正在运行的)容器中,首先您必须找出容器 ID。您可以通过运行以下命令来实现:

<code class="language-bash">$ docker container ls</code>
登录后复制

<code class="language-bash">$ docker ps</code>
登录后复制

获得容器 ID 后(在此示例中,我们将使用 80f8041db4b4),您可以运行以下命令以在容器中恢复转储:

<code class="language-bash">$ docker exec -i 80f8041db4b4 pg_restore -d app_development -U postgres</code>
登录后复制

如果您有常规转储(例如 latest.sql),则可以使用以下命令将其恢复:

<code class="language-bash">$ docker exec -i 80f8041db4b4 psql -d app_development -U postgres</code>
登录后复制

如果您使用的是 docker-compose,事情会变得更容易:

<code class="language-bash">$ docker-compose exec -T db pg_restore -d app_development -U postgres</code>
登录后复制

所有内容都容器化!

我经常使用 Elastic Beanstalk。我通常使用 Homebrew 安装它,但它会安装许多它自己的依赖项,例如 Python、SQLite 等。我不希望所有这些都在我的系统中,尤其是我总是遇到 Python 版本问题。相反,我将其容器化:docker-awsebcli

敬请期待下一期!

以上是Docker 的开发:第 3 集的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板