Migrate to Containers CLI 版本说明
本页面记录了 Migrate to Containers CLI 的正式版更新。您可以定期查看此页面,了解有关新增功能、功能更新、问题修复、已知问题和弃用功能的公告。
2024 年 10 月 8 日
2024 年 10 月 8 日,我们发布了 Migrate to Containers CLI 1.2.3 版和 Migrate to Containers 现代化改造插件 1.4.2 版。
特性
添加了在 PowerShell Core (
pwsh.exe
) 中运行 Migrate to Containers CLI 的功能。所有插件都使用 DNS-1123 格式命名部署,以便与 Kubernetes 兼容。
使用自动过期和随机密码的临时用户,增强了 Windows IIS 迁移的安全性。
用于 WebSphere 应用现代化的新功能:
- 添加了 WebSphere 迁移计划字段的相关文档,以便在 Visual Studio Code 中使用自动补全功能。
- 缩短了执行 WebSphere 应用现代化所需的时间。
修复的问题
- 修复了与 CVE-2024-9858 相关的 bug。
- 修复了导致无法在 Windows IIS 应用的迁移计划中设置身份验证方法的 bug。
2024 年 1 月 3 日
2024 年 1 月 3 日,我们发布了 Migrate to Containers 现代化改造插件的 1.4.1 版本,其中包含 Tomcat 迁移的 bug 修复。
2023 年 12 月 4 日
2023 年 12 月 4 日,我们发布了 Migrate to Containers CLI 1.2.2 版。
已弃用
websphere-traditional
插件现已弃用。对于现有客户,此插件在 2023 年 12 月之前仍受支持,之后将无法使用。如果您是首次进行 WebSphere 工作负载现代化改造,请改为将 websphere-container
插件与 Migrate to Containers CLI 搭配使用。
2023 年 11 月 2 日
2023 年 11 月 2 日,我们发布了 Migrate to Containers CLI 1.2.1 版,其中包含 bug 修复。
2023 年 10 月 30 日
2023 年 10 月 30 日,我们发布了 Migrate to Containers CLI 1.2.0 版。
功能
添加了对离线迁移 Linux 应用的支持
Migrate to Containers CLI 现在支持使用新的离线模式,即使没有连接到互联网也能正常工作。借助离线模式,您可以在离线环境中迁移 Linux 应用。
如果本地环境(包括本地机器、源机器和部署集群)位于需要预先批准和安全扫描才能下载外部文件和二进制文件的安全网络中,这将非常有用。在离线模式下,我们通过添加文件捆绑和解绑选项,简化了从外部来源接收软件更新并将其传输到安全网络的过程。此外,您还可以指定一个本地且安全的注册表作为迁移应用所需工件的来源。
如需设置离线迁移,请在下载 Migrate to Containers CLI 后执行以下步骤:
下载离线 Migrate to Containers CLI 插件软件包:
curl -O https://storage.googleapis.com/modernize-plugins-prod/$(curl -s https://storage.googleapis.com/modernize-plugins-prod/latest)/m2c-offline-bundle-linux.tar
如果需要,请将 Migrate to Containers CLI 和离线 Migrate to Containers CLI 插件软件包复制到离线环境。
解压缩离线 Migrate to Containers CLI 插件软件包:
./m2c plugins unpack -i m2c-offline-bundle-linux.tar
如需添加对离线数据迁移的支持,请指定本地网络中可用的容器注册表:
./m2c plugins unpack -i m2c-offline-bundle-linux.tar --registry HOSTNAME
将 HOSTNAME 替换为容器注册表主机名。
如需了解详情,请参阅设置离线迁移。
2023 年 8 月 22 日
2023 年 8 月 22 日,我们发布了 Migrate to Containers CLI 1.1.0 版。
功能
新增了对 Windows IIS 服务迁移的支持
Migrate to Containers CLI 现在支持 Windows IIS 服务迁移。迁移 Windows IIS 服务需要在 Windows 机器上运行 Migrate to Containers CLI。
如需对 Windows IIS 服务进行现代化改造,请按照以下步骤操作:
-
例如,如需从 Compute Engine 导出映像,请先将映像导出到 Cloud Storage,然后在本地机器上下载映像:
gcloud compute images export \ --export-format vhdx \ --destination-uri DESTINATION_URI \ --image IMAGE_NAME gcloud storage cp DESTINATION_URI LOCAL_PATH
分析磁盘映像以创建迁移计划:
./m2c analyze \ -s PATH_TO_IMAGE \ -p windows-iis-container \ -o ANALYSIS_OUTPUT_PATH
通过磁盘映像和迁移计划生成迁移工件:
./m2c generate \ -i ANALYSIS_PATH \ -o OUTPUT_ARTIFACTS_PATH
增强了对 IBM WebSphere 应用迁移的支持
修改并扩展了 IBM WebSphere 支持。现有插件支持将 WebSphere Application Server 传统版作为迁移来源。添加了新插件,以支持将 WebSphere Application Server Liberty 作为迁移来源。
IBM WebSphere Application Server 传统版迁移的变化
IBM WebSphere Application Server 传统版迁移有以下更改:
websphere-traditional-container
插件现在用于迁移 IBM WebSphere Application Server 传统版工作负载。- 现在支持将 WebSphere Application Server Liberty 作为目标。
was-home
参数现在是必需参数,即使您使用 mFit 扫描源虚拟机也是如此。
如需迁移 IBM WebSphere Application Server 传统版工作负载,请运行以下命令:
./m2c analyze \ -s PATH_TO_COPIED_FILESYSTEM \ -p websphere-traditional-container -o ANALYSIS_OUTPUT_PATH \ -r was-home=PATH_TO_WAS_HOME \ --volume PATH_TO_BINARYAPPSCANNER:/binaryAppScanner.jar
如需了解详情,请参阅为 WebSphere 传统版工作负载创建迁移计划。
新增了对 IBM WebSphere Application Server Liberty 迁移的支持
WebSphere Application Server Liberty 的现代化改造现已随 websphere-container
插件正式发布。
如需迁移 IBM WebSphere Liberty 工作负载,请运行以下命令:
./m2c analyze \ -s PATH_TO_COPIED_FILESYSTEM \ -p websphere-container \ -o ANALYSIS_OUTPUT_PATH \ -r websphere-home=WEBSPHERE_HOME \ -r websphere-java-home=WEBSPHERE_JAVA_HOME -r target-base-image=TARGET_BASE_IMAGE
如需了解详情,请参阅为 WebSphere Application Server Liberty 工作负载创建迁移计划。
更新了 Tomcat 插件
Tomcat 插件的发现参数已更新。
java-version
参数现已作为输入添加到 Tomcat 迁移中。catalina-base
参数现在可以包含多个以英文冒号 (:
) 分隔的目录。java-version
、catalina-base
和catalina-home
参数现在是必需参数,即使您使用 mFit 扫描源虚拟机也是如此。
如需了解详情,请参阅为 Tomcat 工作负载创建迁移计划。
更新了 Linux 系统容器插件
在自定义 Linux 迁移计划时,系统不会再自动发现 Linux 系统服务端点,您并且必须手动指定,即使您使用 mFit 扫描源虚拟机也是如此。
固定
在早期版本的 Migrate to Containers CLI 中,尝试在 /tmp
目录中使用套接字时,copy
命令可能会失败。在此版本中,默认值已更改。如需自定义套接字位置,您可以设置 SOCKDIR
环境变量。
问题
Windows 映像的 Skaffold 构建可能会在 Windows 机器上失败,因为 Skaffold 尝试拉取错误目标的基础映像。
如需解决此问题,请使用
docker pull
命令手动拉取映像,然后再次运行 Skaffold 构建。由于超时较短,Windows IIS 工作负载的部署可能会被标记为未就绪。如果您使用 Skaffold 部署工作负载,则部署可能会显示为失败。
如需解决此问题,请使用 PowerShell 提高就绪性探测超时和时长:
foreach ($file in (Get-ChildItem . -Recurse -Include "deployment_spec.yaml")) { (Get-Content $file).replace("periodSeconds: 10", "periodSe conds: 30").replace("timeoutSeconds: 1", "timeoutSeconds: 10") | Set-Content $file }
2023 年 6 月 27 日
2023 年 6 月 27 日,我们发布了 Migrate to Containers CLI 1.0.0 版。
功能
升级了 Skaffold API 版本
Migrate to Containers CLI 现在使用 Skaffold API 版本 v4beta4
(而非版本 v2beta25
)生成 Skaffold 配置。
添加了对 Linux 虚拟机容器化的支持
现在,借助 Migrate to Containers CLI,您可以将 Linux 虚拟机迁移到系统容器。它会发现源应用文件并对其进行处理,以生成迁移工件,其中包括 Dockerfile、Kubernetes 清单和基于 Skaffold 的自动部署脚本。
Migrate to Containers CLI 使用预构建的 Linux 系统容器,它充当现代化应用所需服务的启动加载器。借助 Migrate to Containers CLI,您可以对一系列基于 Linux 的无状态应用进行现代化改造,以便在 GKE、Cloud Run 或 GKE Enterprise 集群上运行。
如需了解详情,请参阅为 Linux 虚拟机容器创建迁移计划。
增强了 copy
操作
copy
操作进行了以下改进:
Migrate to Containers CLI
copy
操作现在使用本地容器将来源虚拟机文件系统复制到本地目录,而不是使用本地 tar 文件。此增强功能无需在本地机器上安装rsync
,并减少了复制源机器文件系统所需的磁盘空间。在发生故障时,Migrate to Containers CLI 现在会从故障点继续复制过程。
如需了解详情,请参阅复制来源机器的文件系统。
添加了清理复制文件系统的功能
迁移完成后,您可以使用新的 cleanup
命令移除在本地机器上使用 copy
命令创建的源机器文件系统的副本,而不会遇到任何权限问题。
如需了解详情,请参阅清理本地机器。
添加了对数据迁移的支持
执行迁移后,您现在可以使用新的 migrate-data
命令将数据目录复制到目标集群上的新或现有永久性卷声明 (PVC) 中。
如果您可能需要将永久性数据目录从源虚拟机迁移到挂载在目标容器上的永久性卷,则必须执行此步骤。
如需了解详情,请参阅迁移数据。
2023 年 6 月 13 日
我们在 2023 年 6 月 13 日宣布 Migrate to Containers CLI 现在已正式发布。
借助 Migrate to Containers CLI,您可以将虚拟机上运行的应用组件现代化改造为在 GKE、GKE Autopilot、Cloud Run 或 GKE Enterprise 集群上运行的容器。
如需了解详情,请参阅在命令行中将应用迁移到基于容器的工作负载 | Google Cloud 博客。
2023 年 5 月 2 日
2023 年 5 月 2 日,我们发布了 Migrate to Containers CLI 0.2.0 版(预览版)。借助 Migrate to Containers CLI,您可以将虚拟机上运行的应用组件现代化改造为在 GKE、GKE Autopilot、Cloud Run 或 GKE Enterprise 集群上运行的容器。该工具提供了简化的流程,包括 4 个主要步骤:
- 使用 SSH 或 gcloud CLI 从源虚拟机复制应用文件。
- 分析应用文件的本地副本以生成迁移计划。
- 修改迁移计划文件以自定义迁移计划。
- 生成作为容器映像、部署 YAML 和 Skaffold 配置文件的必要工件。
如需了解详情,请参阅 Migrate to Containers | Google Cloud 简介。
特性
复制源应用文件
在本地使用 SSH 从远程虚拟机复制应用文件,或者使用 gcloud CLI 从 Google Cloud 上运行的虚拟机复制应用文件。
分析应用文件以进行现代化改造更改
分析应用二进制文件和配置文件,并使用从复制文件中提取的参数生成迁移计划文件报告和迁移计划。
生成应用工件以作为容器运行
使用 Skaffold 配置文件生成将应用作为容器运行所需的工件,该配置文件使您可以在目标集群上自动部署生成的工件。
支持的现代化改造流程
借助新的 Migrate to Containers CLI,您可以在本地环境中对应用进行现代化改造,并直接在本地或远程集群上部署生成的工件。
Migrate to Containers CLI 支持以下现代化改造流程:
- 将 Tomcat 应用改造为使用社区基础映像的容器
- 将 Apache 应用改造为使用社区基础映像的容器
- 将 IBM JBoss 应用改造为使用社区 WildFly 基础映像的容器
- 将 IBM WebSphere Application Server 传统版改造为使用 IBM Websphere Application Server 传统映像的容器
- 将 IBM WebSphere Application Server 传统版改造为使用 Open Liberty 容器映像的容器