你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn。
在 Azure Red Hat OpenShift 上部署 WebSphere Liberty 和 Open Liberty
本文介绍如何在 Azure Red Hat OpenShift 上快速建立 IBM WebSphere Liberty 和 Open Liberty。
本文使用 Open/WebSphere Liberty 的 Azure 市场产品/服务加速你的 Azure Red Hat OpenShift 之旅。 产品/服务会自动预配多个资源,包括带有内置 OpenShift 容器注册表 (OCR)、Liberty Operator 的 Azure Red Hat OpenShift 群集,以及(可选)包括 Liberty 和你的应用程序的容器映像。 若要查看该产品/服务,请访问 Azure 门户。 如果你想要通过手动分步指南了解如何在不使用产品/服务启用的自动化的 Azure Red Hat OpenShift 上运行 Liberty,请参阅在 Azure Red Hat OpenShift 群集上使用 Open Liberty/WebSphere Liberty 手动部署 Java 应用程序。
本文旨在帮助你快速进行部署。 在进入生产环境之前,应探索 Tuning Liberty。
如果你有兴趣提供反馈或与开发 WebSphere on Azure 解决方案的工程团队就迁移方案展开密切合作,请填写这份简短的有关 WebSphere 迁移的调查并提供联系人信息。 项目经理、架构师和工程师团队会及时与你联系,以开展密切合作。
重要
Azure Red Hat OpenShift 由 Red Hat 和 Microsoft 联合设计、运营和支持,以提供集成的支持体验,但在 Azure Red Hat OpenShift 上运行的软件(包括本文中描述的软件)受其自身的支持和许可条款的约束。 有关 Azure Red Hat OpenShift 的支持详细信息,请参阅 Azure Red Hat OpenShift 4 的支持生命周期。 有关本文中所述软件支持的详细信息,请查看本文中列出的相应软件的主页。
注意
Azure Red Hat OpenShift 至少需要 40 个核心才能创建和运行 OpenShift 群集。 新 Azure 订阅的默认 Azure 资源配额不满足此要求。 若要请求增加资源限制,请参阅增加 VM 系列 vCPU 配额中请求增加不可调整配额的部分。 由于需要请求增加的配额类型是“不可调整的”,因此必须提交支持票证。 请求增加不可调整配额的步骤显示如何使用正确的内容提交票证。
免费试用订阅不符合增加配额的条件。 在请求增加配额之前升级到即用即付订阅。 有关详细信息,请参阅升级 Azure 免费帐户或面向学生的 Azure 入门版帐户。
先决条件
- Azure 订阅。 如果没有 Azure 订阅,请在开始之前创建一个 Azure 免费帐户。
- 一台安装了类似于 Unix 的操作系统(例如 Ubuntu、macOS 或适用于 Linux 的 Windows 子系统)的本地计算机。
- Azure CLI。 如果在 Windows 或 macOS 上运行,请考虑在 Docker 容器中运行 Azure CLI。 有关详细信息,请参阅如何在 Docker 容器中运行 Azure CLI。
- 通过使用 az login 命令登录到 Azure CLI。 若要完成身份验证过程,请遵循终端中显示的步骤。 有关其他登录选项,请参阅使用 Azure CLI 登录到 Azure。
- 出现提示时,请在首次使用时安装 Azure CLI 扩展。 有关扩展详细信息,请参阅使用和管理 Azure CLI 的扩展。
- 运行 az version 以查找安装的版本和依赖库。 若要升级到最新版本,请运行 az upgrade。 本文需要的 Azure CLI 最低版本为 2.61.0。
- Java Standard Edition (SE) 实施版本 17(例如 Eclipse Open J9)。
- Maven 版本 3.9.8 或更高版本。
- 用于 OS 的 Docker。
- 用于登录的 Azure 标识具有当前订阅中的参与者角色、用户访问管理员角色或所有者角色。 有关 Azure 角色的概述,请参阅 什么是 Azure 基于角色的访问控制 (Azure RBAC)?
获取 Red Hat 拉取机密
本文中使用的 Azure 市场产品/服务需要 Red Hat 拉取机密。 本部分介绍如何获取 Azure Red Hat OpenShift 的 Red Hat 拉取机密。 要了解什么是 Red Hat 拉取机密以及为什么需要它,请参阅创建 Azure Red Hat OpenShift 4 群集的获取 Red Hat 拉取机密部分。 若要获取要使用的拉取机密,请按照本部分中的步骤进行操作。
访问 Red Hat OpenShift 混合云控制台,使用 Red Hat 帐户登录 OpenShift 群集管理器门户。 可能需要接受更多条款并更新帐户,如以下屏幕截图所示。 使用与创建帐户时相同的密码。
登录后,选择“OpenShift”,然后选择“下载”。 选择“所有类别”下拉列表,然后选择“令牌”。 在“拉取机密”下,选择“复制”或“下载”,如以下屏幕截图所示。
以下内容是从 Red Hat 控制台门户复制的示例,其中身份验证代码替换为 xxxx...xxx
。
{"auths":{"cloud.openshift.com":{"auth":"xxxx...xxx","email":"contoso-user@contoso.com"},"quay.io":{"auth":"xxx...xxx","email":"contoso-user@test.com"},"registry.connect.redhat.com":{"auth":"xxxx...xxx","email":"contoso-user@contoso.com"},"registry.redhat.io":{"auth":"xxxx...xxx","email":"contoso-user@contoso.com"}}}
将机密保存到文件中,以便稍后使用。
从 Azure 门户创建 Microsoft Entra 服务主体
本文中使用的 Azure 市场产品/服务需要 Microsoft Entra 服务主体才能部署 Azure Red Hat OpenShift 群集。 该产品/服务会在部署期间为服务主体分配适当的权限,无需进行角色分配。 如果已准备好使用服务主体,请跳过此部分并转到下一部分,在其中部署产品/服务。
使用以下步骤部署服务主体并从 Azure 门户获取其应用程序(客户端)ID 和机密。 有关详细信息,请参阅创建并使用服务主体来部署 Azure Red Hat OpenShift 群集。
注意
你必须具有足够的权限,才能向你的 Microsoft Entra 租户注册应用程序。 如果遇到问题,请查看所需权限,确保帐户可以创建标识。 有关详细信息,请参阅注册 Microsoft Entra 应用并创建服务主体。
通过 Azure 门户登录到 Azure 帐户。
选择“Microsoft Entra ID”。
选择“应用注册” 。
选择“新注册”。
为应用程序命名,例如“liberty-on-aro-app”。 选择支持的帐户类型,它决定了谁可以使用应用程序。 设置好值后,选择“注册”,如以下屏幕截图所示。 预配应用程序需要几秒钟时间。 等待部署完成,然后再继续。
从概述页保存应用程序(客户端)ID,如以下屏幕截图所示。 将指针悬停在该值(在屏幕截图中已编辑)上,然后选择出现的复制图标。 工具提示将显示“复制到剪贴板”。 请注意复制正确的值,因为该部分中的其他值也有复制图标。 将应用程序 ID 保存到文件中,以便稍后使用。
按照以下步骤创建新的客户端密码:
- 选择“证书和机密”。
- 选择“客户端密码”,然后选择“新建客户端密码”。
- 提供机密的说明和持续时间。 完成后,选择“添加”。
- 添加客户端密码后,将显示客户端密码的值。 请复制此值,因为以后无法检索此值。
你现在拥有 Microsoft Entra 应用程序、服务主体和客户端密码。
在 Azure Red Hat OpenShift 上部署 IBM WebSphere Liberty 或 Open Liberty
本部分中的步骤将指导你在 Azure Red Hat OpenShift 上部署 IBM WebSphere Liberty 或 Open Liberty。
以下步骤演示了如何查找产品/服务并填写“基本信息”窗格。
在 Azure 门户顶部的搜索栏中输入“Liberty”。 在自动建议的搜索结果中的“市场”部分,选择“WebSphere Liberty/Open Liberty on OpenShift”,如以下屏幕截图所示。
还可以使用此门户链接直接转到该服务。
在产品/服务页面,选择“创建”。
在“基本信息”窗格中,确保“订阅”字段中显示的值与先决条件部分中列出的角色的值相同。
在“资源组”字段中,选择“新建”,然后填写资源组的值。 由于资源组在订阅中必须是唯一的,因此请选择一个唯一名称。 拥有唯一名称的一种简单方法是使用首字母缩写、今天的日期和一些标识符的组合(例如 abc1228rg)。
在 shell 中为群集的资源组名称创建环境变量。
export RESOURCE_GROUP_NAME=<your-resource-group-name>
在“实例详细信息”下,选择部署的区域。 有关运行 OpenShift 的 Azure 区域的列表,请参阅 Azure 上的 Red Hat OpenShift 4.x 的区域。
选择区域后,选择“下一步”。
以下步骤演示如何填写 ARO 窗格,如以下屏幕截图所示:
在“创建新群集”下,选择“是”。
在“提供信息以创建新群集”下,对于“Red Hat 拉取机密”,填写在“获取 Red Hat 拉取机密”部分中获取的 Red Hat 拉取机密。 对“确认机密”使用相同的值。
使用在从 Azure 门户创建 Microsoft Entra 服务主体部分中获取的服务主体应用程序(客户端)ID 填写服务主体客户端 ID。
使用在从 Azure 门户创建 Microsoft Entra 服务主体部分中获取的服务主体应用程序密码填写服务主体客户端密码。 对“确认机密”使用相同的值。
填写值后,选择“下一步”。
以下步骤演示如何填写“运算符和应用程序”窗格(如以下屏幕截图所示),然后开始部署。
在“IBM 支持?”下,选择“是”。
注意
本快速入门部署 IBM 支持的 WebSphere Liberty Operator,但你可以选择“否”来部署 Open Liberty Operator。
保留“部署应用程序?”的默认“否”选项。
注意
本快速入门稍后手动部署示例应用程序,但如果需要,可以为“部署应用程序?”选择“是”。
选择“查看 + 创建”。 确保绿色的“验证通过”消息显示在顶部。 如果未显示该消息,请解决所有验证问题,然后选择“查看 + 创建”。
选择创建。
在“部署正在进行”页面跟踪部署进度。
根据所选区域中的网络状况和其他活动,部署可能需要长达 40 分钟才能完成。
验证部署功能
本部分中的步骤演示了如何验证部署已成功完成。
如果你已离开“部署正在进行”页面,后续步骤将演示如何返回该页面。 如果你仍在显示“部署已完成”的页面上,则可以跳到步骤 5。
在任何门户页面的一角,选择汉堡菜单,然后选择“资源组”。
在包含文本“筛选任何字段”的框中,输入之前创建的资源组的前几个字符。 如果遵循了建议的约定,请输入缩写,然后选择相应的资源组。
在导航窗格的“设置”部分,选择“部署”。 你将看到此资源组的部署的有序列表,最新的部署在最前面。
滚动到此列表中最早的条目。 此条目对应于在上一部分中启动的部署。 选择最早的部署,如以下屏幕截图所示。
在导航窗格中,选择“输出”。 此列表显示部署的输出值,其中包括一些有用的信息。
打开终端,粘贴 cmdToGetKubeadminCredentials 字段中的值。 将看到用于登录 OpenShift 群集控制台门户的管理员帐户和凭据。 以下内容是管理员帐户的示例。
az aro list-credentials --resource-group abc1228rg --name clusterf9e8b9 { "kubeadminPassword": "xxxxx-xxxxx-xxxxx-xxxxx", "kubeadminUsername": "kubeadmin" }
将 clusterConsoleUrl 字段中的值粘贴到连接到 Internet 的 Web 浏览器中,然后按 Enter。 填写管理员用户名和密码,并登录。
验证是否安装了适用于 Liberty 的相应 Kubernetes 运算符。 在导航窗格中,选择“运算符”,然后选择“安装运算符”,如以下屏幕截图所示:
如果安装了 WebSphere Liberty 运算符或 Open Liberty 运算符,请记下。 运算符变体与在部署时选择的内容匹配。 如果选择“IBM 支持”,则拥有 WebSphere Liberty 运算符。 否则,就拥有 Open Liberty 运算符。 在后续步骤中,此信息非常重要。
按照教程安装 OpenShift CLI 中的步骤下载并安装 OpenShift CLI
oc
,然后返回到本文档。切换到“输出”窗格,复制 cmdToLoginWithKubeadmin 字段中的值,然后将其粘贴到终端中。 运行命令登录到 OpenShift 群集的 API 服务器。 在控制台中应会看到类似于以下示例的输出:
Login successful. You have access to 71 projects, the list has been suppressed. You can list all projects with 'oc projects' Using project "default".
创建 Azure SQL 数据库
以下步骤将指导你创建 Azure SQL 数据库单一数据库,以便与你的应用配合使用:
按照快速入门:创建 Azure SQL 数据库单一数据库中的步骤在 Azure SQL 数据库中创建单一数据库,并仔细注意以下说明中的差别。 可以将数据库部署到与 OpenShift 群集相同的资源组。 创建并配置数据库服务器后,返回到本文。
在 shell 中为数据库的资源组名称创建环境变量。
export DB_RESOURCE_GROUP_NAME=<db-resource-group>
注意
本文介绍如何创建使用 SQL 身份验证的 Azure SQL 数据库单一数据库。 更安全的做法是使用 Azure SQL 的 Microsoft Entra 身份验证来对数据库服务器连接进行身份验证。 Azure Red Hat OpenShift 目前不支持 Microsoft Entra 工作负载 ID,因此 SQL 身份验证是唯一可用的选项。
创建数据库和 Azure Red Hat OpenShift 群集后,便可以准备 Azure Red Hat OpenShift 群集来托管 WebSphere Liberty 应用程序。
配置和部署示例应用程序
按照本部分中的步骤将示例应用程序部署到 Liberty 运行时。 这些步骤使用 Maven。
签出应用程序
使用以下命令克隆本指南的示例代码。 该示例位于 GitHub 上。
git clone https://github.com/Azure-Samples/open-liberty-on-aro.git
cd open-liberty-on-aro
export BASE_DIR=$PWD
git checkout 20240920
cd 3-integration/connect-db/mssql
如果看到消息显示正处于“拆离的 HEAD”状态,可以放心地忽略此消息。 这只标识你签出了一个标签。
存储库中有一些示例。 我们使用 3-integration/connect-db/mssql/。 下面是应用程序的文件结构:
mssql
├─ src/main/
│ ├─ aro/
│ │ ├─ db-secret.yaml
│ │ ├─ openlibertyapplication.yaml
│ │ ├─ webspherelibertyapplication.yaml
│ ├─ docker/
│ │ ├─ Dockerfile
│ │ ├─ Dockerfile-ol
│ ├─ liberty/config/
│ │ ├─ server.xml
│ ├─ java/
│ ├─ resources/
│ ├─ webapp/
├─ pom.xml
目录“java”、“resources”和“webapp”包含示例应用程序的源代码 。 代码声明并使用名为 jdbc/JavaEECafeDB
的数据源。
aro 目录中有三个部署文件。 db-secret.xml 用于创建包含数据库连接凭据的 Kubernetes Secret。 本快速入门使用 webspherelibertyapplication.yaml 文件来部署 WebSphere Liberty 应用程序。 如果在 Azure Red Hat OpenShift 上部署 IBM WebSphere Liberty 或 Open Liberty 部分中部署了 Open Liberty 运算符,请使用 openlibertyapplication.yaml 文件部署 Open Liberty 应用程序。
在 docker 目录中,有两个文件用于使用 Open Liberty 或 WebSphere Liberty 创建应用程序映像。 这些文件分别是 Dockerfile 和 Dockerfile-ol。 在本快速入门中,你使用 Dockerfile 文件构建包含 WebSphere Liberty 的应用程序映像。 同样,如果在 Azure Red Hat OpenShift 上部署 IBM WebSphere Liberty 或 Open Liberty 部分中部署了 Open Liberty Operator,请使用 Dockerfile-ol 文件生成包含 Open Liberty 的应用程序映像。
在目录 liberty/config中,server.xml 文件用于配置 Open Liberty 和 WebSphere Liberty 群集的数据库连接。
生成项目
收集必要的属性后,可以使用以下命令生成应用程序。 项目的 POM 文件从环境中读取多个变量。 在 Maven 生成中,这些变量用于填充位于 src/main/aro 中的 YAML 文件中的值。 如果需要,可以在 Maven 外部为应用程序执行类似操作。
cd ${BASE_DIR}/3-integration/connect-db/mssql
# The following variables are used for deployment file generation into target.
export DB_SERVER_NAME=<server-name>.database.windows.net
export DB_NAME=<database-name>
export DB_USER=<server-admin-login>@<server-name>
export DB_PASSWORD=<server-admin-password>
mvn clean install
(可选)在本地测试项目
现在可以在部署到 Azure 之前,可以使用以下步骤在本地运行和测试项目。 为方便起见,我们使用 liberty-maven-plugin
。 如需详细了解 liberty-maven-plugin
,请参阅使用 Maven 构建 Web 应用程序。 对于你的应用程序,可以使用任何其他机制(例如本地 IDE)执行类似操作。 还可以考虑使用用于容器开发的 liberty:devc
选项。 可以在 Liberty 文档中详细了解 liberty:devc
。
使用
liberty:run
启动应用程序,如以下示例所示。liberty:run
也会使用在上一节中定义的环境变量。cd ${BASE_DIR}/3-integration/connect-db/mssql mvn liberty:run
验证应用程序是否按预期运行。 如果成功,你应该会在命令输出中看到类似于
[INFO] [AUDIT] CWWKZ0003I: The application javaee-cafe updated in 1.930 seconds.
的消息。 在浏览器中转到http://localhost:9080/
或https://localhost:9443/
,验证应用程序是否可访问,所有功能是否正常运作。按 Ctrl+C 可停止。
接下来,使用以下步骤来使用 Docker 容器化项目,并将其作为容器在本地运行,然后再部署到 Azure:
使用以下命令生成映像:
cd ${BASE_DIR}/3-integration/connect-db/mssql/target docker buildx build --platform linux/amd64 -t javaee-cafe:v1 --pull --file=Dockerfile .
使用以下命令运行映像。 请注意,我们使用的是之前定义的环境变量。
docker run -it --rm -p 9080:9080 -p 9443:9443 \ -e DB_SERVER_NAME=${DB_SERVER_NAME} \ -e DB_NAME=${DB_NAME} \ -e DB_USER=${DB_USER} \ -e DB_PASSWORD=${DB_PASSWORD} \ javaee-cafe:v1
容器启动后,在浏览器中转到
http://localhost:9080/
或https://localhost:9443/
以访问应用程序。按 Ctrl+C 可停止。
生成映像并推送到映像流
对应用程序的状态感到满意时,请使用以下步骤在群集上远程生成映像。
使用以下命令确定源目录和 Dockerfile:
cd ${BASE_DIR}/3-integration/connect-db/mssql/target # If you are deploying the application with WebSphere Liberty Operator, the existing Dockerfile is ready for you # If you are deploying the application with Open Liberty Operator, uncomment and execute the following two commands to rename Dockerfile-ol to Dockerfile # mv Dockerfile Dockerfile.backup # mv Dockerfile-ol Dockerfile
使用以下命令创建图像流:
oc create imagestream javaee-cafe
使用以下命令创建生成配置,该配置可指定生成输出的映像流标记:
oc new-build --name javaee-cafe-config --binary --strategy docker --to javaee-cafe:v1
使用以下命令启动生成,以将本地内容上传、容器化以及输出到之前指定的映像流标记:
oc start-build javaee-cafe-config --from-dir . --follow
部署并测试应用程序
使用以下步骤部署并测试应用程序:
使用以下命令应用数据库机密:
cd ${BASE_DIR}/3-integration/connect-db/mssql/target oc apply -f db-secret.yaml
你应该可以看到输出
secret/db-secret-mssql created
:使用以下命令应用部署文件:
oc apply -f webspherelibertyapplication.yaml
使用以下命令等待所有 Pod 启动并成功运行:
oc get pods -l app.kubernetes.io/name=javaee-cafe --watch
应会看到类似于以下示例的输出,指示所有 Pod 正在运行:
NAME READY STATUS RESTARTS AGE javaee-cafe-67cdc95bc-2j2gr 1/1 Running 0 29s javaee-cafe-67cdc95bc-fgtt8 1/1 Running 0 29s javaee-cafe-67cdc95bc-h47qm 1/1 Running 0 29s
使用以下步骤验证结果:
清理资源
若要避免 Azure 费用,应清除不需要的资源。 如果不再需要群集,可以使用 az group delete 命令删除资源组、Azure Red Hat OpenShift 群集、 Azure SQL 数据库及所有相关资源。
az group delete --name $RESOURCE_GROUP_NAME --yes --no-wait
az group delete --name $DB_RESOURCE_GROUP_NAME --yes --no-wait
后续步骤
有关在 Azure 上部署 IBM WebSphere 系列产品的详细信息,请参阅哪些解决方案可在 Azure 上运行 WebSphere 系列产品?