Elastic Beanstalk 上预配置的 Docker GlassFish 容器
注意
2022 年 7 月 18 日,Elastic Beanstalk 将基于 Amazon Linux AMI(AL1)的所有平台分支的状态设置为已停用。有关迁移到当前且完全受支持的 Amazon Linux 2023 平台分支的更多信息,请参阅 将 Elastic Beanstalk Linux 应用程序迁移到 Amazon Linux 2023 或 Amazon Linux 2。
Amazon Linux AMI (AL1) 上运行的预配置 Docker GlassFish 平台分支不再受支持。要将 GlassFish 应用程序迁移到受支持的 Amazon Linux 2023 平台,请将 GlassFish 和您的应用程序代码部署到 Amazon Linux 2023 Docker 映像。有关更多信息,请参阅以下主题:将 GlassFish 应用程序部署到 Docker 平台:迁移到 Amazon Linux 2023 的路径。
本部分介绍如何在本地开发示例应用程序,然后使用预配置的 Docker 容器将应用程序部署到 Elastic Beanstalk。
设置本地开发环境
对于本演练,我们使用 GlassFish 示例应用程序。
设置环境
-
为示例应用程序创建新文件夹。
~$mkdir eb-preconf-example~$cd eb-preconf-example -
将示例应用程序代码下载到新文件夹。
~$wget https://docs.aws.amazon.com/elasticbeanstalk/latest/dg/samples/docker-glassfish-v1_cn.zip~$unzip docker-glassfish-v1_cn.zip~$rm docker-glassfish-v1_cn.zip
在本地开发和测试
开发示例 GlassFish 应用程序
-
将
Dockerfile添加到应用程序的根目录文件夹。在该文件中,指定要用于运行本地预配置 Docker 容器的 Amazon Elastic Beanstalk Docker 基础映像。稍后,您将应用程序部署到 Elastic Beanstalk 预配置的 Docker GlassFish 平台版本。选择此平台版本使用的 Docker 基本映像。要了解此平台版本的当前 Docker 映像的更多信息,请参阅《Amazon Elastic Beanstalk 平台》指南中的 Amazon Elastic Beanstalk 支持的平台页面的预配置的 Docker 部分。例 ~/Eb-preconf-example/Dockerfile
# For Glassfish 5.0 Java 8 FROM amazon/aws-eb-glassfish:5.0-al-onbuild-2.11.1有关使用
Dockerfile的更多信息,请参阅准备 Docker 映像以部署到 Elastic Beanstalk。 -
构建 Docker 映像。
~/eb-preconf-example$docker build -t my-app-image . -
从该映像运行 Docker 容器。
注意
必须包含
-p标记才能将容器中的端口 8080 映射到 localhost 端口 3000。Elastic Beanstalk Docker 容器始终在容器上的端口 8080 上公开应用程序。-it标志将映像作为交互式进程运行。当容器存在时,--rm标志将清理容器文件系统。您可以选择包含-d标志以将映像作为守护程序运行。$docker run -it --rm -p 3000:8080 my-app-image -
要查看示例应用程序,请将以下 URL 键入您的 Web 浏览器。
http://localhost:3000
部署到 Elastic Beanstalk
在测试应用程序后,可随时将其部署到 Elastic Beanstalk。
将应用程序部署到 Elastic Beanstalk
-
在应用程序的根文件夹中,将
Dockerfile重命名为Dockerfile.local。Elastic Beanstalk 若要使用Dockerfile,则必须执行此步骤,该文件中包含关于 Elastic Beanstalk 在 Elastic Beanstalk 环境中的每个 Amazon EC2 实例上构建自定义 Docker 映像的正确说明。注意
如果您的
Dockerfile包含修改平台版本的基础 Docker 映像的指令,则无需执行此步骤。如果您的Dockerfile仅包含用来指定从中构建容器的基本映像的Dockerfile行,则完全无需使用FROM。在这种情况下,Dockerfile是冗余的。 -
创建应用程序源包。
~/eb-preconf-example$zip myapp.zip -r * -
使用下面的预配置链接打开 Elastic Beanstalk 控制台:console.aws.amazon.com/elasticbeanstalk/home#/newApplication?applicationName=tutorials&environmentType=LoadBalanced
-
对于 Platform (平台),在 Preconfigured – Docker (预配置 – Docker) 下,选择 Glassfish。
-
对于 Application code (应用程序节点),选择 Upload your code (上传您的节点),然后选择 Upload (上传)。
-
选择 Local file (本地文件),再选择 Browse (浏览),然后打开您刚刚创建的应用程序源包。
-
选择 Upload。
-
选择复查并启动。
-
查看可用设置并选择 Create app (创建应用程序)。
-
创建环境后,您可以查看已部署的应用程序。选择控制台控制面板顶部显示的环境 URL。
将 GlassFish 应用程序部署到 Docker 平台:迁移到 Amazon Linux 2023 的路径
本教程的目标是为使用预配置 Docker GlassFish 平台(基于 Amazon Linux AMI)的客户提供迁移到 Amazon Linux 2023 的路径。可以通过将 GlassFish 和您的应用程序代码部署到 Amazon Linux 2023 Docker 映像,将 GlassFish 应用程序迁移到 Amazon Linux 2023。
本教程指导您使用 Amazon Elastic Beanstalk Docker 平台将基于 Java EE GlassFish 应用程序服务器
我们演示两种构建 Docker 映像的方法:
-
简单 – 提供您的 GlassFish 应用程序源代码,并让 Elastic Beanstalk 构建和运行 Docker 映像,作为预配置环境的一部分。这很容易设置,但代价是增加实例预置时间。
-
高级 – 构建包含应用程序代码和依赖关系的自定义 Docker 映像,并将其提供给 Elastic Beanstalk 以在您的环境中使用。这种方法的参与度稍高一些,并减少了环境中实例的预置时间。
先决条件
本教程假设您对基本 Elastic Beanstalk 操作、Elastic Beanstalk 命令行界面(EB CLI)和 Docker 有一定了解。如果尚不了解,请按照了解如何开始使用 Elastic Beanstalk中的说明操作以启动您的第一个 Elastic Beanstalk 环境。本教程使用 EB CLI,但您也可以使用 Elastic Beanstalk 控制台创建环境并上传应用程序。
要完成本教程,您需要做以下 Docker 组件:
要了解有关在 Elastic Beanstalk 平台上配置 Docker 环境的更多信息,请参阅同一章中的准备 Docker 映像以部署到 Elastic Beanstalk。
简单示例:提供您的应用程序代码
这是一种部署 GlassFish 应用程序的简单方法。提供您的应用程序源代码以及本教程中包含的 Dockerfile。Elastic Beanstalk 构建一个包含应用程序和 GlassFish 软件堆栈的 Docker 映像。然后,Elastic Beanstalk 在环境实例上运行该映像。
此方法的一个问题是,无论 Elastic Beanstalk 何时为您的环境创建实例,都会在本地构建 Docker 映像。映像构建会增加实例预置时间。这种影响不限于初始环境创建,也会在扩展操作期间发生。
使用示例 GlassFish 应用程序启动环境
-
下载示例
docker-glassfish-al2-v1.zip,然后将.zip文件展开到开发环境的目录中。~$curl https://docs.aws.amazon.com/elasticbeanstalk/latest/dg/samples/docker-glassfish-al2-v1.zip --output docker-glassfish-al2-v1.zip~$mkdir glassfish-example~$cd glassfish-example~/glassfish-example$unzip ../docker-glassfish-al2-v1.zip您的目录结构应如下所示。
~/glassfish-example |-- Dockerfile |-- Dockerrun.aws.json |-- glassfish-start.sh |-- index.jsp |-- META-INF | |-- LICENSE.txt | |-- MANIFEST.MF | `-- NOTICE.txt |-- robots.txt `-- WEB-INF `-- web.xml以下文件是在环境中构建和运行 Docker 容器的关键:
-
Dockerfile– 提供 Docker 用于构建具有应用程序和所需依赖关系的映像的说明。 -
glassfish-start.sh– Docker 映像运行以启动应用程序的 Shell 脚本。 -
Dockerrun.aws.json– 提供日志记录密钥,以便在日志文件请求中包含 GlassFish 应用程序服务器日志。如果您对 GlassFish 日志不感兴趣,可以忽略此文件。
-
-
为到 Elastic Beanstalk 的部署配置本地目录。
~/glassfish-example$eb init -p dockerglassfish-example -
(可选)使用 eb local run 命令在本地生成并运行您的容器。
~/glassfish-example$eb local run --port 8080 -
(可选)当您的容器正在运行时,可使用 eb local open 命令在 Web 浏览器中查看您的应用程序。或者,在 Web 浏览器中打开 http://localhost:8080/
。 ~/glassfish-example$eb local open -
使用 eb create 命令创建环境并部署应用程序。
~/glassfish-example$eb createglassfish-example-env -
启动环境后,使用 eb open 命令在 Web 浏览器中查看它。
~/glassfish-example$eb open
完成使用该示例后,终止环境并删除相关资源。
~/glassfish-example$eb terminate --all
高级示例:提供预构建的 Docker 映像
这是部署 GlassFish 应用程序的更高级方法。基于第一个示例,您创建一个包含应用程序代码和 GlassFish 软件堆栈的 Docker 映像,然后将其推送到 Docker Hub。完成此一次性步骤后,您可以根据自定义映像启动 Elastic Beanstalk 环境。
当您启动环境并提供 Docker 映像时,环境中的实例会直接下载并使用此映像,而不需要构建 Docker 映像。因此,实例预置时间会减少。
备注
以下步骤将创建一个公开可用的 Docker 映像。
您将使用本地安装的 Docker 中的 Docker 命令以及 Docker Hub 凭据。有关更多信息,请参阅本主题中的前面的先决条件部分。
使用预构建的 GlassFish 应用程序 Docker 映像启动环境
-
下载并展开示例
docker-glassfish-al2-v1.zip,如前面的简单示例所示。如果您已完成该示例,则可以使用已有的目录。 -
构建一个 Docker 映像并将其推送到 Docker Hub。为
docker-id输入您的 Docker ID,以登录到 Docker Hub。~/glassfish-example$docker build -t~/glassfish-example$docker-id/beanstalk-glassfish-example:latest .docker pushdocker-id/beanstalk-glassfish-example:latest注意
在推送映像之前,您可能需要运行 docker login。如果您运行不带参数的命令,系统将提示您输入 Docker Hub 凭据。
-
创建其他目录。
~$mkdir glassfish-prebuilt~$cd glassfish-prebuilt -
将以下示例复制到名为
Dockerrun.aws.json的文件中。例
~/glassfish-prebuilt/Dockerrun.aws.json{ "AWSEBDockerrunVersion": "1", "Image": { "Name": "docker-username/beanstalk-glassfish-example" }, "Ports": [ { "ContainerPort": 8080, "HostPort": 8080 } ], "Logging": "/usr/local/glassfish5/glassfish/domains/domain1/logs" } -
为到 Elastic Beanstalk 的部署配置本地目录。
~/glassfish-prebuilt$eb init -p dockerglassfish-prebuilt$ -
(可选)使用 eb local run 命令在本地运行容器。
~/glassfish-prebuilt$eb local run --port 8080 -
(可选)当您的容器正在运行时,可使用 eb local open 命令在 Web 浏览器中查看您的应用程序。或者,在 Web 浏览器中打开 http://localhost:8080/
。 ~/glassfish-prebuilt$eb local open -
使用 eb create 命令创建环境并部署 Docker 映像。
~/glassfish-prebuilt$eb createglassfish-prebuilt-env -
启动环境后,使用 eb open 命令在 Web 浏览器中查看它。
~/glassfish-prebuilt$eb open
完成使用该示例后,终止环境并删除相关资源。
~/glassfish-prebuilt$eb terminate --all