登录
首页 >  文章 >  python教程

Docker 的开发:第 3 集

时间:2025-01-15 11:00:45 442浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《Docker 的开发:第 3 集》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下,希望所有认真读完的童鞋们,都有实质性的提高。

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 集》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>