-
-
Notifications
You must be signed in to change notification settings - Fork 327
Observability
Since version 2.4.15rc8 mod_auth_openidc allows for collection and retrieval of a number of metrics that are designed to be used in systems monitoring and alerting tools such as Prometheus.
The OIDCMetricsData
primitive configures the top level classes of metrics that will be collected. Supported metric classes are:
-
authtype
the authentication handler type split out perAuthType
:openid-connect
,oauth20
andauth-openidc
-
redirect_uri
requests to the Redirect URI -
authn
authentication request generation and response processing -
session
existing session handling -
content
requests to the content handler, split out per types of request (info
,metrics
,jwks
, etc.)
Two types of metrics exists, counters, recorded a simple number and timings, recorded as a histogram.
[The detailed list of all metrics with their description will be included here when ready for final release in 2.4.15]
The measurements are recorded per virtual host in a local in-memory hash table for performance reasons. The local data is flushed to shared memory in a dedicated thread that runs every 5 seconds per virtual host. Notice that any data consumed on OIDCMetricsPublish
is therefore max 5 seconds behind. The shared memory is shared between all of the virtual hosts configured on the same Apache instance. Retrieval of the data on OIDCMetricsPublish
returns and resets the counters/timings for all virtual hosts.
The OIDCMetricsPublish
primitive configures where the data is published. This URL may contain sensitive data and can be protected by any available Apache mechanism (including e.g. AuthType oauth20)
. This can be done as part of the virtual host that runs mod_auth_openidc but one may also define a separate virtual host in the same Apache server to publish the data, e.g.:
<VirtualHost _default_:8443>
SSLEngine on
OIDCMetricsPublish /_mod_auth_openidc/metrics
Require ip 192.168
</VirtualHost>
Data can be retrieved configured in Prometheus format (the default) or (internal) JSON format e.g. https://localhost/_mod_auth_openidc/metrics?format=json