У меня есть весеннее приложение, которое я успешно внедряю в движок приложений в облаке, но которое мне трудно разрабатывать локально.
Я получаю 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 и запускаю его из конфигурации весеннего запуска, а затем отменяю комментирование исключения перед фиксацией, которая быстро устареет.