integration_test/third_party_apps_test/applications/tomcat/metadata.yaml (209 lines of code) (raw):

# Copyright 2022 Google LLC # # 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. public_url: "https://cloud.google.com/stackdriver/docs/solutions/agents/ops-agent/third-party/tomcat" app_url: "https://tomcat.apache.org/" short_name: Tomcat long_name: Apache Tomcat logo_path: /images/launcher/logos/tomcat.png # supplied by google technical writer description: |- The Apache Tomcat integration collects traffic-related metrics, such as the number of active sessions or network throughput. The integration also collects access and Catalina logs. Access logs are parsed into a JSON payload focused on request details, whereas Catalina logs are parsed for general details. The `tomcat` receiver collects telemetry from the Tomcat server's Java Virtual Machine (JVM) via [JMX](https://www.oracle.com/java/technologies/javase/javamanagement.html). configure_integration: |- To expose a JMX endpoint, you must set the `com.sun.management.jmxremote.port` system property when starting the JVM. We also recommend setting the `com.sun.management.jmxremote.rmi.port` system property to the same port. To expose a JMX endpoint remotely, you must also set the `java.rmi.server.hostname` system property. By default, these properties are set in a Tomcat deployment's `tomcat-env.sh` file. To set system properties by using command-line arguments, prepend the property name with `-D` when starting the JVM. For example, to set `com.sun.management.jmxremote.port` to port `8050`, specify the following when starting the JVM: <pre> -Dcom.sun.management.jmxremote.port=8050 </pre> minimum_supported_agent_version: metrics: 2.9.0 logging: 2.9.0 supported_operating_systems: linux supported_app_version: ["10.x", "9.0.x"] expected_metrics: - type: workload.googleapis.com/tomcat.errors value_type: INT64 kind: CUMULATIVE monitored_resources: [gce_instance] labels: - name: proto_handler value_regex: .* - type: workload.googleapis.com/tomcat.max_time value_type: INT64 kind: GAUGE monitored_resources: [gce_instance] labels: - name: proto_handler value_regex: .* - type: workload.googleapis.com/tomcat.processing_time value_type: INT64 kind: CUMULATIVE monitored_resources: [gce_instance] labels: - name: proto_handler value_regex: .* - type: workload.googleapis.com/tomcat.request_count value_type: INT64 kind: CUMULATIVE monitored_resources: [gce_instance] labels: - name: proto_handler value_regex: .* - type: workload.googleapis.com/tomcat.sessions value_type: DOUBLE kind: GAUGE monitored_resources: [gce_instance] - type: workload.googleapis.com/tomcat.threads value_type: INT64 kind: GAUGE monitored_resources: [gce_instance] labels: - name: proto_handler value_regex: .* - name: state value_regex: .* representative: true - type: workload.googleapis.com/tomcat.traffic value_type: INT64 kind: CUMULATIVE monitored_resources: [gce_instance] labels: - name: direction value_regex: .* - name: proto_handler value_regex: .* expected_logs: - log_name: tomcat_system fields: - name: jsonPayload.message value_regex: org.apache.catalina.startup.Catalina.start Server startup.* type: string description: Log message, including detailed stacktrace where provided - name: jsonPayload.module value_regex: main type: string description: Module of tomcat where the log originated - name: jsonPayload.source value_regex: org.apache.catalina.startup.Catalina.start type: string description: Source of where the log originated - name: jsonPayload.level type: string description: Log entry level optional: true - name: severity type: string description: '' - log_name: tomcat_access fields: - name: httpRequest.remoteIp value_regex: 127.0.0.1 type: string description: '' optional: true - name: httpRequest.requestUrl value_regex: /forbidden.html type: string description: '' optional: true - name: httpRequest.protocol value_regex: HTTP/1.1 type: string description: '' optional: true - name: httpRequest.requestMethod value_regex: GET type: string description: '' optional: true - name: httpRequest.responseSize type: string description: '' optional: true - name: httpRequest.userAgent type: string description: '' optional: true - name: httpRequest.status type: string description: '' optional: true - name: jsonPayload.host type: string description: Contents of the Host header optional: true - name: jsonPayload.user type: string optional: true description: Authenticated username for the request - name: severity type: string description: '' optional: true configuration_options: logs: - type: tomcat_system fields: - name: type default: null description: The value must be `tomcat_system`. - name: include_paths default: '[/opt/tomcat/logs/catalina.out]' description: A list of filesystem paths to read by tailing each file. A wild card (`*`) can be used in the paths. - name: exclude_paths default: null description: A list of filesystem path patterns to exclude from the set matched by `include_paths`. - name: record_log_file_path default: false description: If set to `true`, then the path to the specific file from which the log record was obtained appears in the output log entry as the value of the `agent.googleapis.com/log_file_path` label. When using a wildcard, only the path of the file from which the record was obtained is recorded. - name: wildcard_refresh_interval default: 60s description: The interval at which wildcard file paths in `include_paths` are refreshed. Given as a [time duration](https://pkg.go.dev/time#ParseDuration), for example `30s` or `2m`. This property might be useful under high logging throughputs where log files are rotated faster than the default interval. - type: tomcat_access fields: - name: type default: null description: The value must be `tomcat_access`. - name: include_paths default: '[/opt/tomcat/logs/localhost_access_log*.txt]' description: A list of filesystem paths to read by tailing each file. A wild card (`*`) can be used in the paths. - name: exclude_paths default: null description: A list of filesystem path patterns to exclude from the set matched by `include_paths`. - name: record_log_file_path default: false description: If set to `true`, then the path to the specific file from which the log record was obtained appears in the output log entry as the value of the `agent.googleapis.com/log_file_path` label. When using a wildcard, only the path of the file from which the record was obtained is recorded. - name: wildcard_refresh_interval default: 60s description: The interval at which wildcard file paths in `include_paths` are refreshed. Given as a [time duration](https://pkg.go.dev/time#ParseDuration), for example `30s` or `2m`. This property might be useful under high logging throughputs where log files are rotated faster than the default interval. metrics: - type: tomcat fields: - name: type default: null description: This value must be `tomcat`. - name: endpoint default: localhost:8050 description: The [JMX Service URL](https://docs.oracle.com/javase/8/docs/api/javax/management/remote/JMXServiceURL.html) or host and port used to construct the service URL. This value must be in the form of `service:jmx:<protocol>:<sap>` or `host:port`. Values in `host:port` form are used to create a service URL of `service:jmx:rmi:///jndi/rmi://<host>:<port>/jmxrmi`. - name: collect_jvm_metrics default: true description: Configures the receiver to also collect the supported JVM metrics. - name: username default: null description: The configured username if JMX is configured to require authentication. - name: password default: null description: The configured password if JMX is configured to require authentication. - name: collection_interval default: 60s description: A [time duration](https://pkg.go.dev/time#ParseDuration) value, such as `30s` or `5m`.