how to debug spring application with gradle

JavaEclipseSpringDebuggingGradle

Java Problem Overview


I am working on spring app and need to step through a controller method to see how it works. I am working in eclipse and building my app with gradle bootRun command.

How to run it in debug mode?

i tried gradle bootRun --debug but it's just debug log, not debug mode

i tried gradle help --task bootRun -- this gives me info about task there i saw --debug-jvm option but when i run gradle bootRun --debug-jvm application doesn't start

Java Solutions


Solution 1 - Java

After you run gradle bootRun --debug-jvm the application is suspended until you connect your debugger to the port it is listening on (port 5005).

Solution 2 - Java

As a response to dankdirkd's answer above: (compare)

gradle bootRun --debug-jvm

will make the gradle build run in debug mode. That probably is not what you want. What you want to achieve is that the springBoot task starts your application in debug mode.

The spring boot task extends the gradle JavaExec task. You can configure the bootRun task in your build.gradle file to add a debug configuration like this:

bootRun {
  jvmArgs=["-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=32323"]
}

For the build.gradle.kts this would look like this (with suspend mode disabled):

tasks {
	val bootRun by getting(BootRun::class) {
		jvmArgs=listOf("-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=32323")
	}
}

If your server is within a cloud and you want to debug from local machine, you need to make sure that it allows connections from outside. Use below configuration in that case

tasks {
val bootRun by getting(BootRun::class) {
    jvmArgs=listOf("-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=0.0.0.0:32323")
    }
}

Note that the address is now 0.0.0.0:port instead of just port

Solution 3 - Java

For build.gradle.kts file you can also simply use below:

tasks.withType<BootRun> {
    jvmArgs = listOf("-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=0.0.0.0:32323")
}

Solution 4 - Java

I personally prefer going under Gradle tasks and right-clicking on the bootRun. This is useful in the IDE compared to the terminal.

Solution 5 - Java

For people hitting this via Google and wondering how to enable Spring's debug mode (normally done by java -jar app.jar --debug) and using Gradle, here is how. This passes --debug to the main class which is how you turn on Spring Boot's debug mode which logs autoconfig classes among other things.

./gradlew bootRun --args='--debug'

Solution 6 - Java

Define an executes a Java application in a child process.

task executeApp() {
    doFirst {
       println "Executing java app from Gradle..."
       javaexec {
           main = "com.mymain"
           jvmArgs = ["-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=30000"]
       }
    }
}

Set your breakpoints in the java code. After execute the Gradle task.For example in Windows:

  .\gradlew.bat executeApp

The task waits until you attach the debugger. For example in Netbeans go to Debug->Attach debugger , set 30000 on port Field.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionrigbyView Question on Stackoverflow
Solution 1 - JavadankirkdView Answer on Stackoverflow
Solution 2 - JavarexfordView Answer on Stackoverflow
Solution 3 - JavaHimadriView Answer on Stackoverflow
Solution 4 - JavakguiView Answer on Stackoverflow
Solution 5 - JavaCaptain ManView Answer on Stackoverflow
Solution 6 - JavajsciView Answer on Stackoverflow