Reputation: 363
I deployed my Spring-Boot application with Java8 into Tomcat 8.5, but when I'm sending some request using CURL, I get a 404 response. I have no clue what I'm doing wrong.
I'm not new to Java, but it's my first time to set up an environment on a server to deploy my app. The blog post I followed: https://linuxize.com/post/how-to-install-tomcat-9-on-ubuntu-18-04/
The only difference is that I installed Tomcat 8.5 on a Ubuntu 16.04 and I didn't set up the manager interface.
My Spring-Boot entry point:
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
return builder.sources(Application.class);
}
}
My pom.xml:
<packaging>war</packaging>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.2.RELEASE</version>
</parent>
<groupId>
some.group.id
</groupId>
<artifactId>
server
</artifactId>
<!--<version>-->
<!--1.0-SNAPSHOT-->
<!--</version>-->
<properties>
<commons-lang.version>3.6</commons-lang.version>
<guava.version>25.0-jre</guava.version>
<jwt.version>0.9.0</jwt.version>
<joda-time.version>2.9.9</joda-time.version>
<junit.version>4.12</junit.version>
<mockito.version>2.17.0</mockito.version>
<start-class>some.group.id.Application</start-class>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>${commons-lang.version}</version>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>${guava.version}</version>
</dependency>
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt</artifactId>
<version>${jwt.version}</version>
</dependency>
<dependency>
<groupId>joda-time</groupId>
<artifactId>joda-time</artifactId>
<version>${joda-time.version}</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.mockito</groupId>
<artifactId>mockito-core</artifactId>
<version>${mockito.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava-testlib</artifactId>
<version>${guava.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.4.199</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
<version>2.1.4.RELEASE</version>
</dependency>
<dependency>
<groupId>com.google.firebase</groupId>
<artifactId>firebase-admin</artifactId>
<version>6.8.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
</plugin>
</plugins>
</build>
I'm starting Tomcat as a service:
Description=Tomcat 8 servlet container
After=network.target
[Service]
Type=forking
User=tomcatuser
Group=tomcatuser
#Environment="JAVA_HOME=/usr/lib/jvm/default-java"
Environment="JAVA_OPTS=-Djava.security.egd=file:///dev/urandom -Djava.awt.headless=true"
Environment="CATALINA_BASE=/opt/tomcat/latest"
Environment="CATALINA_HOME=/opt/tomcat/latest"
Environment="CATALINA_PID=/opt/tomcat/latest/temp/tomcat.pid"
Environment="CATALINA_OPTS=-Xms512M -Xmx1024M -server -XX:+UseParallelGC"
ExecStart=/opt/tomcat/latest/bin/startup.sh
ExecStop=/opt/tomcat/latest/bin/shutdown.sh
[Install]
WantedBy=multi-user.target
JAVA_HOME is set in the /etc/environment, so that's why it's commented out.
I deployed my App to AWS, and it works. When I'm running it locally from IntelliJ, it also works. So, I assume it has to do with my Tomcat setup. Also, I do not have any log files, such as catalina.out.
Upvotes: 2
Views: 3447
Reputation: 363
@lealceldeiro answer helped me
The error was that I was requesting a resource without the name of my application's context route. My deployed war was "app.war" named, so, the wrong URL which I was requesting:
host-address:8080/resource-uri
The right URL is:
host-address:8080/app/resource-uri
Upvotes: 2