Directorio de artículos
Implemente el paquete de guerra en un contenedor tomcat externo
1. Modificar el método de embalaje
<packaging>war</packaging>
Agregue el código anterior al principio del archivo pom.xml, de la siguiente manera:
2. Excluya las dependencias de tomcat incorporadas
Usamos un gato externo y, naturalmente, excluimos los frascos relacionados del gato integrado incorporado.
<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>
</exclusions>
</dependency>
3. Agregue una nueva clase para heredar SpringBootServletInitializer para implementar la configuración:
Por qué heredar esta clase, comentario del código fuente de SpringBootServletInitializer:
tenga en cuenta que solo se necesita un WebApplicationInitializer si está creando un archivo war y desplegándolo.
Si prefiere ejecutar un servidor web incorporado, entonces no necesitará esto en absoluto.
Tenga en cuenta que si está compilando el archivo WAR y desplegándolo, se requiere WebApplicationInitializer. Si le gusta ejecutar un servidor web incorporado, entonces no necesita esto en absoluto.
public class ServletInitializer extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
//此处的Application.class为带有@SpringBootApplication注解的启动类
return builder.sources(BootLaunchApplication.class);
}
}
Nota:
Cuando utilice Tomcat externo para implementar y acceder, la siguiente configuración en application.properties (o application.yml) no será válida. Utilice el puerto de Tomcat externo y el nombre del proyecto en las aplicaciones web de Tomcat para acceder.
server.port=
server.servlet.context-path=
4. La compilación debe tener una etiqueta finalName
El segmento de código de compilación en pom.xml debe tener el nombre del paquete de compilación final de la aplicación.
<finalName>boot-launch</finalName>
5. Empaquetado y funcionamiento
El paquete war está empaquetado y el resultado empaquetado se almacenará en el directorio de destino del proyecto.
mvn clean package -Dmaven.test.skip=true
A continuación, copie el paquete war en el directorio externo de aplicaciones web de Tomcat. Ejecute en el tomcat externo: ejecute startup.bat (windows) o startup.sh (linux) en el directorio ${Tomcat_home}/bin/ y luego acceda a la aplicación a través de un navegador para probar el efecto.
hay que ser consciente de es
- Descomprima boot-launch.war en el directorio de aplicaciones web de tomcat en la carpeta boot-launch. Por lo tanto, cuando acceda a la aplicación, debe usar
http://localhost:8888/boot-launch/template/jsp
, no:http://localhost:8888/template/jsp
. Se informará un error 404. - La referencia del recurso estático jsp también debe ser: /boot-launch/image/xxxx.png, no /image/xxxx.png
- En el paquete war de JSP, ya no se admite el uso de recursos de webjars.