Enables or disables the Healthcheck of a specific performance metric service.
Synopsis
asadmin [asadmin-options] set-healthcheck-service-configuration
[--help]
[--target target]
[--enabled={false|true}]
[--dynamic={false|true}]
[--service=serviceName]
[--checker-name=checkerName]
[--add-to-microprofile-health={true|false}]
[--time=time]
[--time-unit={DAYS|HOURS|MINUTES|SECONDS|MILLISECONDS}]
[--threshold-critical=threshold]
[--threshold-warning=threshold]
[--threshold-good=threshold]
[--hogging-threads-threshold=threshold]
[--hogging-threads-retry-count=count]
[--stuck-threads-threshold=threshold]
[--stuck-threads-threshold-unit={DAYS|HOURS|MINUTES|SECONDS|MILLISECONDS}]
[--add-metric=metricName]
[--delete-metric=metricName]
Description
Enables and disables the monitoring of a HealthCheck performance metric service. The command also configures the frequency of monitoring for that metric.
The command can also be used to configures performance metric specific properties.
If this command is run before running the set-healthcheck-configuration command, it will succeed and the configuration will be saved, but the Healthcheck service will not be enabled until the command is used.
|
Options
- asadmin-options
-
Options for the
asadmin
utility. For information about these options, see theasadmin
help page. --help
-?
-
Displays the help text for the subcommand.
--target
-
This option helps specify the target on which you are configuring the Healthcheck performance metric service. Valid values are:
server
-
Applies to the default server instance. This is the default value.
- cluster_name
-
Applies to every server instance in the cluster.
- instance_name
-
Applies to a specified server instance.
--enabled
-
Defaults to
false
. Enables or disables the healthcheck performance metric service --dynamic
-
Defaults to
false
. When set totrue
, applies the changes without a server restart. --service
-
The performance service metric name. Required.
One of:
-
connection-pool
orcp
-
cpu-usage
orcu
-
garbage-collector
orgc
-
heap-memory-usage
orhmu
-
hogging-threads
orht
-
machine-memory-usage
ormmu
-
stuck-thread
orst
-
mp-health
ormh
-
mp-metrics
ormm
-
--checker-name
-
A user determined name for easy identification of the checker.
This should be unique among the services you have configured, to avoid confusion on the notification messages.
Depends on the service checker. One of:
-
CONP
-
CPUC
-
GBGC
-
HEAP
-
HOGT
-
MEMM
-
MP
-
MPM
-
--add-to-microprofile-health
-
Defaults to
false
. When enabled, the checker results are displayed on MicroProfile Health REST endpoints as a readiness check. --time
-
Defaults to
5
. The amount of time units that the service will use to periodically monitor the metric. --time-unit
-
Defaults to
MINUTES
. The time unit to set the frequency of the metric monitoring.Must correspond to a valid java.util.concurrent.TimeUnit
--threshold-critical
-
Defaults to
90
. The threshold value that this metric must surpass to generate aCRITICAL
event.A value between WARNING VALUE and
100
must be used.Available for the cp
,cu
,gc
,hmu
andmmu
metric services. --threshold-warning
-
Defaults to
50
. The threshold value that this metric must surpass to generate aWARNING
event.A value between GOOD VALUE and WARNING VALUE must be used.
Available for the cp
,cu
,gc
,hmu
andmmu
metric services. --threshold-good
-
Defaults to
0
. The threshold value that this metric must surpass to generate aGOOD
event.A value between
0
and WARNING VALUE must be used.Available for the cp
,cu
,gc
,hmu
andmmu
metric services. --hogging-threads-threshold
-
Defaults to
95
. The threshold value that this metric will be compared to mark threads as hogging the CPU.Only available for the ht
metric service. --hogging-threads-retry-count
-
Defaults to
3
. The number of retries that the checker service will execute in order to identify a hogging thread.Only available for the ht
metric service. --stuck-threads-threshold
-
The threshold above which a thread is considered stuck. Must be
1
or greater.Only available for the st
metric service. --stuck-threads-threshold-unit
-
The unit for the threshold for when a thread should be considered stuck.
Must correspond to a valid java.util.concurrent.TimeUnit
Only available for the st
metric service. --add-metric
-
Adds a metric exposed by Eclipse MicroProfile Metrics to monitor.
Takes a string of the format
'metricName=MetricName description=Description'
, wheremetricName
is a mandatory value. --delete-metric
-
Removes a metric exposed by MicroProfile Metrics that has been added to monitor. Takes a string of the format
'metricName=MetricName'
, wheremetricName
is required.
Examples
Example 1 Basic Configuration
A very basic example command to simply enable the Garbage Collector checker service and activate it without needing a restart would be as follows:
asadmin set-healthcheck-service-configuration --enabled=true --service=gc --dynamic=true
Example 2 Setting up thresholds for configuring JDBC Connection Pools health monitoring
Monitoring the health of JDBC connection pools is a common need. In that scenario, it is very unlikely that on-the-fly configuration changes would be made, so a very high CRITICAL
threshold can be set.
Likewise, a nonzero GOOD
threshold is needed because an empty or unused connection pool may not be healthy either.
The following command would apply these settings to the connection pool checker:
asadmin set-healthcheck-service-configuration --service=cp --dynamic=true --threshold-critical=95 --threshold-warning=70 --threshold-good=30
Example 3 Setting up thresholds for identifying CPU hogging threads
Monitoring which threads hog the CPU is extremely important since this can lead to performance degradation, deadlocks and extreme bottlenecks issues that web applications can incur.
In some cases the defaults are all that is needed, but imagine that in a critical system you want to set the threshold percentage to 90%, and you want to make sure that the health check service guarantees the state of such threads with a retry count of 5.
Additionally, you want to set the frequency of this check for every 20 seconds.
The following command would apply these settings to the Hogging threads checker service:
asadmin> set-healthcheck-service-configuration --service=ht --dynamic=true --hogging-threads-threshold=90 --hogging-threads-retry-count=5 --time=20 --time-unit=SECONDS
Example 4 Setting up thresholds for identifying stuck threads
The following example configures the stuck threads checker to check every 30 seconds for any threads which have been stuck for more than 5 minutes and applies the configuration change without needing a restart:
asadmin set-healthcheck-service-configuration --service=st --enabled=true --dynamic=true --time=30 --time-unit=SECONDS --stuck-threads-threshold=5 --stuck-threads-threshold-unit=MINUTES
Example 5 Setting up thresholds adding a MicroProfile Metrics check for the maximum thread count:
The following example configures the Microprofile Metrics Checker to add base_thread_max_count
metrics for monitoring, adds the checker to MicroProfile Health to display its result on MicroProfile Health REST endpoints and applies the configuration change without needing a restart:
asadmin set-healthcheck-service-configuration --service=mp-metrics --enabled=true --dynamic=true --add-to-microprofile-health=true --add-metric='metricName=base_thread_max_count'