This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Este contenido no está disponible en el idioma seleccionado.
Metering
Configuring and using Metering in OpenShift Container Platform
Abstract
Chapter 1. About Metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
1.1. Metering overview
Metering is a general purpose data analysis tool that enables you to write reports to process data from different data sources. As a cluster administrator, you can use metering to analyze what is happening in your cluster. You can either write your own, or use predefined SQL queries to define how you want to process data from the different data sources you have available.
Metering focuses primarily on in-cluster metric data using Prometheus as a default data source, enabling users of metering to do reporting on pods, namespaces, and most other Kubernetes resources.
You can install metering on OpenShift Container Platform 4.x clusters and above.
1.1.1. Installing metering
You can install metering using the CLI and the web console on OpenShift Container Platform 4.x and above. To learn more, see installing metering.
1.1.2. Upgrading metering
You can upgrade metering by updating the Metering Operator subscription. Review the following tasks:
- 
							The MeteringConfigcustom resource specifies all the configuration details for your metering installation. When you first install the metering stack, a defaultMeteringConfigcustom resource is generated. Use the examples in the documentation to modify this default file.
- 
							A report custom resource provides a method to manage periodic Extract Transform and Load (ETL) jobs using SQL queries. Reports are composed from other metering resources, such as ReportQueryresources that provide the actual SQL query to run, andReportDataSourceresources that define the data available to theReportQueryandReportresources.
1.1.3. Using metering
You can use metering for writing reports and viewing report results. To learn more, see examples of using metering.
1.1.4. Troubleshooting metering
You can use the following sections to troubleshoot specific issues with metering.
- Not enough compute resources
- 
							StorageClassresource not configured
- Secret not configured correctly
1.1.5. Debugging metering
You can use the following sections to debug specific issues with metering.
- Get reporting Operator logs
- Query Presto using presto-cli
- Query Hive using beeline
- Port-forward to the Hive web UI
- Port-forward to HDFS
- Metering Ansible Operator
1.1.6. Uninstalling metering
You can remove and clean metering resources from your OpenShift Container Platform cluster. To learn more, see uninstalling metering.
1.1.7. Metering resources
Metering has many resources which can be used to manage the deployment and installation of metering, as well as the reporting functionality metering provides.
Metering is managed using the following custom resource definitions (CRDs):
| MeteringConfig | Configures the metering stack for deployment. Contains customizations and configuration options to control each component that makes up the metering stack. | 
| Report | Controls what query to use, when, and how often the query should be run, and where to store the results. | 
| ReportQuery | 
									Contains the SQL queries used to perform analysis on the data contained within  | 
| ReportDataSource | 
									Controls the data available to  | 
Chapter 2. Installing metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
Review the following sections before installing metering into your cluster.
			To get started installing metering, first install the Metering Operator from OperatorHub. Next, configure your instance of metering by creating a MeteringConfig custom resource (CR). Installing the Metering Operator creates a default MeteringConfig resource that you can modify using the examples in the documentation. After creating your MeteringConfig resource, install the metering stack. Last, verify your installation.
		
2.1. Prerequisites
Metering requires the following components:
- 
						A StorageClassresource for dynamic volume provisioning. Metering supports a number of different storage solutions.
- 4GB memory and 4 CPU cores available cluster capacity and at least one node with 2 CPU cores and 2GB memory capacity available.
- The minimum resources needed for the largest single pod installed by metering are 2GB of memory and 2 CPU cores. - Memory and CPU consumption may often be lower, but will spike when running reports, or collecting data for larger clusters.
 
2.2. Installing the Metering Operator
You can install metering by deploying the Metering Operator. The Metering Operator creates and manages the components of the metering stack.
					You cannot create a project starting with openshift- using the web console or by using the oc new-project command in the CLI.
				
					If the Metering Operator is installed using a namespace other than openshift-metering, the metering reports are only viewable using the CLI. It is strongly suggested throughout the installation steps to use the openshift-metering namespace.
				
2.2.1. Installing metering using the web console
You can use the OpenShift Container Platform web console to install the Metering Operator.
Procedure
- Create a namespace object YAML file for the Metering Operator with the - oc create -f <file-name>.yamlcommand. You must use the CLI to create the namespace. For example,- metering-namespace.yaml:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							In the OpenShift Container Platform web console, click Operators → OperatorHub. Filter for meteringto find the Metering Operator.
- Click the Metering card, review the package description, and then click Install.
- Select an Update Channel, Installation Mode, and Approval Strategy.
- Click Install.
- Verify that the Metering Operator is installed by switching to the Operators → Installed Operators page. The Metering Operator has a Status of Succeeded when the installation is complete. Note- It might take several minutes for the Metering Operator to appear. 
- Click Metering on the Installed Operators page for Operator Details. From the Details page you can create different resources related to metering.
					To complete the metering installation, create a MeteringConfig resource to configure metering and install the components of the metering stack.
				
2.2.2. Installing metering using the CLI
You can use the OpenShift Container Platform CLI to install the Metering Operator.
Procedure
- Create a - Namespaceobject YAML file for the Metering Operator. You must use the CLI to create the namespace. For example,- metering-namespace.yaml:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - Namespaceobject:- oc create -f <file-name>.yaml - $ oc create -f <file-name>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For example: - oc create -f openshift-metering.yaml - $ oc create -f openshift-metering.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - OperatorGroupobject YAML file. For example,- metering-og:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - Subscriptionobject YAML file to subscribe a namespace to the Metering Operator. This object targets the most recently released version in the- redhat-operatorscatalog source. For example,- metering-sub.yaml:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name is arbitrary.
- 2
- You must specify theopenshift-meteringnamespace.
- 3
- Specify 4.7 as the channel.
- 4
- Specify theredhat-operatorscatalog source, which contains themetering-ocppackage manifests. If your OpenShift Container Platform is installed on a restricted network, also known as a disconnected cluster, specify the name of theCatalogSourceobject you created when you configured the Operator LifeCycle Manager (OLM).
- 5
- Specify "Automatic" install plan approval.
 
2.3. Installing the metering stack
After adding the Metering Operator to your cluster you can install the components of metering by installing the metering stack.
2.4. Prerequisites
- Review the configuration options
- Create a - MeteringConfigresource. You can begin the following process to generate a default- MeteringConfigresource, then use the examples in the documentation to modify this default file for your specific installation. Review the following topics to create your- MeteringConfigresource:- For configuration options, review About configuring metering.
- At a minimum, you need to configure persistent storage and configure the Hive metastore.
 
					There can only be one MeteringConfig resource in the openshift-metering namespace. Any other configuration is not supported.
				
Procedure
- 
						From the web console, ensure you are on the Operator Details page for the Metering Operator in the openshift-meteringproject. You can navigate to this page by clicking Operators → Installed Operators, then selecting the Metering Operator.
- Under Provided APIs, click Create Instance on the Metering Configuration card. This opens a YAML editor with the default - MeteringConfigresource file where you can define your configuration.Note- For example configuration files and all supported configuration options, review the configuring metering documentation. 
- 
						Enter your MeteringConfigresource into the YAML editor and click Create.
				The MeteringConfig resource begins to create the necessary resources for your metering stack. You can now move on to verifying your installation.
			
2.5. Verifying the metering installation
You can verify the metering installation by performing any of the following checks:
- Check the Metering Operator - ClusterServiceVersion(CSV) resource for the metering version. This can be done through either the web console or CLI.- Procedure (UI) - 
								Navigate to Operators → Installed Operators in the openshift-meteringnamespace.
- Click Metering Operator.
- Click Subscription for Subscription Details.
- Check the Installed Version.
 - Procedure (CLI) - Check the Metering Operator CSV in the - openshift-meteringnamespace:- oc --namespace openshift-metering get csv - $ oc --namespace openshift-metering get csv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME DISPLAY VERSION REPLACES PHASE elasticsearch-operator.4.7.0-202006231303.p0 OpenShift Elasticsearch Operator 4.7.0-202006231303.p0 Succeeded metering-operator.v4.7.0 Metering 4.7.0 Succeeded - NAME DISPLAY VERSION REPLACES PHASE elasticsearch-operator.4.7.0-202006231303.p0 OpenShift Elasticsearch Operator 4.7.0-202006231303.p0 Succeeded metering-operator.v4.7.0 Metering 4.7.0 Succeeded- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
								Navigate to Operators → Installed Operators in the 
- Check that all required pods in the - openshift-meteringnamespace are created. This can be done through either the web console or CLI.Note- Many pods rely on other components to function before they themselves can be considered ready. Some pods may restart if other pods take too long to start. This is to be expected during the Metering Operator installation. - Procedure (UI) - Navigate to Workloads → Pods in the metering namespace and verify that pods are being created. This can take several minutes after installing the metering stack.
 - Procedure (CLI) - Check that all required pods in the - openshift-meteringnamespace are created:- oc -n openshift-metering get pods - $ oc -n openshift-metering get pods- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Verify that the - ReportDataSourceresources are beginning to import data, indicated by a valid timestamp in the- EARLIEST METRICcolumn. This might take several minutes. Filter out the "-raw"- ReportDataSourceresources, which do not import data:- oc get reportdatasources -n openshift-metering | grep -v raw - $ oc get reportdatasources -n openshift-metering | grep -v raw- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
After all pods are ready and you have verified that data is being imported, you can begin using metering to collect data and report on your cluster.
Chapter 3. Upgrading metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
You can upgrade metering to 4.7 by updating the Metering Operator subscription.
3.1. Prerequisites
- The cluster is updated to 4.7.
- The Metering Operator is installed from OperatorHub. Note- You must upgrade the Metering Operator to 4.7 manually. Metering does not upgrade automatically if you selected the "Automatic" Approval Strategy in a previous installation. 
- The MeteringConfig custom resource is configured.
- The metering stack is installed.
- Ensure that metering status is healthy by checking that all pods are ready.
Potential data loss can occur if you modify your metering storage configuration after installing or upgrading metering.
Procedure
- Click Operators → Installed Operators from the web console.
- 
						Select the openshift-meteringproject.
- Click Metering Operator.
- Click Subscription → Channel.
- In the Change Subscription Update Channel window, select 4.7 and click Save. Note- Wait several seconds to allow the subscription to update before proceeding to the next step. 
- Click Operators → Installed Operators. - The Metering Operator is shown as 4.7. For example: - Metering 4.7.0-202007012112.p0 provided by Red Hat, Inc - Metering 4.7.0-202007012112.p0 provided by Red Hat, Inc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
You can verify the metering upgrade by performing any of the following checks:
- Check the Metering Operator cluster service version (CSV) for the new metering version. This can be done through either the web console or CLI. - Procedure (UI) - Navigate to Operators → Installed Operators in the metering namespace.
- Click Metering Operator.
- Click Subscription for Subscription Details.
- Check the Installed Version for the upgraded metering version. The Starting Version shows the metering version prior to upgrading.
 - Procedure (CLI) - Check the Metering Operator CSV: - oc get csv | grep metering - $ oc get csv | grep metering- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output for metering upgrade from 4.6 to 4.7 - NAME DISPLAY VERSION REPLACES PHASE metering-operator.4.7.0-202007012112.p0 Metering 4.7.0-202007012112.p0 metering-operator.4.6.0-202007012112.p0 Succeeded - NAME DISPLAY VERSION REPLACES PHASE metering-operator.4.7.0-202007012112.p0 Metering 4.7.0-202007012112.p0 metering-operator.4.6.0-202007012112.p0 Succeeded- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Check that all required pods in the - openshift-meteringnamespace are created. This can be done through either the web console or CLI.Note- Many pods rely on other components to function before they themselves can be considered ready. Some pods may restart if other pods take too long to start. This is to be expected during the Metering Operator upgrade. - Procedure (UI) - Navigate to Workloads → Pods in the metering namespace and verify that pods are being created. This can take several minutes after upgrading the metering stack.
 - Procedure (CLI) - Check that all required pods in the - openshift-meteringnamespace are created:- oc -n openshift-metering get pods - $ oc -n openshift-metering get pods- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Verify that the - ReportDataSourceresources are importing new data, indicated by a valid timestamp in the- NEWEST METRICcolumn. This might take several minutes. Filter out the "-raw"- ReportDataSourceresources, which do not import data:- oc get reportdatasources -n openshift-metering | grep -v raw - $ oc get reportdatasources -n openshift-metering | grep -v raw- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Timestamps in the - NEWEST METRICcolumn indicate that- ReportDataSourceresources are beginning to import new data.- Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
After all pods are ready and you have verified that new data is being imported, metering continues to collect data and report on your cluster. Review a previously scheduled report or create a run-once metering report to confirm the metering upgrade.
Chapter 4. Configuring metering
4.1. About configuring metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
				The MeteringConfig custom resource specifies all the configuration details for your metering installation. When you first install the metering stack, a default MeteringConfig custom resource is generated. Use the examples in the documentation to modify this default file. Keep in mind the following key points:
			
- At a minimum, you need to configure persistent storage and configure the Hive metastore.
- Most default configuration settings work, but larger deployments or highly customized deployments should review all configuration options carefully.
- Some configuration options can not be modified after installation.
				For configuration options that can be modified after installation, make the changes in your MeteringConfig custom resource and reapply the file.
			
4.2. Common configuration options
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
4.2.1. Resource requests and limits
					You can adjust the CPU, memory, or storage resource requests and/or limits for pods and volumes. The default-resource-limits.yaml below provides an example of setting resource request and limits for each component.
				
4.2.2. Node selectors
					You can run the metering components on specific sets of nodes. Set the nodeSelector on a metering component to control where the component is scheduled. The node-selectors.yaml file below provides an example of setting node selectors for each component.
				
						Add the openshift.io/node-selector: "" namespace annotation to the metering namespace YAML file before configuring specific node selectors for the operand pods. Specify "" as the annotation value.
					
						Add the openshift.io/node-selector: "" namespace annotation to the metering namespace YAML file before configuring specific node selectors for the operand pods. When the openshift.io/node-selector annotation is set on the project, the value is used in preference to the value of the spec.defaultNodeSelector field in the cluster-wide Scheduler object.
					
Verification
You can verify the metering node selectors by performing any of the following checks:
- Verify that all pods for metering are correctly scheduled on the IP of the node that is configured in the - MeteringConfigcustom resource:- Check all pods in the - openshift-meteringnamespace:- oc --namespace openshift-metering get pods -o wide - $ oc --namespace openshift-metering get pods -o wide- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output shows the - NODEand corresponding- IPfor each pod running in the- openshift-meteringnamespace.- Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Compare the nodes in the - openshift-meteringnamespace to each node- NAMEin your cluster:- oc get nodes - $ oc get nodes- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Verify that the node selector configuration in the - MeteringConfigcustom resource does not interfere with the cluster-wide node selector configuration such that no metering operand pods are scheduled.- Check the cluster-wide - Schedulerobject for the- spec.defaultNodeSelectorfield, which shows where pods are scheduled by default:- oc get schedulers.config.openshift.io cluster -o yaml - $ oc get schedulers.config.openshift.io cluster -o yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
4.3. Configuring persistent storage
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
Metering requires persistent storage to persist data collected by the Metering Operator and to store the results of reports. A number of different storage providers and storage formats are supported. Select your storage provider and modify the example configuration files to configure persistent storage for your metering installation.
4.3.1. Storing data in Amazon S3
Metering can use an existing Amazon S3 bucket or create a bucket for storage.
Metering does not manage or delete any S3 bucket data. You must manually clean up S3 buckets that are used to store metering data.
Procedure
- Edit the - spec.storagesection in the- s3-storage.yamlfile:- Example - s3-storage.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the name of the bucket where you would like to store your data. Optional: Specify the path within the bucket.
- 2
- Specify the region of your bucket.
- 3
- The name of a secret in the metering namespace containing the AWS credentials in thedata.aws-access-key-idanddata.aws-secret-access-keyfields. See the exampleSecretobject below for more details.
- 4
- Set this field tofalseif you want to provide an existing S3 bucket, or if you do not want to provide IAM credentials that haveCreateBucketpermissions.
 
- Use the following - Secretobject as a template:- Example AWS - Secretobject- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- The values of the - aws-access-key-idand- aws-secret-access-keymust be base64 encoded.
- Create the secret: - oc create secret -n openshift-metering generic my-aws-secret \ --from-literal=aws-access-key-id=my-access-key \ --from-literal=aws-secret-access-key=my-secret-key - $ oc create secret -n openshift-metering generic my-aws-secret \ --from-literal=aws-access-key-id=my-access-key \ --from-literal=aws-secret-access-key=my-secret-key- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- This command automatically base64 encodes your - aws-access-key-idand- aws-secret-access-keyvalues.
					The aws-access-key-id and aws-secret-access-key credentials must have read and write access to the bucket. The following aws/read-write.json file shows an IAM policy that grants the required permissions:
				
Example aws/read-write.json file
					If spec.storage.hive.s3.createBucket is set to true or unset in your s3-storage.yaml file, then you should use the aws/read-write-create.json file that contains permissions for creating and deleting buckets:
				
Example aws/read-write-create.json file
4.3.2. Storing data in S3-compatible storage
You can use S3-compatible storage such as Noobaa.
Procedure
- Edit the - spec.storagesection in the- s3-compatible-storage.yamlfile:- Example - s3-compatible-storage.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the following - Secretobject as a template:- Example S3-compatible - Secretobject- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.3.3. Storing data in Microsoft Azure
To store data in Azure blob storage, you must use an existing container.
Procedure
- Edit the - spec.storagesection in the- azure-blob-storage.yamlfile:- Example - azure-blob-storage.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the following - Secretobject as a template:- Example Azure - Secretobject- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the secret: - oc create secret -n openshift-metering generic my-azure-secret \ --from-literal=azure-storage-account-name=my-storage-account-name \ --from-literal=azure-secret-access-key=my-secret-key - $ oc create secret -n openshift-metering generic my-azure-secret \ --from-literal=azure-storage-account-name=my-storage-account-name \ --from-literal=azure-secret-access-key=my-secret-key- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.3.4. Storing data in Google Cloud Storage
To store your data in Google Cloud Storage, you must use an existing bucket.
Procedure
- Edit the - spec.storagesection in the- gcs-storage.yamlfile:- Example - gcs-storage.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the following - Secretobject as a template:- Example Google Cloud Storage - Secretobject- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the secret: - oc create secret -n openshift-metering generic my-gcs-secret \ --from-file gcs-service-account.json=/path/to/my/service-account-key.json - $ oc create secret -n openshift-metering generic my-gcs-secret \ --from-file gcs-service-account.json=/path/to/my/service-account-key.json- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4. Configuring the Hive metastore
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
Hive metastore is responsible for storing all the metadata about the database tables created in Presto and Hive. By default, the metastore stores this information in a local embedded Derby database in a persistent volume attached to the pod.
Generally, the default configuration of the Hive metastore works for small clusters, but users may wish to improve performance or move storage requirements out of cluster by using a dedicated SQL database for storing the Hive metastore data.
4.4.1. Configuring persistent volumes
By default, Hive requires one persistent volume to operate.
					hive-metastore-db-data is the main persistent volume claim (PVC) required by default. This PVC is used by the Hive metastore to store metadata about tables, such as table name, columns, and location. Hive metastore is used by Presto and the Hive server to look up table metadata when processing queries. You remove this requirement by using MySQL or PostgreSQL for the Hive metastore database.
				
To install, Hive metastore requires that dynamic volume provisioning is enabled in a storage class, a persistent volume of the correct size must be manually pre-created, or you use a pre-existing MySQL or PostgreSQL database.
4.4.1.1. Configuring the storage class for the Hive metastore
						To configure and specify a storage class for the hive-metastore-db-data persistent volume claim, specify the storage class in your MeteringConfig custom resource. An example storage section with the class field is included in the metastore-storage.yaml file below.
					
- 1
- Uncomment this line and replacenullwith the name of the storage class to use. Leaving the valuenullwill cause metering to use the default storage class for the cluster.
4.4.1.2. Configuring the volume size for the Hive metastore
						Use the metastore-storage.yaml file below as a template to configure the volume size for the Hive metastore.
					
- 1
- Replace the value forsizewith your desired capacity. The example file shows "5Gi".
4.4.2. Using MySQL or PostgreSQL for the Hive metastore
The default installation of metering configures Hive to use an embedded Java database called Derby. This is unsuited for larger environments and can be replaced with either a MySQL or PostgreSQL database. Use the following example configuration files if your deployment requires a MySQL or PostgreSQL database for Hive.
					There are three configuration options you can use to control the database that is used by Hive metastore: url, driver, and secretName.
				
					Create your MySQL or Postgres instance with a user name and password. Then create a secret by using the OpenShift CLI (oc) or a YAML file. The secretName you create for this secret must map to the spec.hive.spec.config.db.secretName field in the MeteringConfig object resource.
				
Procedure
- Create a secret using the OpenShift CLI ( - oc) or by using a YAML file:- Create a secret by using the following command: - oc --namespace openshift-metering create secret generic <YOUR_SECRETNAME> --from-literal=username=<YOUR_DATABASE_USERNAME> --from-literal=password=<YOUR_DATABASE_PASSWORD> - $ oc --namespace openshift-metering create secret generic <YOUR_SECRETNAME> --from-literal=username=<YOUR_DATABASE_USERNAME> --from-literal=password=<YOUR_DATABASE_PASSWORD>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a secret by using a YAML file. For example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create a configuration file to use a MySQL or PostgreSQL database for Hive: - To use a MySQL database for Hive, use the example configuration file below. Metering supports configuring the internal Hive metastore to use the MySQL server versions 5.6, 5.7, and 8.0. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- When configuring Metering to work with older MySQL server versions, such as 5.6 or 5.7, you might need to add the - enabledTLSProtocolsJDBC URL parameter when configuring the internal Hive metastore.- You can pass additional JDBC parameters using the - spec.hive.config.url. For more details, see the MySQL Connector/J 8.0 documentation.
- To use a PostgreSQL database for Hive, use the example configuration file below: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You can pass additional JDBC parameters using the - spec.hive.config.url. For more details, see the PostgreSQL JDBC driver documentation.
 
4.5. Configuring the Reporting Operator
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
				The Reporting Operator is responsible for collecting data from Prometheus, storing the metrics in Presto, running report queries against Presto, and exposing their results via an HTTP API. Configuring the Reporting Operator is primarily done in your MeteringConfig custom resource.
			
4.5.1. Securing a Prometheus connection
When you install metering on OpenShift Container Platform, Prometheus is available at https://prometheus-k8s.openshift-monitoring.svc:9091/.
To secure the connection to Prometheus, the default metering installation uses the OpenShift Container Platform certificate authority (CA). If your Prometheus instance uses a different CA, you can inject the CA through a config map. You can also configure the Reporting Operator to use a specified bearer token to authenticate with Prometheus.
Procedure
- Inject the CA that your Prometheus instance uses through a config map. For example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, to use the system certificate authorities for publicly valid certificates, set both - useServiceAccountCAand- configMap.enabledto- false.
- Specify a bearer token to authenticate with Prometheus. For example:
4.5.2. Exposing the reporting API
On OpenShift Container Platform the default metering installation automatically exposes a route, making the reporting API available. This provides the following features:
- Automatic DNS
- Automatic TLS based on the cluster CA
Also, the default installation makes it possible to use the OpenShift service for serving certificates to protect the reporting API with TLS. The OpenShift OAuth proxy is deployed as a sidecar container for the Reporting Operator, which protects the reporting API with authentication.
4.5.2.1. Using OpenShift Authentication
By default, the reporting API is secured with TLS and authentication. This is done by configuring the Reporting Operator to deploy a pod containing both the Reporting Operator’s container, and a sidecar container running OpenShift auth-proxy.
To access the reporting API, the Metering Operator exposes a route. Once that route has been installed, you can run the following command to get the route’s hostname.
METERING_ROUTE_HOSTNAME=$(oc -n openshift-metering get routes metering -o json | jq -r '.status.ingress[].host')
$ METERING_ROUTE_HOSTNAME=$(oc -n openshift-metering get routes metering -o json | jq -r '.status.ingress[].host')Next, set up authentication using either a service account token or basic authentication with a username and password.
4.5.2.1.1. Authenticate using a service account token
With this method, you use the token in the Reporting Operator’s service account, and pass that bearer token to the Authorization header in the following command:
TOKEN=$(oc -n openshift-metering serviceaccounts get-token reporting-operator)
$ TOKEN=$(oc -n openshift-metering serviceaccounts get-token reporting-operator)
curl -H "Authorization: Bearer $TOKEN" -k "https://$METERING_ROUTE_HOSTNAME/api/v1/reports/get?name=[Report Name]&namespace=openshift-metering&format=[Format]"
							Be sure to replace the name=[Report Name] and format=[Format] parameters in the URL above. The format parameter can be json, csv, or tabular.
						
4.5.2.1.2. Authenticate using a username and password
							Metering supports configuring basic authentication using a username and password combination, which is specified in the contents of an htpasswd file. By default, a secret containing empty htpasswd data is created. You can, however, configure the reporting-operator.spec.authProxy.htpasswd.data and reporting-operator.spec.authProxy.htpasswd.createSecret keys to use this method.
						
							Once you have specified the above in your MeteringConfig resource, you can run the following command:
						
curl -u testuser:password123 -k "https://$METERING_ROUTE_HOSTNAME/api/v1/reports/get?name=[Report Name]&namespace=openshift-metering&format=[Format]"
$ curl -u testuser:password123 -k "https://$METERING_ROUTE_HOSTNAME/api/v1/reports/get?name=[Report Name]&namespace=openshift-metering&format=[Format]"
							Be sure to replace testuser:password123 with a valid username and password combination.
						
4.5.2.2. Manually Configuring Authentication
						To manually configure, or disable OAuth in the Reporting Operator, you must set spec.tls.enabled: false in your MeteringConfig resource.
					
This also disables all TLS and authentication between the Reporting Operator, Presto, and Hive. You would need to manually configure these resources yourself.
Authentication can be enabled by configuring the following options. Enabling authentication configures the Reporting Operator pod to run the OpenShift auth-proxy as a sidecar container in the pod. This adjusts the ports so that the reporting API isn’t exposed directly, but instead is proxied to via the auth-proxy sidecar container.
- 
								reporting-operator.spec.authProxy.enabled
- 
								reporting-operator.spec.authProxy.cookie.createSecret
- 
								reporting-operator.spec.authProxy.cookie.seed
						You need to set reporting-operator.spec.authProxy.enabled and reporting-operator.spec.authProxy.cookie.createSecret to true and reporting-operator.spec.authProxy.cookie.seed to a 32-character random string.
					
You can generate a 32-character random string using the following command.
openssl rand -base64 32 | head -c32; echo.
$ openssl rand -base64 32 | head -c32; echo.4.5.2.2.1. Token authentication
							When the following options are set to true, authentication using a bearer token is enabled for the reporting REST API. Bearer tokens can come from service accounts or users.
						
- 
									reporting-operator.spec.authProxy.subjectAccessReview.enabled
- 
									reporting-operator.spec.authProxy.delegateURLs.enabled
When authentication is enabled, the Bearer token used to query the reporting API of the user or service account must be granted access using one of the following roles:
- report-exporter
- reporting-admin
- reporting-viewer
- metering-admin
- metering-viewer
							The Metering Operator is capable of creating role bindings for you, granting these permissions by specifying a list of subjects in the spec.permissions section. For an example, see the following advanced-auth.yaml example configuration.
						
							Alternatively, you can use any role which has rules granting get permissions to reports/export. This means get access to the export sub-resource of the Report resources in the namespace of the Reporting Operator. For example: admin and cluster-admin.
						
By default, the Reporting Operator and Metering Operator service accounts both have these permissions, and their tokens can be used for authentication.
4.5.2.2.2. Basic authentication with a username and password
							For basic authentication you can supply a username and password in the reporting-operator.spec.authProxy.htpasswd.data field. The username and password must be the same format as those found in an htpasswd file. When set, you can use HTTP basic authentication to provide your username and password that has a corresponding entry in the htpasswdData contents.
						
4.6. Configure AWS billing correlation
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
				Metering can correlate cluster usage information with AWS detailed billing information, attaching a dollar amount to resource usage. For clusters running in EC2, you can enable this by modifying the example aws-billing.yaml file below.
			
To enable AWS billing correlation, first ensure the AWS Cost and Usage Reports are enabled. For more information, see Turning on the AWS Cost and Usage Report in the AWS documentation.
- 1
- Update the bucket, prefix, and region to the location of your AWS Detailed billing report.
- 2 3 4
- AllsecretNamefields should be set to the name of a secret in the metering namespace containing AWS credentials in thedata.aws-access-key-idanddata.aws-secret-access-keyfields. See the example secret file below for more details.
				To store data in S3, the aws-access-key-id and aws-secret-access-key credentials must have read and write access to the bucket. For an example of an IAM policy granting the required permissions, see the aws/read-write.json file below.
			
This can be done either pre-installation or post-installation. Disabling it post-installation can cause errors in the Reporting Operator.
Chapter 5. Reports
5.1. About Reports
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
				A Report custom resource provides a method to manage periodic Extract Transform and Load (ETL) jobs using SQL queries. Reports are composed from other metering resources, such as ReportQuery resources that provide the actual SQL query to run, and ReportDataSource resources that define the data available to the ReportQuery and Report resources.
			
				Many use cases are addressed by the predefined ReportQuery and ReportDataSource resources that come installed with metering. Therefore, you do not need to define your own unless you have a use case that is not covered by these predefined resources.
			
5.1.1. Reports
					The Report custom resource is used to manage the execution and status of reports. Metering produces reports derived from usage data sources, which can be used in further analysis and filtering. A single Report resource represents a job that manages a database table and updates it with new information according to a schedule. The report exposes the data in that table via the Reporting Operator HTTP API.
				
					Reports with a spec.schedule field set are always running and track what time periods it has collected data for. This ensures that if metering is shutdown or unavailable for an extended period of time, it backfills the data starting where it left off. If the schedule is unset, then the report runs once for the time specified by the reportingStart and reportingEnd. By default, reports wait for ReportDataSource resources to have fully imported any data covered in the reporting period. If the report has a schedule, it waits to run until the data in the period currently being processed has finished importing.
				
5.1.1.1. Example report with a schedule
						The following example Report object contains information on every pod’s CPU requests, and runs every hour, adding the last hours worth of data each time it runs.
					
5.1.1.2. Example report without a schedule (run-once)
						The following example Report object contains information on every pod’s CPU requests for all of July. After completion, it does not run again.
					
5.1.1.3. query
						The query field names the ReportQuery resource used to generate the report. The report query controls the schema of the report as well as how the results are processed.
					
						query is a required field.
					
						Use the following command to list available ReportQuery resources:
					
oc -n openshift-metering get reportqueries
$ oc -n openshift-metering get reportqueriesExample output
						Report queries with the -raw suffix are used by other ReportQuery resources to build more complex queries, and should not be used directly for reports.
					
						namespace- prefixed queries aggregate pod CPU and memory requests by namespace, providing a list of namespaces and their overall usage based on resource requests.
					
						pod- prefixed queries are similar to namespace- prefixed queries but aggregate information by pod rather than namespace. These queries include the pod’s namespace and node.
					
						node- prefixed queries return information about each node’s total available resources.
					
						aws- prefixed queries are specific to AWS. Queries suffixed with -aws return the same data as queries of the same name without the suffix, and correlate usage with the EC2 billing data.
					
						The aws-ec2-billing-data report is used by other queries, and should not be used as a standalone report. The aws-ec2-cluster-cost report provides a total cost based on the nodes included in the cluster, and the sum of their costs for the time period being reported on.
					
						Use the following command to get the ReportQuery resource as YAML, and check the spec.columns field. For example, run:
					
oc -n openshift-metering get reportqueries namespace-memory-request -o yaml
$ oc -n openshift-metering get reportqueries namespace-memory-request -o yamlExample output
5.1.1.4. schedule
						The spec.schedule configuration block defines when the report runs. The main fields in the schedule section are period, and then depending on the value of period, the fields hourly, daily, weekly, and monthly allow you to fine-tune when the report runs.
					
						For example, if period is set to weekly, you can add a weekly field to the spec.schedule block. The following example will run once a week on Wednesday, at 1 PM (hour 13 in the day).
					
5.1.1.4.1. period
							Valid values of schedule.period are listed below, and the options available to set for a given period are also listed.
						
- hourly- 
											minute
- 
											second
 
- 
											
- daily- 
											hour
- 
											minute
- 
											second
 
- 
											
- weekly- 
											dayOfWeek
- 
											hour
- 
											minute
- 
											second
 
- 
											
- monthly- 
											dayOfMonth
- 
											hour
- 
											minute
- 
											second
 
- 
											
- cron- 
											expression
 
- 
											
							Generally, the hour, minute, second fields control when in the day the report runs, and dayOfWeek/dayOfMonth control what day of the week, or day of month the report runs on, if it is a weekly or monthly report period.
						
For each of these fields, there is a range of valid values:
- 
									houris an integer value between 0-23.
- 
									minuteis an integer value between 0-59.
- 
									secondis an integer value between 0-59.
- 
									dayOfWeekis a string value that expects the day of the week (spelled out).
- 
									dayOfMonthis an integer value between 1-31.
For cron periods, normal cron expressions are valid:
- 
									expression: "*/5 * * * *"
5.1.1.5. reportingStart
						To support running a report against existing data, you can set the spec.reportingStart field to a RFC3339 timestamp to tell the report to run according to its schedule starting from reportingStart rather than the current time.
					
							Setting the spec.reportingStart field to a specific time will result in the Reporting Operator running many queries in succession for each interval in the schedule that is between the reportingStart time and the current time. This could be thousands of queries if the period is less than daily and the reportingStart is more than a few months back. If reportingStart is left unset, the report will run at the next full reportingPeriod after the time the report is created.
						
						As an example of how to use this field, if you had data already collected dating back to January 1st, 2019 that you want to include in your Report object, you can create a report with the following values:
					
5.1.1.6. reportingEnd
						To configure a report to only run until a specified time, you can set the spec.reportingEnd field to an RFC3339 timestamp. The value of this field will cause the report to stop running on its schedule after it has finished generating reporting data for the period covered from its start time until reportingEnd.
					
						Because a schedule will most likely not align with the reportingEnd, the last period in the schedule will be shortened to end at the specified reportingEnd time. If left unset, then the report will run forever, or until a reportingEnd is set on the report.
					
For example, if you want to create a report that runs once a week for the month of July:
5.1.1.7. expiration
						Add the expiration field to set a retention period on a scheduled metering report. You can avoid manually removing the report by setting the expiration duration value. The retention period is equal to the Report object creationDate plus the expiration duration. The report is removed from the cluster at the end of the retention period if no other reports or report queries depend on the expiring report. Deleting the report from the cluster can take several minutes.
					
							Setting the expiration field is not recommended for roll-up or aggregated reports. If a report is depended upon by other reports or report queries, then the report is not removed at the end of the retention period. You can view the report-operator logs at debug level for the timing output around a report retention decision.
						
						For example, the following scheduled report is deleted 30 minutes after the creationDate of the report:
					
- 1
- Valid time units for theexpirationduration arens,us(orµs),ms,s,m, andh.
							The expiration retention period for a Report object is not precise and works on the order of several minutes, not nanoseconds.
						
5.1.1.8. runImmediately
						When runImmediately is set to true, the report runs immediately. This behavior ensures that the report is immediately processed and queued without requiring additional scheduling parameters.
					
							When runImmediately is set to true, you must set a reportingEnd and reportingStart value.
						
5.1.1.9. inputs
						The spec.inputs field of a Report object can be used to override or set values defined in a ReportQuery resource’s spec.inputs field.
					
						spec.inputs is a list of name-value pairs:
					
spec:
  inputs:
  - name: "NamespaceCPUUsageReportName" 
    value: "namespace-cpu-usage-hourly" 
spec:
  inputs:
  - name: "NamespaceCPUUsageReportName" 
    value: "namespace-cpu-usage-hourly" 5.1.1.10. Roll-up reports
Report data is stored in the database much like metrics themselves, and therefore, can be used in aggregated or roll-up reports. A simple use case for a roll-up report is to spread the time required to produce a report over a longer period of time. This is instead of requiring a monthly report to query and add all data over an entire month. For example, the task can be split into daily reports that each run over 1/30 of the data.
						A custom roll-up report requires a custom report query. The ReportQuery resource template processor provides a reportTableName function that can get the necessary table name from a Report object’s metadata.name.
					
Below is a snippet taken from a built-in query:
pod-cpu.yaml
Example aggregated-report.yaml roll-up report
spec:
  query: "namespace-cpu-usage"
  inputs:
  - name: "NamespaceCPUUsageReportName"
    value: "namespace-cpu-usage-hourly"
spec:
  query: "namespace-cpu-usage"
  inputs:
  - name: "NamespaceCPUUsageReportName"
    value: "namespace-cpu-usage-hourly"5.1.1.10.1. Report status
The execution of a scheduled report can be tracked using its status field. Any errors occurring during the preparation of a report will be recorded here.
							The status field of a Report object currently has two fields:
						
- 
									conditions: Conditions is a list of conditions, each of which have atype,status,reason, andmessagefield. Possible values of a condition’stypefield areRunningandFailure, indicating the current state of the scheduled report. Thereasonindicates why itsconditionis in its current state with thestatusbeing eithertrue,falseor,unknown. Themessageprovides a human readable indicating why the condition is in the current state. For detailed information on thereasonvalues, seepkg/apis/metering/v1/util/report_util.go.
- 
									lastReportTime: Indicates the time metering has collected data up to.
5.2. Storage locations
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
				A StorageLocation custom resource configures where data will be stored by the Reporting Operator. This includes the data collected from Prometheus, and the results produced by generating a Report custom resource.
			
				You only need to configure a StorageLocation custom resource if you want to store data in multiple locations, like multiple S3 buckets or both S3 and HDFS, or if you wish to access a database in Hive and Presto that was not created by metering. For most users this is not a requirement, and the documentation on configuring metering is sufficient to configure all necessary storage components.
			
5.2.1. Storage location examples
					The following example shows the built-in local storage option, and is configured to use Hive. By default, data is stored wherever Hive is configured to use storage, such as HDFS, S3, or a ReadWriteMany persistent volume claim (PVC).
				
Local storage example
- 1
- If thehivesection is present, then theStorageLocationresource will be configured to store data in Presto by creating the table using the Hive server. OnlydatabaseNameandunmanagedDatabaseare required fields.
- 2
- The name of the database within hive.
- 3
- Iftrue, theStorageLocationresource will not be actively managed, and thedatabaseNameis expected to already exist in Hive. Iffalse, the Reporting Operator will create the database in Hive.
The following example uses an AWS S3 bucket for storage. The prefix is appended to the bucket name when constructing the path to use.
Remote storage example
- 1
- Optional: The filesystem URL for Presto and Hive to use for the database. This can be anhdfs://ors3a://filesystem URL.
					There are additional optional fields that can be specified in the hive section:
				
- 
							defaultTableProperties: Contains configuration options for creating tables using Hive.
- 
							fileFormat: The file format used for storing files in the filesystem. See the Hive Documentation on File Storage Format for a list of options and more details.
- 
							rowFormat: Controls the Hive row format. This controls how Hive serializes and deserializes rows. See the Hive Documentation on Row Formats and SerDe for more details.
5.2.2. Default storage location
					If an annotation storagelocation.metering.openshift.io/is-default exists and is set to true on a StorageLocation resource, then that resource becomes the default storage resource. Any components with a storage configuration option where the storage location is not specified will use the default storage resource. There can be only one default storage resource. If more than one resource with the annotation exists, an error is logged because the Reporting Operator cannot determine the default.
				
Default storage example
Chapter 6. Using Metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
6.1. Prerequisites
- Install Metering
- Review the details about the available options that can be configured for a report and how they function.
6.2. Writing Reports
Writing a report is the way to process and analyze data using metering.
				To write a report, you must define a Report resource in a YAML file, specify the required parameters, and create it in the openshift-metering namespace.
			
Prerequisites
- Metering is installed.
Procedure
- Change to the - openshift-meteringproject:- oc project openshift-metering - $ oc project openshift-metering- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - Reportresource as a YAML file:- Create a YAML file with the following content: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 2
- Thequeryspecifies theReportQueryresources used to generate the report. Change this based on what you want to report on. For a list of options, runoc get reportqueries | grep -v raw.
- 1
- Use a descriptive name about what the report does formetadata.name. A good name describes the query, and the schedule or period you used.
- 3
- SetrunImmediatelytotruefor it to run with whatever data is available, or set it tofalseif you want it to wait forreportingEndto pass.
 
- Run the following command to create the - Reportresource:- oc create -f <file-name>.yaml - $ oc create -f <file-name>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - report.metering.openshift.io/namespace-cpu-request-2019 created - report.metering.openshift.io/namespace-cpu-request-2019 created- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- You can list reports and their - Runningstatus with the following command:- oc get reports - $ oc get reports- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME QUERY SCHEDULE RUNNING FAILED LAST REPORT TIME AGE namespace-cpu-request-2019 namespace-cpu-request Finished 2019-12-30T23:59:59Z 26s - NAME QUERY SCHEDULE RUNNING FAILED LAST REPORT TIME AGE namespace-cpu-request-2019 namespace-cpu-request Finished 2019-12-30T23:59:59Z 26s- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.3. Viewing report results
				Viewing a report’s results involves querying the reporting API route and authenticating to the API using your OpenShift Container Platform credentials. Reports can be retrieved as JSON, CSV, or Tabular formats.
			
Prerequisites
- Metering is installed.
- 
						To access report results, you must either be a cluster administrator, or you need to be granted access using the report-exporterrole in theopenshift-meteringnamespace.
Procedure
- Change to the - openshift-meteringproject:- oc project openshift-metering - $ oc project openshift-metering- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Query the reporting API for results: - Create a variable for the metering - reporting-apiroute then get the route:- meteringRoute="$(oc get routes metering -o jsonpath='{.spec.host}')"- $ meteringRoute="$(oc get routes metering -o jsonpath='{.spec.host}')"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - echo "$meteringRoute" - $ echo "$meteringRoute"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Get the token of your current user to be used in the request: - token="$(oc whoami -t)" - $ token="$(oc whoami -t)"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set - reportNameto the name of the report you created:- reportName=namespace-cpu-request-2019 - $ reportName=namespace-cpu-request-2019- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set - reportFormatto one of- csv,- json, or- tabularto specify the output format of the API response:- reportFormat=csv - $ reportFormat=csv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To get the results, use - curlto make a request to the reporting API for your report:- curl --insecure -H "Authorization: Bearer ${token}" "https://${meteringRoute}/api/v1/reports/get?name=${reportName}&namespace=openshift-metering&format=$reportFormat"- $ curl --insecure -H "Authorization: Bearer ${token}" "https://${meteringRoute}/api/v1/reports/get?name=${reportName}&namespace=openshift-metering&format=$reportFormat"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output with - reportName=namespace-cpu-request-2019and- reportFormat=csv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
Chapter 7. Examples of using metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
Use the following example reports to get started measuring capacity, usage, and utilization in your cluster. These examples showcase the various types of reports metering offers, along with a selection of the predefined queries.
7.1. Prerequisites
- Install metering
- Review the details about writing and viewing reports.
7.2. Measure cluster capacity hourly and daily
The following report demonstrates how to measure cluster capacity both hourly and daily. The daily report works by aggregating the hourly report’s results.
The following report measures cluster CPU capacity every hour.
Hourly CPU capacity by cluster example
- 1
- You could change this period todailyto get a daily report, but with larger data sets it is more efficient to use an hourly report, then aggregate your hourly data into a daily report.
The following report aggregates the hourly data into a daily report.
Daily CPU capacity by cluster example
- 1
- To stay organized, remember to change thenameof your report if you change any of the other values.
- 2
- You can also measurecluster-memory-capacity. Remember to update the query in the associated hourly report as well.
- 3
- Theinputssection configures this report to aggregate the hourly report. Specifically,value: cluster-cpu-capacity-hourlyis the name of the hourly report that gets aggregated.
7.3. Measure cluster usage with a one-time report
The following report measures cluster usage from a specific starting date forward. The report only runs once, after you save it and apply it.
CPU usage by cluster example
- 1
- To stay organized, remember to change thenameof your report if you change any of the other values.
- 2
- Configures the report to start using data from thereportingStarttimestamp until thereportingEndtimestamp.
- 3
- Adjust your query here. You can also measure cluster usage with thecluster-memory-usagequery.
- 4
- Configures the report to run immediately after saving it and applying it.
7.4. Measure cluster utilization using cron expressions
You can also use cron expressions when configuring the period of your reports. The following report measures cluster utilization by looking at CPU utilization from 9am-5pm every weekday.
Weekday CPU utilization by cluster example
Chapter 8. Troubleshooting and debugging metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
Use the following sections to help troubleshoot and debug specific issues with metering.
In addition to the information in this section, be sure to review the following topics:
8.1. Troubleshooting metering
				A common issue with metering is pods failing to start. Pods might fail to start due to lack of resources or if they have a dependency on a resource that does not exist, such as a StorageClass or Secret resource.
			
8.1.1. Not enough compute resources
					A common issue when installing or running metering is a lack of compute resources. As the cluster grows and more reports are created, the Reporting Operator pod requires more memory. If memory usage reaches the pod limit, the cluster considers the pod out of memory (OOM) and terminates it with an OOMKilled status. Ensure that metering is allocated the minimum resource requirements described in the installation prerequisites.
				
The Metering Operator does not autoscale the Reporting Operator based on the load in the cluster. Therefore, CPU usage for the Reporting Operator pod does not increase as the cluster grows.
To determine if the issue is with resources or scheduling, follow the troubleshooting instructions included in the Kubernetes document Managing Compute Resources for Containers.
					To troubleshoot issues due to a lack of compute resources, check the following within the openshift-metering namespace.
				
Prerequisites
- You are currently in the - openshift-meteringnamespace. Change to the- openshift-meteringnamespace by running:- oc project openshift-metering - $ oc project openshift-metering- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Procedure
- Check for metering - Reportresources that fail to complete and show the status of- ReportingPeriodUnmetDependencies:- oc get reports - $ oc get reports- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME QUERY SCHEDULE RUNNING FAILED LAST REPORT TIME AGE namespace-cpu-utilization-adhoc-10 namespace-cpu-utilization Finished 2020-10-31T00:00:00Z 2m38s namespace-cpu-utilization-adhoc-11 namespace-cpu-utilization ReportingPeriodUnmetDependencies 2m23s namespace-memory-utilization-202010 namespace-memory-utilization ReportingPeriodUnmetDependencies 26s namespace-memory-utilization-202011 namespace-memory-utilization ReportingPeriodUnmetDependencies 14s - NAME QUERY SCHEDULE RUNNING FAILED LAST REPORT TIME AGE namespace-cpu-utilization-adhoc-10 namespace-cpu-utilization Finished 2020-10-31T00:00:00Z 2m38s namespace-cpu-utilization-adhoc-11 namespace-cpu-utilization ReportingPeriodUnmetDependencies 2m23s namespace-memory-utilization-202010 namespace-memory-utilization ReportingPeriodUnmetDependencies 26s namespace-memory-utilization-202011 namespace-memory-utilization ReportingPeriodUnmetDependencies 14s- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check the - ReportDataSourceresources where the- NEWEST METRICis less than the report end date:- oc get reportdatasource - $ oc get reportdatasource- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check the health of the - reporting-operator- Podresource for a high number of pod restarts:- oc get pods -l app=reporting-operator - $ oc get pods -l app=reporting-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY STATUS RESTARTS AGE reporting-operator-84f7c9b7b6-fr697 2/2 Running 542 8d - NAME READY STATUS RESTARTS AGE reporting-operator-84f7c9b7b6-fr697 2/2 Running 542 8d- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The Reporting Operator pod is restarting at a high rate.
 
- Check the - reporting-operator- Podresource for an- OOMKilledtermination:- oc describe pod/reporting-operator-84f7c9b7b6-fr697 - $ oc describe pod/reporting-operator-84f7c9b7b6-fr697- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The Reporting Operator pod was terminated due to OOM kill.
 
Increasing the reporting-operator pod memory limit
					If you are experiencing an increase in pod restarts and OOM kill events, you can check the current memory limit set for the Reporting Operator pod. Increasing the memory limit allows the Reporting Operator pod to update the report data sources. If necessary, increase the memory limit in your MeteringConfig resource by 25% - 50%.
				
Procedure
- Check the current memory limits of the - reporting-operator- Podresource:- oc describe pod reporting-operator-67d6f57c56-79mrt - $ oc describe pod reporting-operator-67d6f57c56-79mrt- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The current memory limit for the Reporting Operator pod.
 
- Edit the - MeteringConfigresource to update the memory limit:- oc edit meteringconfig/operator-metering - $ oc edit meteringconfig/operator-metering- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example - MeteringConfigresource- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Add or increase memory limits within theresourcesfield of theMeteringConfigresource.
 Note- If there continue to be numerous OOM killed events after memory limits are increased, this might indicate that a different issue is causing the reports to be in a pending state. 
8.1.2. StorageClass resource not configured
					Metering requires that a default StorageClass resource be configured for dynamic provisioning.
				
					See the documentation on configuring metering for information on how to check if there are any StorageClass resources configured for the cluster, how to set the default, and how to configure metering to use a storage class other than the default.
				
8.1.3. Secret not configured correctly
A common issue with metering is providing the incorrect secret when configuring your persistent storage. Be sure to review the example configuration files and create you secret according to the guidelines for your storage provider.
8.2. Debugging metering
Debugging metering is much easier when you interact directly with the various components. The sections below detail how you can connect and query Presto and Hive as well as view the dashboards of the Presto and HDFS components.
					All of the commands in this section assume you have installed metering through OperatorHub in the openshift-metering namespace.
				
8.2.1. Get reporting operator logs
					Use the command below to follow the logs of the reporting-operator:
				
oc -n openshift-metering logs -f "$(oc -n openshift-metering get pods -l app=reporting-operator -o name | cut -c 5-)" -c reporting-operator
$ oc -n openshift-metering logs -f "$(oc -n openshift-metering get pods -l app=reporting-operator -o name | cut -c 5-)" -c reporting-operator8.2.2. Query Presto using presto-cli
The following command opens an interactive presto-cli session where you can query Presto. This session runs in the same container as Presto and launches an additional Java instance, which can create memory limits for the pod. If this occurs, you should increase the memory request and limits of the Presto pod.
By default, Presto is configured to communicate using TLS. You must use the following command to run Presto queries:
oc -n openshift-metering exec -it "$(oc -n openshift-metering get pods -l app=presto,presto=coordinator -o name | cut -d/ -f2)" \ -- /usr/local/bin/presto-cli --server https://presto:8080 --catalog hive --schema default --user root --keystore-path /opt/presto/tls/keystore.pem
$ oc -n openshift-metering exec -it "$(oc -n openshift-metering get pods -l app=presto,presto=coordinator -o name | cut -d/ -f2)"  \
  -- /usr/local/bin/presto-cli --server https://presto:8080 --catalog hive --schema default --user root --keystore-path /opt/presto/tls/keystore.pem
					Once you run this command, a prompt appears where you can run queries. Use the show tables from metering; query to view the list of tables:
				
presto:default> show tables from metering;
$ presto:default> show tables from metering;Example output
8.2.3. Query Hive using beeline
The following opens an interactive beeline session where you can query Hive. This session runs in the same container as Hive and launches an additional Java instance, which can create memory limits for the pod. If this occurs, you should increase the memory request and limits of the Hive pod.
oc -n openshift-metering exec -it $(oc -n openshift-metering get pods -l app=hive,hive=server -o name | cut -d/ -f2) \ -c hiveserver2 -- beeline -u 'jdbc:hive2://127.0.0.1:10000/default;auth=noSasl'
$ oc -n openshift-metering exec -it $(oc -n openshift-metering get pods -l app=hive,hive=server -o name | cut -d/ -f2) \
  -c hiveserver2 -- beeline -u 'jdbc:hive2://127.0.0.1:10000/default;auth=noSasl'
					Once you run this command, a prompt appears where you can run queries. Use the show tables; query to view the list of tables:
				
0: jdbc:hive2://127.0.0.1:10000/default> show tables from metering;
$ 0: jdbc:hive2://127.0.0.1:10000/default> show tables from metering;Example output
8.2.4. Port-forward to the Hive web UI
Run the following command to port-forward to the Hive web UI:
oc -n openshift-metering port-forward hive-server-0 10002
$ oc -n openshift-metering port-forward hive-server-0 10002You can now open http://127.0.0.1:10002 in your browser window to view the Hive web interface.
8.2.5. Port-forward to HDFS
Run the following command to port-forward to the HDFS namenode:
oc -n openshift-metering port-forward hdfs-namenode-0 9870
$ oc -n openshift-metering port-forward hdfs-namenode-0 9870You can now open http://127.0.0.1:9870 in your browser window to view the HDFS web interface.
Run the following command to port-forward to the first HDFS datanode:
oc -n openshift-metering port-forward hdfs-datanode-0 9864
$ oc -n openshift-metering port-forward hdfs-datanode-0 9864 - 1
- To check other datanodes, replacehdfs-datanode-0with the pod you want to view information on.
8.2.6. Metering Ansible Operator
					Metering uses the Ansible Operator to watch and reconcile resources in a cluster environment. When debugging a failed metering installation, it can be helpful to view the Ansible logs or status of your MeteringConfig custom resource.
				
8.2.6.1. Accessing Ansible logs
In the default installation, the Metering Operator is deployed as a pod. In this case, you can check the logs of the Ansible container within this pod:
oc -n openshift-metering logs $(oc -n openshift-metering get pods -l app=metering-operator -o name | cut -d/ -f2) -c ansible
$ oc -n openshift-metering logs $(oc -n openshift-metering get pods -l app=metering-operator -o name | cut -d/ -f2) -c ansible
						Alternatively, you can view the logs of the Operator container (replace -c ansible with -c operator) for condensed output.
					
8.2.6.2. Checking the MeteringConfig Status
						It can be helpful to view the .status field of your MeteringConfig custom resource to debug any recent failures. The following command shows status messages with type Invalid:
					
oc -n openshift-metering get meteringconfig operator-metering -o=jsonpath='{.status.conditions[?(@.type=="Invalid")].message}'
$ oc -n openshift-metering get meteringconfig operator-metering -o=jsonpath='{.status.conditions[?(@.type=="Invalid")].message}'8.2.6.3. Checking MeteringConfig Events
Check events that the Metering Operator is generating. This can be helpful during installation or upgrade to debug any resource failures. Sort events by the last timestamp:
oc -n openshift-metering get events --field-selector involvedObject.kind=MeteringConfig --sort-by='.lastTimestamp'
$ oc -n openshift-metering get events --field-selector involvedObject.kind=MeteringConfig --sort-by='.lastTimestamp'Example output with latest changes in the MeteringConfig resources
Chapter 9. Uninstalling metering
Metering is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
You can remove metering from your OpenShift Container Platform cluster.
Metering does not manage or delete Amazon S3 bucket data. After uninstalling metering, you must manually clean up S3 buckets that were used to store metering data.
9.1. Removing the Metering Operator from your cluster
Remove the Metering Operator from your cluster by following the documentation on deleting Operators from a cluster.
Removing the Metering Operator from your cluster does not remove its custom resource definitions or managed resources. See the following sections on Uninstalling a metering namespace and Uninstalling metering custom resource definitions for steps to remove any remaining metering components.
9.2. Uninstalling a metering namespace
				Uninstall your metering namespace, for example the openshift-metering namespace, by removing the MeteringConfig resource and deleting the openshift-metering namespace.
			
Prerequisites
- The Metering Operator is removed from your cluster.
Procedure
- Remove all resources created by the Metering Operator: - oc --namespace openshift-metering delete meteringconfig --all - $ oc --namespace openshift-metering delete meteringconfig --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- After the previous step is complete, verify that all pods in the - openshift-meteringnamespace are deleted or are reporting a terminating state:- oc --namespace openshift-metering get pods - $ oc --namespace openshift-metering get pods- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete the - openshift-meteringnamespace:- oc delete namespace openshift-metering - $ oc delete namespace openshift-metering- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
9.3. Uninstalling metering custom resource definitions
				The metering custom resource definitions (CRDs) remain in the cluster after the Metering Operator is uninstalled and the openshift-metering namespace is deleted.
			
Deleting the metering CRDs disrupts any additional metering installations in other namespaces in your cluster. Ensure that there are no other metering installations before proceeding.
Prerequisites
- 
						The MeteringConfigcustom resource in theopenshift-meteringnamespace is deleted.
- 
						The openshift-meteringnamespace is deleted.
Procedure
- Delete the remaining metering CRDs: - oc get crd -o name | grep "metering.openshift.io" | xargs oc delete - $ oc get crd -o name | grep "metering.openshift.io" | xargs oc delete- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
        Legal Notice
        
          
            
          
        
      
 
Copyright © 2025 Red Hat
OpenShift documentation is licensed under the Apache License 2.0 (https://www.apache.org/licenses/LICENSE-2.0).
Modified versions must remove all Red Hat trademarks.
Portions adapted from https://github.com/kubernetes-incubator/service-catalog/ with modifications by Red Hat.
Red Hat, Red Hat Enterprise Linux, the Red Hat logo, the Shadowman logo, JBoss, OpenShift, Fedora, the Infinity logo, and RHCE are trademarks of Red Hat, Inc., registered in the United States and other countries.
Linux® is the registered trademark of Linus Torvalds in the United States and other countries.
Java® is a registered trademark of Oracle and/or its affiliates.
XFS® is a trademark of Silicon Graphics International Corp. or its subsidiaries in the United States and/or other countries.
MySQL® is a registered trademark of MySQL AB in the United States, the European Union and other countries.
Node.js® is an official trademark of Joyent. Red Hat Software Collections is not formally related to or endorsed by the official Joyent Node.js open source or commercial project.
The OpenStack® Word Mark and OpenStack logo are either registered trademarks/service marks or trademarks/service marks of the OpenStack Foundation, in the United States and other countries and are used with the OpenStack Foundation’s permission. We are not affiliated with, endorsed or sponsored by the OpenStack Foundation, or the OpenStack community.
All other trademarks are the property of their respective owners.