пружина микронавта и пружина-загрузочный привод, нет доступа к конечным точкам привода - PullRequest
1 голос
/ 28 мая 2020

Просто пробую micronaut с возможностью Spring и не могу получить доступ к конечным точкам my / actator Выпуск Spring Boot v2.3.0 и micronaut 2.0.0.M3

Я создал проект basi c micronaut используя mn create-app xxx --lang groovy.

, я затем добавил зависимости spring и micronaut-spring и связанные с ними процессоры аннотаций.

Мой build.gradle теперь выглядит следующим образом:

plugins {
    id "groovy"
    id "com.github.johnrengelman.shadow" version "5.2.0"
    id "application"
    id "net.ltgt.apt" version "0.21"  //enables annotation preproccessing support
    id "net.ltgt.apt-idea" version "0.21"
    id "org.springframework.boot" version "2.3.0.RELEASE"
    id "io.spring.dependency-management" version "1.0.9.RELEASE"
}

ext['groovy.version'] = '3.0.4'

version "0.1"
group "com.softwood"

repositories {
    mavenCentral()
    maven { url "https://jcenter.bintray.com" }
}

configurations {
    // for dependencies that are needed for development only
    developmentOnly 
}

dependencies {

    //annotation processors
    annotationProcessor platform("io.micronaut:micronaut-bom:$micronautVersion")
    annotationProcessor "io.micronaut.spring:micronaut-spring-boot-annotation"
    annotationProcessor "io.micronaut.spring:micronaut-spring-web-annotation"
    testAnnotationProcessor "io.micronaut.spring:micronaut-spring-web-annotation:2.0.1"

    //latest groovy v3
    implementation group: 'org.codehaus.groovy', name: 'groovy-all', version: '3.0.4' //, ext: 'pom'

    //spring
    compileOnly "io.micronaut.spring:micronaut-spring-annotation:2.0.1"
    implementation("org.springframework.boot:spring-boot-starter-web")
    implementation("org.springframework.boot:spring-boot-starter-actuator")
    implementation group: 'io.micronaut.spring', name: 'micronaut-spring-web', version: '2.0.1'
    runtime ("io.micronaut.spring:micronaut-spring-boot:2.0.1")


    compileOnly platform("io.micronaut:micronaut-bom:$micronautVersion")
    compileOnly "io.micronaut:micronaut-inject-groovy"
    implementation platform("io.micronaut:micronaut-bom:$micronautVersion")
    implementation "io.micronaut:micronaut-runtime-groovy"
    implementation "io.micronaut:micronaut-validation"
    implementation "javax.annotation:javax.annotation-api"
    implementation "io.micronaut:micronaut-http-server-netty"
    implementation "io.micronaut:micronaut-http-client"
    runtimeOnly "ch.qos.logback:logback-classic:1.2.3"
    testCompileOnly platform("io.micronaut:micronaut-bom:$micronautVersion")
    testImplementation platform("io.micronaut:micronaut-bom:$micronautVersion")
    testImplementation("org.spockframework:spock-core:2.0-M2-groovy-3.0") {
        exclude group: "org.codehaus.groovy", module: "groovy-all"
    }
    testImplementation "io.micronaut:micronaut-inject-groovy"
    testImplementation "io.micronaut.test:micronaut-test-spock"
    testImplementation "io.micronaut.test:micronaut-test-junit5"
}

test.classpath += configurations.developmentOnly

mainClassName = "com.softwood.Application"

//added - enable incremetal compile feature - can't enable with annotation processors !
/*tasks.withType(GroovyCompile).configureEach {
    options.incremental = true
}*/

tasks.withType(GroovyCompile) {
    groovyOptions.forkOptions.jvmArgs.add('-Dgroovy.parameters=true')
}


shadowJar {
    mergeServiceFiles()
}

tasks.withType(JavaExec) {
    classpath += configurations.developmentOnly
    jvmArgs('-noverify', '-XX:TieredStopAtLevel=1', '-Dcom.sun.management.jmxremote')
}

Я настроил HelloController следующим образом:

import io.micronaut.http.annotation.Controller
import io.micronaut.http.annotation.Get
import io.micronaut.http.HttpStatus
import org.springframework.boot.actuate.endpoint.annotation.Endpoint


@Controller("/hello")
@Endpoint
class HelloController {

    @Get("/")
    String index() {
        return 'hello william'
    }
}

и пометил класс Application как SpringbootApplication, но вызвал Micronaut.run () для создания контекста MN et c

import io.micronaut.runtime.Micronaut
import groovy.transform.CompileStatic
import org.springframework.boot.autoconfigure.SpringBootApplication

@CompileStatic
@SpringBootApplication
class Application {
    static void main(String[] args) {
        Micronaut.run(Application)
    }
}

Я попытался настроить application.yml, чтобы открыть все конечные точки следующим образом:

micronaut:
  application:
    name: micronaut-std-app

management:
  endpoints:
    web:
      exposure:
        include=*:

Все это компилируется нормально и работает нормально. если вы вызываете localhost:8080/hello, вы получаете ожидаемую строку

, если вы пытаетесь получить доступ к конечным точкам привода - ничего не создается, и браузер отображает

{"message":"Page Not Found","_links":{"self":{"href":"/actuator/health","templated":false}}}

, если вы пытаетесь сделать смешанный проект микронавта и пружины, тогда как вы можете включить какие-либо конечные точки исполнительных механизмов для ваших контроллеров с предварительной обработкой MN и т. д. c?

1 Ответ

1 голос
/ 29 мая 2020

Если вам просто нужна конечная точка проверки работоспособности, Micronaut имеет встроенную конечную точку проверки работоспособности.

Добавьте в build.gradle следующую зависимость, чтобы добавить конечные точки, такие как здоровье:

implementation("io.micronaut:micronaut-management")

Вы можете добавить в application.yml

endpoints:
    health:
        enabled: true

Затем измените URL-адрес проверки работоспособности на «/ health»

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