Приложение Spring с App Engine позволяет 404 или 503 работать локально, но отлично работает при развертывании в appengine - PullRequest
0 голосов
/ 17 марта 2019

У меня есть весеннее приложение, которое я успешно внедряю в движок приложений в облаке, но которое мне трудно разрабатывать локально.

Я получаю 404 при исчерпании конфигурации запуска IntelliJ AppEngine. С логотипом

WARNING: No file found for: /index

Что заставляет меня думать, что конфигурация запуска локального ядра приложения из intellij неправильно подключает сервлет.

Я получаю 503 при использовании mvn appengine:run в консоли, без строк журнала, когда страница выдает 503, что не является неожиданным для 503 (сервер состояний последней строки журнала работает).

При запуске в консоли я замечаю, что в журналах запуска есть:

[INFO] java.lang.NoClassDefFoundError: com/google/appengine/tools/util/Action
[...]
[INFO] Caused by: 
[INFO] java.lang.ClassNotFoundException: com.google.appengine.tools.util.Action

Что может объяснить 503-е в консоли.

Это так странно, потому что в моих средах разработки и разработки все работает нормально (у меня он работает за образцом подпрограммы на моем домене): https://samplesite.taylormade.space/

Вот мой помп:

    <?xml version="1.0" encoding="UTF-8"?>
<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>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.3.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>space.taylormade</groupId>
    <artifactId>samplesite</artifactId>
    <version>${appengineVersion}</version>
    <name>samplesite</name>
    <description>Sample site</description>

    <!--
        for more information on using war packaging for a springboot application in order to get a app engine standard deploy go to:
        https://github.com/GoogleCloudPlatform/getting-started-java/tree/master/appengine-standard-java8/springboot-appengine-standard
    -->
    <packaging>war</packaging>

    <properties>
        <java.version>1.8</java.version>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
        <appengineVersion>local</appengineVersion>
        <appengineProject></appengineProject>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <!-- Exclude any jul-to-slf4j -->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>jul-to-slf4j</artifactId>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>com.google.appengine</groupId>
            <artifactId>appengine-maven-plugin</artifactId>
            <version>1.9.71</version>
        </dependency>
        <!--For servlet attachment in app engine-->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <!-- Import dependency management from Spring Boot -->
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>2.1.3.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <plugin>
                <groupId>com.google.appengine</groupId>
                <artifactId>appengine-maven-plugin</artifactId>
                <version>1.9.71</version>
                <configuration>
                    <appId>${appengineProject}</appId>
                    <version>${appengineVersion}</version>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

Я не запускаю web.xml, потому что я расширяю SpringBootServletInitializer в моем основном классе:

package space.taylormade.samplesite;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
import org.springframework.context.annotation.Configuration;

@Configuration
@SpringBootApplication
public class SamplesiteApplication extends SpringBootServletInitializer {

    public static void main(String[] args) {
        SpringApplication.run(SamplesiteApplication.class, args);
    }

}

Вот мой appengine-web.xml:

    <?xml version="1.0" encoding="utf-8"?>
<appengine-web-app xmlns="http://appengine.google.com/ns/1.0">
    <application>tigermaestro-1297</application><!-- unused for Cloud SDK based tooling -->
    <version>0.0.1</version><!-- unused for Cloud SDK based tooling -->
    <threadsafe>true</threadsafe>
    <runtime>java8</runtime>
    <system-properties>
        <property name="java.util.logging.config.file" value="WEB-INF/classes/logging.properties"/>
    </system-properties>
</appengine-web-app>

У меня есть два контроллера:

package space.taylormade.samplesite;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
@RequestMapping("/")
public class IndexController {
  @RequestMapping("")
  public String root(){return index();}

  @RequestMapping("index")
  public String index(){return "index";}
}

И (чтобы убедиться, что компонентное сканирование получало все):

package space.taylormade.samplesite.controllers;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
@RequestMapping("/hello-world")
public class HelloWorldController {
  @RequestMapping("")
  public String helloWorld(){
    return "helloworld";
  }
}

Если у кого-нибудь есть идеи, как заставить его работать так же локально, как в App Engine, это было бы замечательно. Сейчас я комментирую исключение tomcat и запускаю его из конфигурации весеннего запуска, а затем отменяю комментирование исключения перед фиксацией, которая быстро устареет.

...