本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
将 GlassFish 应用程序部署到 Docker 平台:2023 年亚马逊 Linux 的迁移之路
本教程的目标是为使用预配置的 Docker GlassFish 平台(基于亚马逊 Linux AMI)的客户提供向亚马逊 Linux 2023 的迁移路径。您可以通过部署 GlassFish 将 GlassFish 应用程序迁移到亚马逊 Linux 2023,将应用程序代码迁移到亚马逊 Linux 2023 Docker 镜像。
本教程将引导你使用 Amazon Elastic Beanstalk Docker 平台将基于 Java EE 应用服务器的应用程序部署到 E 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 配置。
简单示例:提供您的应用程序代码
这是部署 GlassFish 应用程序的简便方法。提供您的应用程序源代码以及本教程中包含的 Dockerfile
。Elastic Beanstalk 会生成一个 Docker 镜像,其中包含你的应用程序和软件堆栈。 GlassFish 然后,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 docker
glassfish-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 create
glassfish-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 push
docker-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 docker
glassfish-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 create
glassfish-prebuilt-env
-
启动环境后,使用 eb open 命令在 Web 浏览器中查看它。
~/glassfish-prebuilt$
eb open
完成使用该示例后,终止环境并删除相关资源。
~/glassfish-prebuilt$
eb terminate --all