server: log when cron triggers are fetched from database for generating events

PR-URL: https://github.com/hasura/graphql-engine-mono/pull/7725
Co-authored-by: Rob Dominguez <24390149+robertjdominguez@users.noreply.github.com>
GitOrigin-RevId: 8dd2b07c769392e057400c5e60e40e7fc56ac26f
This commit is contained in:
Rakesh Emmadi 2023-02-07 17:52:08 +05:30 committed by hasura-bot
parent 36a9de5215
commit e6c5a9505b
5 changed files with 125 additions and 13 deletions

View File

@ -61,17 +61,18 @@ All the log-types that can be enabled/disabled are:
Apart from the above, there are other internal log-types which cannot be configured: Apart from the above, there are other internal log-types which cannot be configured:
| Log type | Description | Log Level | | Log type | Description | Log Level |
|-----------------------------|-----------------------------------------------------------------------------------------------------|--------------------| |--------------------------------|-----------------------------------------------------------------------------------------------------|--------------------|
| `pg-client` | Logs from the postgres client library | `warn` | | `pg-client` | Logs from the postgres client library | `warn` |
| `metadata` | Logs inconsistent Metadata items | `warn` | | `metadata` | Logs inconsistent Metadata items | `warn` |
| `telemetry-log` | Logs error (if any) while sending out telemetry data | `info` | | `telemetry-log` | Logs error (if any) while sending out telemetry data | `info` |
| `event-trigger` | Logs HTTP responses from the webhook, HTTP exceptions and internal errors | `info` and `error` | | `event-trigger` | Logs HTTP responses from the webhook, HTTP exceptions and internal errors | `info` and `error` |
| `ws-server` | Debug logs from the websocket server, mostly used internally for debugging | `debug` | | `ws-server` | Debug logs from the websocket server, mostly used internally for debugging | `debug` |
| `schema-sync-thread` | Logs internal events, when it detects schema has changed on Postgres and when it reloads the schema | `info` and `error` | | `schema-sync-thread` | Logs internal events, when it detects schema has changed on Postgres and when it reloads the schema | `info` and `error` |
| `health-check-log` | Logs source Health Check events which includes health status of a data source | `info` and `warn` | | `health-check-log` | Logs source Health Check events which includes health status of a data source | `info` and `warn` |
| `event-trigger-process` | Logs the statistics of events fetched from database for each source | `info` and `warn` | | `event-trigger-process` | Logs the statistics of events fetched from database for each source | `info` and `warn` |
| `scheduled-trigger-process` | Logs the statistics of scheduled and cron events fetched from metadata storage | `info` and `warn` | | `scheduled-trigger-process` | Logs the statistics of scheduled and cron events fetched from metadata storage | `info` and `warn` |
| `cron-event-generator-process` | Logs the cron triggers fetched from metadata storage for events generation | `info` and `warn` |
## Logging levels ## Logging levels
@ -594,6 +595,53 @@ The `detail` field value is an object contains the following members.
| `num_one_off_scheduled_events_fetched` | int | The count of total one-off scheduled events fetched | | `num_one_off_scheduled_events_fetched` | int | The count of total one-off scheduled events fetched |
| `num_fetches` | int | The number of fetches happened within 10 minutes | | `num_fetches` | int | The number of fetches happened within 10 minutes |
### **cron-event-generator-process** log structure
Every 10 minutes, the Hasura Engine logs the cron triggers fetched from metadata storage for events generation. The
log also contains the number of times new triggers are fetched within the 10 minute timeframe.
```json
{
"detail": {
"cron_triggers": [
{
"max_scheduled_time": "2023-01-31T13:18:00Z",
"name": "every_two_minutes",
"upcoming_events_count": 99
}
],
"num_fetches": 10
},
"level": "info",
"timestamp": "2023-01-31T15:31:55.773+0530",
"type": "cron-event-generator-process"
}
```
The `type` in the log will be `cron-event-generator-process` and details of the cron event generator process will be
under the `detail` key.
The `detail` field value is an object containing the following members.
| Name | Type | Description |
|-----------------|------------------------------------|--------------------------------------------------|
| `cron_triggers` | List of `CronTriggerStats` objects | The list of cron triggers fetched |
| `num_fetches` | int | The number of fetches happened within 10 minutes |
The `CronTriggerStats` object contains the following members.
| Name | Type | Description |
|-------------------------|--------|------------------------------------------------|
| `name` | string | The name of the cron trigger |
| `upcoming_events_count` | int | The number of undelivered upcoming cron events |
| `max_scheduled_time` | string | The timestamp of the cron event occurring last |
:::info Note
A new set of cron events will be generated only for triggers with fewer than 100 upcoming events.
Thus, the `upcoming_events_count` will be always `< 100`.
:::
## Monitoring frameworks ## Monitoring frameworks
You can integrate the logs emitted by the Hasura Engine with external monitoring tools for better visibility as per your You can integrate the logs emitted by the Hasura Engine with external monitoring tools for better visibility as per your

View File

@ -786,10 +786,16 @@ mkHGEServer setupHook env ServeOptions {..} serverCtx@ServerCtx {..} ekgStore ch
startEventTriggerPollerThread logger lockedEventsCtx cacheRef startEventTriggerPollerThread logger lockedEventsCtx cacheRef
startAsyncActionsPollerThread logger lockedEventsCtx cacheRef actionSubState startAsyncActionsPollerThread logger lockedEventsCtx cacheRef actionSubState
-- Create logger for logging the statistics of fetched cron triggers
fetchedCronTriggerStatsLogger <-
allocate
(createFetchedCronTriggerStatsLogger logger)
(closeFetchedCronTriggersStatsLogger logger)
-- start a background thread to create new cron events -- start a background thread to create new cron events
_cronEventsThread <- _cronEventsThread <-
C.forkManagedT "runCronEventsGenerator" logger $ C.forkManagedT "runCronEventsGenerator" logger $
runCronEventsGenerator logger (getSchemaCache cacheRef) runCronEventsGenerator logger fetchedCronTriggerStatsLogger (getSchemaCache cacheRef)
startScheduledEventsPollerThread logger lockedEventsCtx cacheRef startScheduledEventsPollerThread logger lockedEventsCtx cacheRef
EventingDisabled -> EventingDisabled ->

View File

@ -78,6 +78,10 @@ module Hasura.Eventing.ScheduledTrigger
CronEventSeed (..), CronEventSeed (..),
LockedEventsCtx (..), LockedEventsCtx (..),
-- * Cron trigger stats logger
createFetchedCronTriggerStatsLogger,
closeFetchedCronTriggersStatsLogger,
-- * Scheduled events stats logger -- * Scheduled events stats logger
createFetchedScheduledEventsStatsLogger, createFetchedScheduledEventsStatsLogger,
closeFetchedScheduledEventsStatsLogger, closeFetchedScheduledEventsStatsLogger,
@ -166,9 +170,10 @@ runCronEventsGenerator ::
MonadMetadataStorage m MonadMetadataStorage m
) => ) =>
L.Logger L.Hasura -> L.Logger L.Hasura ->
FetchedCronTriggerStatsLogger ->
IO SchemaCache -> IO SchemaCache ->
m void m void
runCronEventsGenerator logger getSC = do runCronEventsGenerator logger cronTriggerStatsLogger getSC = do
forever $ do forever $ do
sc <- liftIO getSC sc <- liftIO getSC
-- get cron triggers from cache -- get cron triggers from cache
@ -181,6 +186,8 @@ runCronEventsGenerator logger getSC = do
-- When shutdown is initiated, we stop generating new cron events -- When shutdown is initiated, we stop generating new cron events
eitherRes <- runExceptT $ do eitherRes <- runExceptT $ do
deprivedCronTriggerStats <- liftEitherM $ getDeprivedCronTriggerStats $ Map.keys cronTriggersCache deprivedCronTriggerStats <- liftEitherM $ getDeprivedCronTriggerStats $ Map.keys cronTriggersCache
-- Log fetched deprived cron trigger stats
logFetchedCronTriggersStats cronTriggerStatsLogger deprivedCronTriggerStats
-- join stats with cron triggers and produce @[(CronTriggerInfo, CronTriggerStats)]@ -- join stats with cron triggers and produce @[(CronTriggerInfo, CronTriggerStats)]@
cronTriggersForHydrationWithStats <- cronTriggersForHydrationWithStats <-
catMaybes catMaybes
@ -1109,3 +1116,23 @@ logFetchedScheduledEventsStats ::
m () m ()
logFetchedScheduledEventsStats logger cron oneOff = logFetchedScheduledEventsStats logger cron oneOff =
logStats logger (FetchedScheduledEventsStats cron oneOff 1) logStats logger (FetchedScheduledEventsStats cron oneOff 1)
-- | Logger to accumulate stats of fetched cron triggers, for generating cron events, over a period of time and
-- log once using @'L.Logger L.Hasura'.
-- See @'createStatsLogger' for more details.
createFetchedCronTriggerStatsLogger :: (MonadIO m) => L.Logger L.Hasura -> m FetchedCronTriggerStatsLogger
createFetchedCronTriggerStatsLogger = createStatsLogger
-- | Close the fetched cron trigger stats logger.
closeFetchedCronTriggersStatsLogger ::
(MonadIO m) => L.Logger L.Hasura -> FetchedCronTriggerStatsLogger -> m ()
closeFetchedCronTriggersStatsLogger = closeStatsLogger L.cronEventGeneratorProcessType
-- | Log statistics of fetched cron triggers. See @'logStats' for more details.
logFetchedCronTriggersStats ::
(MonadIO m) =>
FetchedCronTriggerStatsLogger ->
[CronTriggerStats] ->
m ()
logFetchedCronTriggersStats logger cronTriggerStats =
logStats logger (FetchedCronTriggerStats cronTriggerStats 1)

View File

@ -2,6 +2,8 @@
module Hasura.Eventing.ScheduledTrigger.Types module Hasura.Eventing.ScheduledTrigger.Types
( CronTriggerStats (CronTriggerStats, _ctsMaxScheduledTime, _ctsName), ( CronTriggerStats (CronTriggerStats, _ctsMaxScheduledTime, _ctsName),
FetchedCronTriggerStats (..),
FetchedCronTriggerStatsLogger,
RetryContext (RetryContext, _rctxConf), RetryContext (RetryContext, _rctxConf),
ScheduledEventOp (..), ScheduledEventOp (..),
ScheduledEventWebhookPayload (ScheduledEventWebhookPayload, sewpName, sewpScheduledTime, sewpRequestTransform, sewpResponseTransform), ScheduledEventWebhookPayload (ScheduledEventWebhookPayload, sewpName, sewpScheduledTime, sewpRequestTransform, sewpResponseTransform),
@ -40,6 +42,29 @@ data CronTriggerStats = CronTriggerStats
} }
deriving (Eq) deriving (Eq)
$(J.deriveToJSON hasuraJSON ''CronTriggerStats)
data FetchedCronTriggerStats = FetchedCronTriggerStats
{ _fctsCronTriggers :: [CronTriggerStats],
_fctsNumFetches :: Int
}
deriving (Eq)
$(J.deriveToJSON hasuraJSON ''FetchedCronTriggerStats)
instance L.ToEngineLog FetchedCronTriggerStats L.Hasura where
toEngineLog stats =
(L.LevelInfo, L.cronEventGeneratorProcessType, J.toJSON stats)
instance Semigroup FetchedCronTriggerStats where
(FetchedCronTriggerStats lTriggers lFetches) <> (FetchedCronTriggerStats rTriggers rFetches) =
FetchedCronTriggerStats (lTriggers <> rTriggers) (lFetches + rFetches)
instance Monoid FetchedCronTriggerStats where
mempty = FetchedCronTriggerStats mempty 0
type FetchedCronTriggerStatsLogger = FDebounce.Trigger FetchedCronTriggerStats FetchedCronTriggerStats
data RetryContext = RetryContext data RetryContext = RetryContext
{ _rctxTries :: !Int, { _rctxTries :: !Int,
_rctxConf :: !STRetryConf _rctxConf :: !STRetryConf

View File

@ -25,6 +25,7 @@ module Hasura.Logging
eventTriggerProcessLogType, eventTriggerProcessLogType,
scheduledTriggerLogType, scheduledTriggerLogType,
scheduledTriggerProcessLogType, scheduledTriggerProcessLogType,
cronEventGeneratorProcessType,
sourceCatalogMigrationLogType, sourceCatalogMigrationLogType,
EnabledLogTypes (..), EnabledLogTypes (..),
defaultEnabledEngineLogTypes, defaultEnabledEngineLogTypes,
@ -123,6 +124,7 @@ data InternalLogTypes
| ILTEventTriggerProcess | ILTEventTriggerProcess
| ILTScheduledTrigger | ILTScheduledTrigger
| ILTScheduledTriggerProcess | ILTScheduledTriggerProcess
| ILTCronEventGeneratorProcess
| -- | internal logs for the websocket server | -- | internal logs for the websocket server
ILTWsServer ILTWsServer
| ILTPgClient | ILTPgClient
@ -142,6 +144,7 @@ instance Witch.From InternalLogTypes Text where
ILTEventTriggerProcess -> "event-trigger-process" ILTEventTriggerProcess -> "event-trigger-process"
ILTScheduledTrigger -> "scheduled-trigger" ILTScheduledTrigger -> "scheduled-trigger"
ILTScheduledTriggerProcess -> "scheduled-trigger-process" ILTScheduledTriggerProcess -> "scheduled-trigger-process"
ILTCronEventGeneratorProcess -> "cron-event-generator-process"
ILTWsServer -> "ws-server" ILTWsServer -> "ws-server"
ILTPgClient -> "pg-client" ILTPgClient -> "pg-client"
ILTMetadata -> "metadata" ILTMetadata -> "metadata"
@ -324,5 +327,8 @@ scheduledTriggerLogType = ELTInternal ILTScheduledTrigger
scheduledTriggerProcessLogType :: EngineLogType Hasura scheduledTriggerProcessLogType :: EngineLogType Hasura
scheduledTriggerProcessLogType = ELTInternal ILTScheduledTriggerProcess scheduledTriggerProcessLogType = ELTInternal ILTScheduledTriggerProcess
cronEventGeneratorProcessType :: EngineLogType Hasura
cronEventGeneratorProcessType = ELTInternal ILTCronEventGeneratorProcess
sourceCatalogMigrationLogType :: EngineLogType Hasura sourceCatalogMigrationLogType :: EngineLogType Hasura
sourceCatalogMigrationLogType = ELTInternal ILTSourceCatalogMigration sourceCatalogMigrationLogType = ELTInternal ILTSourceCatalogMigration