GAE java 从 Java 8 迁移到 11 - 部署问题和本地开发服务器问题

问题描述 投票:0回答:1

我在 GAE 标准运行时上有一个运行良好的 Java 8 应用程序。显然,2024 年 1 月 31 日之后不再支持 Java 8 部署。我正在尝试迁移到 Java 11 并进行部署。我之前使用 Eclipse 和 Google 插件在本地运行,右键单击并部署到 App Engine 标准,这是无缝的。

这就是我到目前为止所做的

  1. 1.下载Gcloud CLI工具并安装app-engine-java。 2. 在 Eclipse(2023-12 / 4.30 版本)中右键单击该项目,然后执行“配置”>“转换为 Maven 项目” 3. 删除了 appengine-web.xml 中的线程安全,并添加了 java11 运行时,并且 app-engine-apis 属性设置为 true 4.更新了POM文件以添加Google工具。完整的POM如下

.

<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>SAAS_BWCS_GAE_J8</groupId>
<artifactId>SAAS_BWCS_GAE_J8</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
    <dependency>
        <groupId>com.google.appengine</groupId>
        <artifactId>appengine-api-1.0-sdk</artifactId>
        <version>2.0.4</version> <!-- or later-->
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.0.1</version>
        <scope>provided</scope>
    </dependency>
    <!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>2.11.0</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-lang3</artifactId>
        <version>3.4</version>
    </dependency>

    <!--
    https://mvnrepository.com/artifact/commons-fileupload/commons-fileupload -->
    <dependency>
        <groupId>commons-fileupload</groupId>
        <artifactId>commons-fileupload</artifactId>
        <version>1.2.1</version>
    </dependency>

    <!--
    https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-api -->
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.17.2</version>
    </dependency>

</dependencies>
<build>
    <resources>
        <resource>
            <directory>src/main/java</directory>
            <excludes>
                <exclude>**/*.java</exclude>
            </excludes>
        </resource>
    </resources>
    <plugins>
        <plugin>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.1</version>
            <configuration>
                <release>11</release>
            </configuration>
        </plugin>
        <plugin>
            <artifactId>maven-war-plugin</artifactId>
            <version>3.2.3</version>
            <configuration>
                <failOnMissingWebXml>true</failOnMissingWebXml>
                <webResources>
                    <resource>
                        <directory>src/main/webapp/WEB-INF/lib</directory>
                        <targetPath>WEB-INF/lib</targetPath>
                    </resource>
                </webResources>
            </configuration>
        </plugin>
        <plugin>
            <groupId>com.google.cloud.tools</groupId>
            <artifactId>appengine-maven-plugin</artifactId>
            <version>2.7.0</version>
        </plugin>
    </plugins>
</build>

此后,我执行了 Maven/更新项目,并在 Eclipse 中将目标作为 Maven clean 包运行。包 WAR 文件构建良好。但是,当我在本地开发服务器上运行它时,出现以下错误

024-02-23 23:46:29.758:WARN:oejw.WebAppContext:main: Failed startup of context c.g.a.t.d.j.DevAppEngineWebAppContext@7e1a1da6{/,file:///C:/data/MY_APP/src/main/webapp/,UNAVAILABLE}{C:\data\MY_APP\src\main\webapp}

MultiException[javax.servlet.UnavailableException:Servlet 类 com.myapp.MyServlet 不是 javax.servlet.Servlet,javax.servlet.UnavailableException:Servlet 类 com.myapp.EmailServlet 不是 javax.servlet.Servlet]

我认为这可能是本地开发服务器问题并使用部署到云

appengine:deploy -Dapp.deploy.projectId=my_app_id -Dapp.deploy.version=newj11 -Dapp.deploy.promote=True

但是,在谷歌云上的实时版本上,我也遇到了同样的错误,并且服务器无法启动。

Failed startup of context c.g.a.r.j.AppEngineWebAppContext@6d2c0e53{/,file:///workspace/,UNAVAILABLE}{/workspace} MultiException[javax.servlet.UnavailableException: Servlet class com.myapp.MyServlet is not a javax.servlet.Servlet

我认为这是因为我在依赖项中包含了 javax.servlet 并将其删除。如果我删除它,代码不会在 Maven 编译中编译。我已经在这里呆了 7 个多小时了,但我已经迷失了。任何人都可以帮助解决此问题并进行部署。这一变化本身是非常小的一行变化,但谷歌让迁移/部署变得如此困难

java google-app-engine maven-gae-plugin
1个回答
0
投票

如本文档中所述 Cloud Tools for Eclipse 发行说明

注意:Cloud Tools for Eclipse 仅与 App Engine Java 8 运行时兼容,该运行时将于 2024 年 1 月 31 日终止支持。

根据此 Github 链接,目前 Cloud Tools for Eclipse 上的 App Engine 标准的 Java 11/17 支持不可用。

这里有一个开放的 github 线程,您可以将您的担忧添加到同一问题。也可以随时提出公共问题跟踪器功能请求来描述您的担忧。您可以在创建问题时使用此页面作为参考。

© www.soinside.com 2019 - 2024. All rights reserved.