From 489e1c7b39ca205e2458ef1bf74c6a52fc6cdddc Mon Sep 17 00:00:00 2001 From: GitHub Action Date: Thu, 1 Aug 2024 01:55:37 +0000 Subject: [PATCH] Sync documentation of main branch --- ....quarkus.scheduler.runtime.SchedulerConfig | 2 +- .../main/config/quarkus-all-build-items.adoc | 39 +++++++++ .../main/config/quarkus-all-config.adoc | 19 ++++ .../quarkus-scheduler-scheduler-config.adoc | 19 ++++ .../main/config/quarkus-scheduler.adoc | 19 ++++ .../kafka-schema-registry-json-schema.adoc | 2 +- .../main/guides/opentelemetry-metrics.adoc | 87 ++++++++++++------- .../main/guides/scheduler-reference.adoc | 26 +++++- 8 files changed, 180 insertions(+), 33 deletions(-) diff --git a/_generated-doc/main/config/all-configuration-roots-generated-doc/io.quarkus.scheduler.runtime.SchedulerConfig b/_generated-doc/main/config/all-configuration-roots-generated-doc/io.quarkus.scheduler.runtime.SchedulerConfig index fc856ea7cf..3c38a6c992 100644 --- a/_generated-doc/main/config/all-configuration-roots-generated-doc/io.quarkus.scheduler.runtime.SchedulerConfig +++ b/_generated-doc/main/config/all-configuration-roots-generated-doc/io.quarkus.scheduler.runtime.SchedulerConfig @@ -1 +1 @@ -[{"configDocKey":{"type":"com.cronutils.model.CronType","key":"quarkus.scheduler.cron-type","additionalKeys":[],"configDoc":"The syntax used in CRON expressions.","withinAMap":false,"defaultValue":"quartz","javaDocSiteLink":"","docMapKey":"cron-type","configPhase":"BUILD_AND_RUN_TIME_FIXED","acceptedValues":["`cron4j`","`quartz`","`unix`","`spring`","`spring53`"],"optional":false,"list":false,"withinAConfigGroup":false,"topLevelGrouping":"quarkus.scheduler","since":null,"environmentVariable":"QUARKUS_SCHEDULER_CRON_TYPE","enum":true}},{"configDocKey":{"type":"boolean","key":"quarkus.scheduler.metrics.enabled","additionalKeys":[],"configDoc":"Scheduled task metrics will be enabled if a metrics extension is present and this value is true.","withinAMap":false,"defaultValue":"false","javaDocSiteLink":"","docMapKey":"metrics-enabled","configPhase":"BUILD_AND_RUN_TIME_FIXED","acceptedValues":null,"optional":false,"list":false,"withinAConfigGroup":false,"topLevelGrouping":"quarkus.scheduler","since":null,"environmentVariable":"QUARKUS_SCHEDULER_METRICS_ENABLED","enum":false}},{"configDocKey":{"type":"boolean","key":"quarkus.scheduler.tracing.enabled","additionalKeys":[],"configDoc":"Controls whether tracing is enabled. If set to true and the OpenTelemetry extension is present, tracing will be enabled, creating automatic Spans for each scheduled task.","withinAMap":false,"defaultValue":"false","javaDocSiteLink":"","docMapKey":"tracing-enabled","configPhase":"BUILD_AND_RUN_TIME_FIXED","acceptedValues":null,"optional":false,"list":false,"withinAConfigGroup":false,"topLevelGrouping":"quarkus.scheduler","since":null,"environmentVariable":"QUARKUS_SCHEDULER_TRACING_ENABLED","enum":false}}] \ No newline at end of file +[{"configDocKey":{"type":"com.cronutils.model.CronType","key":"quarkus.scheduler.cron-type","additionalKeys":[],"configDoc":"The syntax used in CRON expressions.","withinAMap":false,"defaultValue":"quartz","javaDocSiteLink":"","docMapKey":"cron-type","configPhase":"BUILD_AND_RUN_TIME_FIXED","acceptedValues":["`cron4j`","`quartz`","`unix`","`spring`","`spring53`"],"optional":false,"list":false,"withinAConfigGroup":false,"topLevelGrouping":"quarkus.scheduler","since":null,"environmentVariable":"QUARKUS_SCHEDULER_CRON_TYPE","enum":true}},{"configDocKey":{"type":"boolean","key":"quarkus.scheduler.metrics.enabled","additionalKeys":[],"configDoc":"Scheduled task metrics will be enabled if a metrics extension is present and this value is true.","withinAMap":false,"defaultValue":"false","javaDocSiteLink":"","docMapKey":"metrics-enabled","configPhase":"BUILD_AND_RUN_TIME_FIXED","acceptedValues":null,"optional":false,"list":false,"withinAConfigGroup":false,"topLevelGrouping":"quarkus.scheduler","since":null,"environmentVariable":"QUARKUS_SCHEDULER_METRICS_ENABLED","enum":false}},{"configDocKey":{"type":"boolean","key":"quarkus.scheduler.tracing.enabled","additionalKeys":[],"configDoc":"Controls whether tracing is enabled. If set to true and the OpenTelemetry extension is present, tracing will be enabled, creating automatic Spans for each scheduled task.","withinAMap":false,"defaultValue":"false","javaDocSiteLink":"","docMapKey":"tracing-enabled","configPhase":"BUILD_AND_RUN_TIME_FIXED","acceptedValues":null,"optional":false,"list":false,"withinAConfigGroup":false,"topLevelGrouping":"quarkus.scheduler","since":null,"environmentVariable":"QUARKUS_SCHEDULER_TRACING_ENABLED","enum":false}},{"configDocKey":{"type":"boolean","key":"quarkus.scheduler.use-composite-scheduler","additionalKeys":[],"configDoc":"By default, only one `Scheduler` implementation is used. If set to `true` then a composite `Scheduler` that delegates to all running implementations is used.\n\nScheduler implementations will be started depending on the value of `quarkus.scheduler.start-mode`, i.e. the scheduler is not started unless a relevant `io.quarkus.scheduler.Scheduled` business method is found.","withinAMap":false,"defaultValue":"false","javaDocSiteLink":"","docMapKey":"use-composite-scheduler","configPhase":"BUILD_AND_RUN_TIME_FIXED","acceptedValues":null,"optional":false,"list":false,"withinAConfigGroup":false,"topLevelGrouping":"quarkus.scheduler","since":null,"environmentVariable":"QUARKUS_SCHEDULER_USE_COMPOSITE_SCHEDULER","enum":false}}] \ No newline at end of file diff --git a/_generated-doc/main/config/quarkus-all-build-items.adoc b/_generated-doc/main/config/quarkus-all-build-items.adoc index b1b727405a..d074696c02 100644 --- a/_generated-doc/main/config/quarkus-all-build-items.adoc +++ b/_generated-doc/main/config/quarkus-all-build-items.adoc @@ -7491,12 +7491,51 @@ h|Attributes +a| https://github.com/quarkusio/quarkus/blob/main/extensions/scheduler/deployment/src/main/java/io/quarkus/scheduler/deployment/DiscoveredImplementationsBuildItem.java[`io.quarkus.scheduler.deployment.DiscoveredImplementationsBuildItem`, window="_blank"] +[.description] +-- +This build item holds all discovered `io.quarkus.scheduler.Scheduler` implementations sorted by priority. Higher priority goes first. +-- a|`java.lang.String autoImplementation` + +_No Javadoc found_ + +`java.util.Set implementations` + +_No Javadoc found_ + +`boolean useCompositeScheduler` + +_No Javadoc found_ + + + + a| https://github.com/quarkusio/quarkus/blob/main/extensions/scheduler/deployment/src/main/java/io/quarkus/scheduler/deployment/ForceStartSchedulerBuildItem.java[`io.quarkus.scheduler.deployment.ForceStartSchedulerBuildItem`, window="_blank"] [.description] -- A marker item which forces Quarkus Scheduler initialization regardless of presence of any `io.quarkus.scheduler.Scheduled` methods. This option is similar to using scheduler subsystem configuration option `quarkus.scheduler.start-mode=forced` . -- a|None + + +a| https://github.com/quarkusio/quarkus/blob/main/extensions/scheduler/deployment/src/main/java/io/quarkus/scheduler/deployment/SchedulerImplementationBuildItem.java[`io.quarkus.scheduler.deployment.SchedulerImplementationBuildItem`, window="_blank"] +[.description] +-- +An extension that provides an implementation of `Scheduler` must produce this build item. +If multiple extensions produce this build item with the same `#implementation` value then the build fails. +-- a|`java.lang.String implementation` + +_No Javadoc found_ + +`org.jboss.jandex.DotName schedulerBeanClass` + +_No Javadoc found_ + +`int priority` + +_No Javadoc found_ + + |=== == Security [.configuration-reference,cols=2*] diff --git a/_generated-doc/main/config/quarkus-all-config.adoc b/_generated-doc/main/config/quarkus-all-config.adoc index 5e496060c6..65ae6e49a1 100644 --- a/_generated-doc/main/config/quarkus-all-config.adoc +++ b/_generated-doc/main/config/quarkus-all-config.adoc @@ -68446,6 +68446,25 @@ endif::add-copy-button-to-env-var[] |`false` +a|icon:lock[title=Fixed at build time] [[quarkus-scheduler_quarkus-scheduler-use-composite-scheduler]]`link:#quarkus-scheduler_quarkus-scheduler-use-composite-scheduler[quarkus.scheduler.use-composite-scheduler]` + + +[.description] +-- +By default, only one `Scheduler` implementation is used. If set to `true` then a composite `Scheduler` that delegates to all running implementations is used. + +Scheduler implementations will be started depending on the value of `quarkus.scheduler.start-mode`, i.e. the scheduler is not started unless a relevant `io.quarkus.scheduler.Scheduled` business method is found. + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_SCHEDULER_USE_COMPOSITE_SCHEDULER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_SCHEDULER_USE_COMPOSITE_SCHEDULER+++` +endif::add-copy-button-to-env-var[] +--|boolean +|`false` + + a| [[quarkus-scheduler_quarkus-scheduler-enabled]]`link:#quarkus-scheduler_quarkus-scheduler-enabled[quarkus.scheduler.enabled]` diff --git a/_generated-doc/main/config/quarkus-scheduler-scheduler-config.adoc b/_generated-doc/main/config/quarkus-scheduler-scheduler-config.adoc index cc47474665..d6f784e728 100644 --- a/_generated-doc/main/config/quarkus-scheduler-scheduler-config.adoc +++ b/_generated-doc/main/config/quarkus-scheduler-scheduler-config.adoc @@ -61,4 +61,23 @@ endif::add-copy-button-to-env-var[] --|boolean |`false` + +a|icon:lock[title=Fixed at build time] [[quarkus-scheduler-scheduler-config_quarkus-scheduler-use-composite-scheduler]]`link:#quarkus-scheduler-scheduler-config_quarkus-scheduler-use-composite-scheduler[quarkus.scheduler.use-composite-scheduler]` + + +[.description] +-- +By default, only one `Scheduler` implementation is used. If set to `true` then a composite `Scheduler` that delegates to all running implementations is used. + +Scheduler implementations will be started depending on the value of `quarkus.scheduler.start-mode`, i.e. the scheduler is not started unless a relevant `io.quarkus.scheduler.Scheduled` business method is found. + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_SCHEDULER_USE_COMPOSITE_SCHEDULER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_SCHEDULER_USE_COMPOSITE_SCHEDULER+++` +endif::add-copy-button-to-env-var[] +--|boolean +|`false` + |=== \ No newline at end of file diff --git a/_generated-doc/main/config/quarkus-scheduler.adoc b/_generated-doc/main/config/quarkus-scheduler.adoc index f08fe62ba2..dda2359df6 100644 --- a/_generated-doc/main/config/quarkus-scheduler.adoc +++ b/_generated-doc/main/config/quarkus-scheduler.adoc @@ -62,6 +62,25 @@ endif::add-copy-button-to-env-var[] |`false` +a|icon:lock[title=Fixed at build time] [[quarkus-scheduler_quarkus-scheduler-use-composite-scheduler]]`link:#quarkus-scheduler_quarkus-scheduler-use-composite-scheduler[quarkus.scheduler.use-composite-scheduler]` + + +[.description] +-- +By default, only one `Scheduler` implementation is used. If set to `true` then a composite `Scheduler` that delegates to all running implementations is used. + +Scheduler implementations will be started depending on the value of `quarkus.scheduler.start-mode`, i.e. the scheduler is not started unless a relevant `io.quarkus.scheduler.Scheduled` business method is found. + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_SCHEDULER_USE_COMPOSITE_SCHEDULER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_SCHEDULER_USE_COMPOSITE_SCHEDULER+++` +endif::add-copy-button-to-env-var[] +--|boolean +|`false` + + a| [[quarkus-scheduler_quarkus-scheduler-enabled]]`link:#quarkus-scheduler_quarkus-scheduler-enabled[quarkus.scheduler.enabled]` diff --git a/_versions/main/guides/kafka-schema-registry-json-schema.adoc b/_versions/main/guides/kafka-schema-registry-json-schema.adoc index e65e0cf8e3..e5e5fb99a7 100644 --- a/_versions/main/guides/kafka-schema-registry-json-schema.adoc +++ b/_versions/main/guides/kafka-schema-registry-json-schema.adoc @@ -76,7 +76,7 @@ Create a file called `src/main/resources/json-schema.json` with the schema for o "type": "string", "description": "The movie's title." }, - "yeay": { + "year": { "type": "integer", "description": "The movie's year." } diff --git a/_versions/main/guides/opentelemetry-metrics.adoc b/_versions/main/guides/opentelemetry-metrics.adoc index e29c81e698..cc42f2ea40 100644 --- a/_versions/main/guides/opentelemetry-metrics.adoc +++ b/_versions/main/guides/opentelemetry-metrics.adoc @@ -19,7 +19,6 @@ metrics for interactive web applications. - If you search more information about OpenTelemetry Tracing, please refer to the xref:opentelemetry-tracing.adoc[OpenTelemetry Tracing Guide]. ==== - == Prerequisites :prerequisites-docker-compose: @@ -40,7 +39,8 @@ The solution is located in the `opentelemetry-quickstart` link:{quickstarts-tree == Creating the Maven project -First, we need a new project. Create a new project with the following command: +First, we need a new project. +Create a new project with the following command: :create-app-artifact-id: opentelemetry-quickstart :create-app-extensions: rest,quarkus-opentelemetry @@ -114,13 +114,13 @@ public class MetricResource { } ---- -Quarkus is not currently producing metrics out of the box. Here we are creating a counter for the number of invocations of the `hello()` method. +Quarkus is not currently producing metrics out of the box. +Here we are creating a counter for the number of invocations of the `hello()` method. <1> Constructor injection of the `Meter` instance. <2> Create a `LongCounter` named `hello-metrics` with a description and unit. <3> Increment the counter by one for each invocation of the `hello()` method. - === Create the configuration There are no mandatory configurations for the extension to work. @@ -135,9 +135,12 @@ quarkus.otel.exporter.otlp.metrics.endpoint=http://localhost:4317 // <3> quarkus.otel.exporter.otlp.metrics.headers=authorization=Bearer my_secret // <4> ---- -<1> All metrics created from the application will include an OpenTelemetry `Resource` indicating the metrics was created by the `myservice` application. If not set, it will default to the artifact id. -<2> Enable the OpenTelemetry metrics. Must be set at build time. -<3> gRPC endpoint to send the metrics. If not set, it will default to `http://localhost:4317`. +<1> All metrics created from the application will include an OpenTelemetry `Resource` indicating the metrics was created by the `myservice` application. +If not set, it will default to the artifact id. +<2> Enable the OpenTelemetry metrics. +Must be set at build time. +<3> gRPC endpoint to send the metrics. +If not set, it will default to `http://localhost:4317`. <4> Optional gRPC headers commonly used for authentication. To configure the connection using the same properties for all signals, please check the base xref:opentelemetry.adoc#create-the-configuration[configuration section of the OpenTelemetry guide]. @@ -153,7 +156,8 @@ First we need to start a system to visualise the OpenTelemetry data. ==== Grafana-OTel-LGTM dev service You can use the xref:observability-devservices-lgtm.adoc[Grafana-OTel-LGTM] devservice. -This Dev service includes a Grafana for visualizing data, Loki to store logs, Tempo to store traces and Prometheus to store metrics. Also provides and OTel collector to receive the data. +This Dev service includes a Grafana for visualizing data, Loki to store logs, Tempo to store traces and Prometheus to store metrics. +Also provides and OTel collector to receive the data. ==== Logging exporter @@ -164,12 +168,16 @@ quarkus.otel.metrics.exporter=logging <1> quarkus.otel.metric.export.interval=10000ms <2> ---- -<1> Set the exporter to `logging`. Normally you don't need to set this. The default is `cdi`. -<2> Set the interval to export the metrics. The default is `1m`, which is too long for debugging. +<1> Set the exporter to `logging`. +Normally you don't need to set this. +The default is `cdi`. +<2> Set the interval to export the metrics. +The default is `1m`, which is too long for debugging. === Start the application -Now we are ready to run our application. If using `application.properties` to configure the tracer: +Now we are ready to run our application. +If using `application.properties` to configure the tracer: include::{includes}/devtools/dev.adoc[] @@ -187,7 +195,8 @@ $ curl http://localhost:8080/hello-metrics hello-metrics ---- -When using the logger exporter, metrics will be printed to the console. This is a pretty printed example: +When using the logger exporter, metrics will be printed to the console. +This is a pretty printed example: [source,json] ---- { @@ -260,8 +269,10 @@ When using the logger exporter, metrics will be printed to the console. This is <1> Resource attributes common to all telemetry data. <2> Instrumentation scope is allways `io.quarkus.opentelemetry` <3> The name, description and unit of the metric you defined in the constructor of the `MetricResource` class. -<4> The value of the metric. 3 invocations were made until now. -<5> Exemplars additional tracing information about the metric. In this case, the traceId and spanId of one os the request that triggered the metric, since it was last sent. +<4> The value of the metric. +3 invocations were made until now. +<5> Exemplars additional tracing information about the metric. +In this case, the traceId and spanId of one os the request that triggered the metric, since it was last sent. Hit `CTRL+C` or type `q` to stop the application. @@ -269,11 +280,14 @@ Hit `CTRL+C` or type `q` to stop the application. === OpenTelemetry Metrics vs Micrometer Metrics -Metrics are single numerical measurements, often have additional data captured with them. This ancillary data is used to group or aggregate metrics for analysis. +Metrics are single numerical measurements, often have additional data captured with them. +This ancillary data is used to group or aggregate metrics for analysis. Pretty much like in the xref:telemetry-micrometer.adoc#create-your-own-metrics[Quarkus Micrometer extension], you can create your own metrics using the OpenTelemetry API and the concepts are analogous. -The OpenTelemetry API provides a `Meter` interface to create metrics instead of a Registry. The `Meter` interface is the entry point for creating metrics. It provides methods to create counters, gauges, and histograms. +The OpenTelemetry API provides a `Meter` interface to create metrics instead of a Registry. +The `Meter` interface is the entry point for creating metrics. +It provides methods to create counters, gauges, and histograms. Attributes can be added to metrics to add dimensions, pretty much like tags in Micrometer. @@ -322,20 +336,26 @@ counter.add(1, // <2> <1> Create a `LongCounter` named `hello-metrics` with a description and unit. <2> Increment the counter by one. -<3> Add an attribute to the counter. This will create a dimension called `attribute.name` with value `attribute value`. +<3> Add an attribute to the counter. +This will create a dimension called `attribute.name` with value `attribute value`. -IMPORTANT: Each unique combination of metric name and dimension produces a unique time series. Using an unbounded set of dimensional data (many different values like a userId) can lead to a "cardinality explosion", an exponential increase in the creation of new time series. Avoid! +IMPORTANT: Each unique combination of metric name and dimension produces a unique time series. +Using an unbounded set of dimensional data (many different values like a userId) can lead to a "cardinality explosion", an exponential increase in the creation of new time series. +Avoid! OpenTelemetry provides many other types of Counters: `LongUpDownCounter`, `DoubleCounter`, `DoubleUpDownCounter` and also Observable, async counters like `ObservableLongCounter`, `ObservableDoubleCounter`, `ObservableLongUpDownCounter` and `ObservableDoubleUpDownCounter`. For more details please refer to the https://opentelemetry.io/docs/languages/java/instrumentation/#using-counters[OpenTelemetry Java documentation about Counters]. === Gauges -Observable Gauges should be used to measure non-additive values. A value that can increase or decrease over time, like the speedometer on a car. Gauges can be useful when monitoring the statistics for a cache or collection. +Observable Gauges should be used to measure non-additive values. +A value that can increase or decrease over time, like the speedometer on a car. +Gauges can be useful when monitoring the statistics for a cache or collection. -With this metric you provide a function to be periodically probed by a callback. The value returned by the function is the value of the gauge. +With this metric you provide a function to be periodically probed by a callback. +The value returned by the function is the value of the gauge. -The default gauge records `Double`values, but if you want to record `Long` values, you can use +The default gauge records `Double` values, but if you want to record `Long` values, you can use [source, java] ---- @@ -351,7 +371,8 @@ meter.gaugeBuilder("jvm.memory.total") // <1> ---- <1> Create a `Gauge` named `jvm.memory.total` with a description and unit. <2> If you want to record `Long` values you need this builder method because the default gauge records `Double` values. -<3> Build the gauge with a callback. An imperative builder is also available. +<3> Build the gauge with a callback. +An imperative builder is also available. <4> Register the function to call to get the value of the gauge. <5> No added attributes, this time. @@ -360,7 +381,6 @@ Histograms are synchronous instruments used to measure a distribution of values It is intended for statistics such as histograms, summaries, and percentile. The request duration and response payload size are good uses for a histogram. - On this section we have a new class, the `HistogramResource` that will create a `LongHistogram`. [source, java] @@ -412,9 +432,11 @@ public class HistogramResource { ---- <1> Create a `LongHistogram` named `hello.roll.dice` with a description and unit. <2> If you want to record `Long` values you need this builder method because the default histogram records `Double` values. -<3> Set the explicit bucket boundaries for the histogram. The boundaries are inclusive. +<3> Set the explicit bucket boundaries for the histogram. +The boundaries are inclusive. <4> Record the value of the roll. -<5> Add an attribute to the histogram. This will create a dimension called `attribute.name` with value `value`. +<5> Add an attribute to the histogram. +This will create a dimension called `attribute.name` with value `value`. IMPORTANT: Beware of cardinality explosion. @@ -425,7 +447,8 @@ $ curl http://localhost:8080/roll-dice 2 ---- -If we execute 4 consecutive requests, with results *2,2,3 and 4* this will produce the following output. The `Resource` and `InstrumentationScopeInfo` data are ignored for brevity. +If we execute 4 consecutive requests, with results *2,2,3 and 4* this will produce the following output. +The `Resource` and `InstrumentationScopeInfo` data are ignored for brevity. [source,json] ---- //... @@ -477,13 +500,16 @@ data=ImmutableHistogramData{ <7> The maximum value recorded. <8> The explicit bucket boundaries for the histogram. <9> The number of values recorded in each bucket. -<10> The list of exemplars with tracing data for the values recorded. We only show 1 of 3 exemplars for brevity. +<10> The list of exemplars with tracing data for the values recorded. +We only show 1 of 3 exemplars for brevity. <11> One of the 2 calls made with the value 2. === Differences with the Micrometer API -- Timers and Distribution Summaries are not available in the OpenTelemetry API. Instead, use Histograms. -- The OpenTelemetry API does not define annotations for metrics like Micrometer's `@Counted`, `@Timed` or `@MeterTag` You need to manually create the metrics. +- Timers and Distribution Summaries are not available in the OpenTelemetry API. + Instead, use Histograms. +- The OpenTelemetry API does not define annotations for metrics like Micrometer's `@Counted`, `@Timed` or `@MeterTag`. + You need to manually create the metrics. - OpenTelemetry uses their own https://opentelemetry.io/docs/specs/semconv/[Semantic Conventions] to name metrics and attributes. === Resource @@ -491,7 +517,8 @@ See the main xref:opentelemetry.adoc#resource[OpenTelemetry Guide resources] sec == Additional instrumentation -Automatic metrics are not yet provided by the Quarkus OpenTelemetry extension. We plan to bridge the existing Quarkus Micrometer extension metrics to OpenTelemetry in the future. +Automatic metrics are not yet provided by the Quarkus OpenTelemetry extension. +We plan to bridge the existing Quarkus Micrometer extension metrics to OpenTelemetry in the future. == Exporters See the main xref:opentelemetry.adoc#exporters[OpenTelemetry Guide exporters] section. diff --git a/_versions/main/guides/scheduler-reference.adoc b/_versions/main/guides/scheduler-reference.adoc index ebfa3a4f34..943ff8319b 100644 --- a/_versions/main/guides/scheduler-reference.adoc +++ b/_versions/main/guides/scheduler-reference.adoc @@ -100,7 +100,7 @@ For example `"0 15 10 * * ?"` fires at 10:15am every day. [source,java] ---- @Scheduled(cron = "0 15 10 * * ?") -void fireAt10AmEveryDay() { } +void fireAt1015AmEveryDay() { } ---- The syntax used in CRON expressions is controlled by the `quarkus.scheduler.cron-type` property. @@ -359,6 +359,30 @@ class Jobs { ---- <1> The return type `Uni` instructs the scheduler to execute the method on the Vert.x event loop. +=== How to use multiple scheduler implementations + +In some cases, it might be useful to choose a scheduler implementation used to execute a scheduled method. +However, only one `Scheduler` implementation is used for all scheduled methods by default. +For example, the `quarkus-quartz` extension provides an implementation that supports clustering but it also removes the simple in-memory implementation from the game. +Now, if clustering is enabled then it's not possible to define a scheduled method that would be executed locally on a single node. +Nevertheless, if you set the `quarkus.scheduler.use-composite-scheduler` config property to `true` then a composite `Scheduler` is used instead. +This means that multiple scheduler implementations are kept running side by side. +Furthermore, it's possible to chose a specific implementation used to execute a scheduled method using `@Scheduled#executeWith()`. + +[source,java] +---- +class Jobs { + + @Scheduled(cron = "0 15 10 * * ?") <1> + void fireAt10AmEveryDay() { } + + @Scheduled(every = "1s", executeWith = Scheduled.SIMPLE) <2> + void everySecond() { } +} +---- +<1> If the `quarkus-quartz` extension is present then this method will be executed with the Quartz-specific scheduler. +<2> If `quarkus.scheduler.use-composite-scheduler=true` is set then this method will be executed with the simple in-memory implementation provided by the `quarkus-scheduler` extension. + == Scheduler Quarkus provides a built-in bean of type `io.quarkus.scheduler.Scheduler` that can be injected and used to pause/resume the scheduler and individual scheduled methods identified by a specific `Scheduled#identity()`.