Использование Spring Boot без Maven - PullRequest
1 голос
/ 07 января 2020

Я пытаюсь написать простую Java программу, которая отображает Hello World в виде микросервиса. Я использую Spring Boot, но из-за соображений безопасности в моей компании я не могу использовать Maven. Поэтому у меня нет выбора, кроме как загрузить файлы JAR и добавить их в свой проект. Я сделал это и убедился, что использую последние версии фляги. Когда я запускаю свою программу, она не показывает ошибок, НО сервер Tomcat не запускается, и я не вижу сообщения «Hello World». Ниже мой код:

package com.tutorials;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

@RestController
@EnableAutoConfiguration
public class HelloWorld {

    @RequestMapping("/")
    //http://localhost:port/

    String hello()
    {
        return "Hello World!";
    }

    public static void main(String[] args) throws Exception{

        SpringApplication.run(HelloWorld.class,args);
        System.out.println("done");


    }



}

и ниже вывод:

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v2.2.2.RELEASE)

2020-01-07 11:10:44.563  INFO 13224 --- [           main] com.tutorials.HelloWorld                 : Starting HelloWorld on HQTPM00184606D with PID 13224 (started by z.a in C:\Users\Z\Desktop\Workspace\HelloWorld_Microservice)
2020-01-07 11:10:44.566  INFO 13224 --- [           main] com.tutorials.HelloWorld                 : No active profile set, falling back to default profiles: default
2020-01-07 11:10:44.938  INFO 13224 --- [           main] com.tutorials.HelloWorld                 : Started HelloWorld in 0.703 seconds (JVM running for 1.096)
done

и ниже файлы jar, которые я использую:

enter image description here

Почему Tomcat не запускается и какие зависимости мне здесь не хватает? Спасибо.

1 Ответ

1 голос
/ 07 января 2020

Дерево зависимостей для spring-boot-starter-web 2.2.2:

org.springframework.boot:spring-boot-starter-web:jar:2.2.2.RELEASE:compile
+- org.springframework.boot:spring-boot-starter:jar:2.2.2.RELEASE:compile
|  +- org.springframework.boot:spring-boot:jar:2.2.2.RELEASE:compile
|  +- org.springframework.boot:spring-boot-autoconfigure:jar:2.2.2.RELEASE:compile
|  +- org.springframework.boot:spring-boot-starter-logging:jar:2.2.2.RELEASE:compile
|  |  +- ch.qos.logback:logback-classic:jar:1.2.3:compile
|  |  |  +- ch.qos.logback:logback-core:jar:1.2.3:compile
|  |  |  \- org.slf4j:slf4j-api:jar:1.7.29:compile
|  |  +- org.apache.logging.log4j:log4j-to-slf4j:jar:2.12.1:compile
|  |  |  \- org.apache.logging.log4j:log4j-api:jar:2.12.1:compile
|  |  \- org.slf4j:jul-to-slf4j:jar:1.7.29:compile
|  +- jakarta.annotation:jakarta.annotation-api:jar:1.3.5:compile
|  +- org.springframework:spring-core:jar:5.2.2.RELEASE:compile
|  |  \- org.springframework:spring-jcl:jar:5.2.2.RELEASE:compile
|  \- org.yaml:snakeyaml:jar:1.25:runtime
+- org.springframework.boot:spring-boot-starter-json:jar:2.2.2.RELEASE:compile
|  +- com.fasterxml.jackson.core:jackson-databind:jar:2.10.1:compile
|  |  +- com.fasterxml.jackson.core:jackson-annotations:jar:2.10.1:compile
|  |  \- com.fasterxml.jackson.core:jackson-core:jar:2.10.1:compile
|  +- com.fasterxml.jackson.datatype:jackson-datatype-jdk8:jar:2.10.1:compile
|  +- com.fasterxml.jackson.datatype:jackson-datatype-jsr310:jar:2.10.1:compile
|  \- com.fasterxml.jackson.module:jackson-module-parameter-names:jar:2.10.1:compile
+- org.springframework.boot:spring-boot-starter-tomcat:jar:2.2.2.RELEASE:compile
|  +- org.apache.tomcat.embed:tomcat-embed-core:jar:9.0.29:compile
|  +- org.apache.tomcat.embed:tomcat-embed-el:jar:9.0.29:compile
|  \- org.apache.tomcat.embed:tomcat-embed-websocket:jar:9.0.29:compile
+- org.springframework.boot:spring-boot-starter-validation:jar:2.2.2.RELEASE:compile
|  +- jakarta.validation:jakarta.validation-api:jar:2.0.1:compile
|  \- org.hibernate.validator:hibernate-validator:jar:6.0.18.Final:compile
|     +- org.jboss.logging:jboss-logging:jar:3.4.1.Final:compile
|     \- com.fasterxml:classmate:jar:1.5.1:compile
+- org.springframework:spring-web:jar:5.2.2.RELEASE:compile
|  \- org.springframework:spring-beans:jar:5.2.2.RELEASE:compile
\- org.springframework:spring-webmvc:jar:5.2.2.RELEASE:compile
   +- org.springframework:spring-aop:jar:5.2.2.RELEASE:compile
   +- org.springframework:spring-context:jar:5.2.2.RELEASE:compile
   \- org.springframework:spring-expression:jar:5.2.2.RELEASE:compile

Но, как уже упоминалось в комментариях, вы должны попытаться использовать инструменты сборки (Maven / Gradle) и возможен менеджер хранилища в масштабе всей компании (Nexus / Artifactory).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...