From 44beb8bf13cbd2080e80b3ca7cf3b26e829bbb08 Mon Sep 17 00:00:00 2001 From: dashaun Date: Thu, 4 Jan 2024 10:42:00 -0600 Subject: [PATCH] Update getting started docs, reduce possible confusion, fix example, update output, with help from Harpreet Singh and Jonas Andersen --- docs/modules/ROOT/pages/getting-started.adoc | 57 ++++++++++---------- 1 file changed, 28 insertions(+), 29 deletions(-) diff --git a/docs/modules/ROOT/pages/getting-started.adoc b/docs/modules/ROOT/pages/getting-started.adoc index 5142bb34c..a165dbc4e 100755 --- a/docs/modules/ROOT/pages/getting-started.adoc +++ b/docs/modules/ROOT/pages/getting-started.adoc @@ -20,8 +20,7 @@ environment. [[getting-started-system-requirements]] == System Requirements -You need to have Java installed (Java 17 or better). To build, you need to have Maven -installed as well. +You need to have Java installed (Java 17 or better). [[database-requirements]] === Database Requirements @@ -61,9 +60,9 @@ To do so: . Visit the link:https://start.spring.io/[Spring Initialzr] site. .. Create a new Maven project with a *Group* name of `io.spring.demo` and an *Artifact* name of `helloworld`. -.. In the Dependencies text box, type `task` and then select the `Cloud Task` dependency. -.. In the Dependencies text box, type `jdbc` and then select the `JDBC` dependency. -.. In the Dependencies text box, type `h2` and then select the `H2`. (or your favorite database) +.. In the Dependencies text box, type `task` and then select the `Task` dependency with the `Spring Cloud` label. +.. In the Dependencies text box, type `jdbc` and then select the `JDBC API` dependency. +.. In the Dependencies text box, type `h2` and then select the `H2` dependency with the `SQL` label. .. Click the *Generate Project* button . Unzip the helloworld.zip file and import the project into your favorite IDE. @@ -73,7 +72,7 @@ To do so: To finish our application, we need to update the generated `HelloworldApplication` with the following contents so that it launches a Task. [source,java] ---- -package io.spring.Helloworld; +package io.spring.demo.helloworld; import org.springframework.boot.ApplicationArguments; import org.springframework.boot.ApplicationRunner; @@ -141,7 +140,7 @@ in that repository. In the xref:features.adoc#features-configuration[Configurati documentation), we cover how to customize the configuration of the pieces provided by Spring Cloud Task. -When our sample application runs, Spring Boot launches our `HelloWorldCommandLineRunner` +When our sample application runs, Spring Boot launches our `HelloWorldApplicationRunner` and outputs our "`Hello, World!`" message to standard out. The `TaskLifecycleListener` records the start of the task and the end of the task in the repository. @@ -171,7 +170,7 @@ NOTE: Any processing bootstrapped from mechanisms other than a `CommandLineRunne === Running the Example At this point, our application should work. Since this application is Spring Boot-based, -we can run it from the command line by using `$ mvn spring-boot:run` from the root +we can run it from the command line by using `$ ./mvnw spring-boot:run` from the root of our application, as shown (with its output) in the following example: [source] @@ -187,32 +186,32 @@ $ mvn clean spring-boot:run \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ - :: Spring Boot :: (v2.0.3.RELEASE) - -2018-07-23 17:44:34.426 INFO 1978 --- [ main] i.s.d.helloworld.HelloworldApplication : Starting HelloworldApplication on Glenns-MBP-2.attlocal.net with PID 1978 (/Users/glennrenfro/project/helloworld/target/classes started by glennrenfro in /Users/glennrenfro/project/helloworld) -2018-07-23 17:44:34.430 INFO 1978 --- [ main] i.s.d.helloworld.HelloworldApplication : No active profile set, falling back to default profiles: default -2018-07-23 17:44:34.472 INFO 1978 --- [ main] s.c.a.AnnotationConfigApplicationContext : Refreshing org.springframework.context.annotation.AnnotationConfigApplicationContext@1d24f32d: startup date [Mon Jul 23 17:44:34 EDT 2018]; root of context hierarchy -2018-07-23 17:44:35.280 INFO 1978 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Starting... -2018-07-23 17:44:35.410 INFO 1978 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed. -2018-07-23 17:44:35.419 DEBUG 1978 --- [ main] o.s.c.t.c.SimpleTaskConfiguration : Using org.springframework.cloud.task.configuration.DefaultTaskConfigurer TaskConfigurer -2018-07-23 17:44:35.420 DEBUG 1978 --- [ main] o.s.c.t.c.DefaultTaskConfigurer : No EntityManager was found, using DataSourceTransactionManager -2018-07-23 17:44:35.522 DEBUG 1978 --- [ main] o.s.c.t.r.s.TaskRepositoryInitializer : Initializing task schema for h2 database -2018-07-23 17:44:35.525 INFO 1978 --- [ main] o.s.jdbc.datasource.init.ScriptUtils : Executing SQL script from class path resource [org/springframework/cloud/task/schema-h2.sql] -2018-07-23 17:44:35.558 INFO 1978 --- [ main] o.s.jdbc.datasource.init.ScriptUtils : Executed SQL script from class path resource [org/springframework/cloud/task/schema-h2.sql] in 33 ms. -2018-07-23 17:44:35.728 INFO 1978 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Registering beans for JMX exposure on startup -2018-07-23 17:44:35.730 INFO 1978 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Bean with name 'dataSource' has been autodetected for JMX exposure -2018-07-23 17:44:35.733 INFO 1978 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Located MBean 'dataSource': registering with JMX server as MBean [com.zaxxer.hikari:name=dataSource,type=HikariDataSource] -2018-07-23 17:44:35.738 INFO 1978 --- [ main] o.s.c.support.DefaultLifecycleProcessor : Starting beans in phase 0 -2018-07-23 17:44:35.762 DEBUG 1978 --- [ main] o.s.c.t.r.support.SimpleTaskRepository : Creating: TaskExecution{executionId=0, parentExecutionId=null, exitCode=null, taskName='application', startTime=Mon Jul 23 17:44:35 EDT 2018, endTime=null, exitMessage='null', externalExecutionId='null', errorMessage='null', arguments=[]} -2018-07-23 17:44:35.772 INFO 1978 --- [ main] i.s.d.helloworld.HelloworldApplication : Started HelloworldApplication in 1.625 seconds (JVM running for 4.764) + :: Spring Boot :: (v3.2.1) + +2024-01-04T10:07:01.102-06:00 INFO 18248 --- [helloWorld] [ main] i.s.d.helloworld.HelloworldApplication : Starting HelloworldApplication using Java 21.0.1 with PID 18248 (/Users/dashaun/fun/dashaun/spring-cloud-task/helloworld/target/classes started by dashaun in /Users/dashaun/fun/dashaun/spring-cloud-task/helloworld) +2024-01-04T10:07:01.103-06:00 INFO 18248 --- [helloWorld] [ main] i.s.d.helloworld.HelloworldApplication : No active profile set, falling back to 1 default profile: "default" +2024-01-04T10:07:01.526-06:00 INFO 18248 --- [helloWorld] [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Starting... +2024-01-04T10:07:01.626-06:00 INFO 18248 --- [helloWorld] [ main] com.zaxxer.hikari.pool.HikariPool : HikariPool-1 - Added connection conn0: url=jdbc:h2:mem:3ad913f8-59ce-4785-bf8e-d6335dff6856 user=SA +2024-01-04T10:07:01.627-06:00 INFO 18248 --- [helloWorld] [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed. +2024-01-04T10:07:01.633-06:00 DEBUG 18248 --- [helloWorld] [ main] o.s.c.t.c.SimpleTaskAutoConfiguration : Using org.springframework.cloud.task.configuration.DefaultTaskConfigurer TaskConfigurer +2024-01-04T10:07:01.633-06:00 DEBUG 18248 --- [helloWorld] [ main] o.s.c.t.c.DefaultTaskConfigurer : No EntityManager was found, using DataSourceTransactionManager +2024-01-04T10:07:01.639-06:00 DEBUG 18248 --- [helloWorld] [ main] o.s.c.t.r.s.TaskRepositoryInitializer : Initializing task schema for h2 database +2024-01-04T10:07:01.772-06:00 DEBUG 18248 --- [helloWorld] [ main] o.s.c.t.r.support.SimpleTaskRepository : Creating: TaskExecution{executionId=0, parentExecutionId=null, exitCode=null, taskName='helloWorld', startTime=2024-01-04T10:07:01.757268, endTime=null, exitMessage='null', externalExecutionId='null', errorMessage='null', arguments=[]} +2024-01-04T10:07:01.785-06:00 INFO 18248 --- [helloWorld] [ main] i.s.d.helloworld.HelloworldApplication : Started HelloworldApplication in 0.853 seconds (process running for 1.029) Hello, World! -2018-07-23 17:44:35.782 DEBUG 1978 --- [ main] o.s.c.t.r.support.SimpleTaskRepository : Updating: TaskExecution with executionId=1 with the following {exitCode=0, endTime=Mon Jul 23 17:44:35 EDT 2018, exitMessage='null', errorMessage='null'} +2024-01-04T10:07:01.794-06:00 DEBUG 18248 --- [helloWorld] [ main] o.s.c.t.r.support.SimpleTaskRepository : Updating: TaskExecution with executionId=1 with the following {exitCode=0, endTime=2024-01-04T10:07:01.787112, exitMessage='null', errorMessage='null'} +2024-01-04T10:07:01.799-06:00 INFO 18248 --- [helloWorld] [ionShutdownHook] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown initiated... +2024-01-04T10:07:01.806-06:00 INFO 18248 --- [helloWorld] [ionShutdownHook] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown completed. + +....... . . . +....... . . . (Maven log output here) +....... . . . ---- -The preceding output has three lines that of interest to us here: +The preceding output has three lines that are of interest to us here: * `SimpleTaskRepository` logged the creation of the entry in the `TaskRepository`. -* The execution of our `CommandLineRunner`, demonstrated by the "`Hello, World!`" output. +* The execution of our `ApplicationRunner`, demonstrated by the "`Hello, World!`" output. * `SimpleTaskRepository` logs the completion of the task in the `TaskRepository`. NOTE: A simple task application can be found in the samples module of the Spring Cloud