-
Notifications
You must be signed in to change notification settings - Fork 304
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
HPCC-32465 Add ESP support for trace level
- Define an ESP process configuration node that supports specification of global TraceFlags values for each ESP. - Reserve traceDetail to request a specific trace level (0: none, 1: standard, 2: detailed, 3: max). This replaces acting on the last observed occurrence of either traceNone, traceStandard, traceDetailed, and traceMax. - Override default flag settings when not configured and a debug build. Signed-off-by: Tim Klemm <[email protected]>
- Loading branch information
Tim Klemm
authored and
Tim Klemm
committed
Dec 9, 2024
1 parent
ea1047a
commit caa4517
Showing
6 changed files
with
196 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
/*############################################################################## | ||
HPCC SYSTEMS software Copyright (C) 2024 HPCC Systems®. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
############################################################################## */ | ||
|
||
#pragma once | ||
|
||
#include "jtrace.hpp" | ||
#include <initializer_list> | ||
|
||
// Refer to helm/examples/esp/README.md for more information on the trace options. | ||
|
||
constexpr const char* propTraceFlags = "traceFlags"; | ||
|
||
// Trace option list fragment for jtrace-defined options used by ESPs | ||
#define PLATFORM_OPTIONS_FRAGMENT | ||
|
||
// Trace option list fragment for options used by most ESPs | ||
#define ESP_OPTIONS_FRAGMENT \ | ||
PLATFORM_OPTIONS_FRAGMENT \ | ||
TRACEOPT(traceDetail), | ||
|
||
// Trace option initializer list for ESPs that do not define their own options. | ||
constexpr std::initializer_list<TraceOption> espTraceOptions | ||
{ | ||
ESP_OPTIONS_FRAGMENT | ||
}; | ||
|
||
/** | ||
* @brief Returns the trace options appropriate for the ESP process being initialized. | ||
* | ||
* Most ESPs will simply return espTraceOptions. Any ESP that defines options not applicable to | ||
* other ESPs would return a different list. The determination of which list to return is | ||
* expected to be based on the configuration's `application` property. | ||
* | ||
* If options for all ESPs are defined with no value collisions, there may be no need to define | ||
* separate option lists for individual ESPs. However, if value collisions cannot be avoided, | ||
* separate lists will be needed. | ||
* | ||
* Consider ESDL Script, and the applications that use it. The potential for a significant number | ||
* of options is high, increasing the likelihood of collisions with applications that don't use it. | ||
*/ | ||
inline const std::initializer_list<TraceOption>& mapTraceOptions(const IPTree* config) | ||
{ | ||
return espTraceOptions; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
# ESP Trace Flags | ||
|
||
Each ESP process may specify its own set of flags for controlling trace behavior. The specific flags may be shared with other platform components, shared amongst ESPs, or unique to an ESP. | ||
|
||
## Accepted Flags | ||
|
||
Detailed description of flags used by any ESP. | ||
|
||
### Shared Platform Flags | ||
|
||
Flags defined in `system/jlib/jtrace.hpp` and used by multiple platform processes. | ||
|
||
Flags will be added to this list as tracing logic is updated in ESP code. For example, the shared platform flag `traceHttp` is expected to be used, as are a number of ESP-specific options. | ||
|
||
### Shared ESP Flags | ||
|
||
Flags defined in `esp/platform/esptrace.h` and applicable to most, if not all, ESP configurations. | ||
|
||
#### traceDetail | ||
|
||
Set the default trace level in the process. Accepted case-insensitive values are: | ||
- `1`, `standard`: most important output | ||
- `2`, `detailed`: average verbosity output | ||
- `3`, `max`: highest verbosity output | ||
- `default`: use existing level | ||
- Release builds default to `standard` | ||
- Debug builds default to `max` | ||
- `0`, `none`, *all other values*: no trace output | ||
|
||
## Process Configuration | ||
|
||
### Containerized | ||
|
||
#### esp.yaml | ||
|
||
Each ESP application's configuration object may embed one instance of a `traceFlags` object. Within this object, at most one property per [accepted flag](#accepted-flags) is expected. Properties not described here are ignored. | ||
|
||
For example, the `eclwatch` process might be configured to use detailed reporting like this: | ||
|
||
```yml | ||
esp: | ||
- name: eclwatch | ||
traceFlags: | ||
traceDetail: 2 | ||
``` | ||
## Cluster Overrides | ||
A values file may be used with the `helm install` command to override the settings of all ESPs. The `--set` option may be used to target the settings of a specific ESP in the configured array. | ||
|
||
### Bare-Metal | ||
|
||
No support for defining trace flags is provided by the `configmgr` application. Within a stand-alone `esp.xml` file, however, a `traceFlags` child of the `EspProcess` element may be defined. | ||
|
||
The previous YAML example may be reproduced in XML with the following: | ||
|
||
```xml | ||
<EspProcess ...> | ||
<traceFlags traceDetail="2" /> | ||
... | ||
<EspProcess> | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters