OpenSearch basics

4 minute readData analytics

The OpenSearch database stores all data for use by CloudBees Analytics reports and dashboards. While developing reports and dashboards, it is useful to view the data available in the OpenSearch database. Information in this section helps you to set up and examine data and to run reports and to export to other systems.

Examining data in the OpenSearch database

This section helps you to set up and directly query the OpenSearch database. It can be useful to examine report data and to run reports directly against the OpenSearch database for debugging purposes when you create your own reports and dashboards.

IPv6 addresses are only supported for Kubernetes platforms. If using an IPv6 address, enclose the address in square brackets. Example: [<IPv6-ADDRESS>].

Run a report

This section demonstrates how to manually submit a CloudBees Analytics report to CloudBees Analytics engine and to the OpenSearch database. It assumes you have deployment data in your database.

Define the report

Use the CloudBees Analytics UI to define search criteria.

  1. Select Analytics  Reports. The reports list displays.

  2. Select the Build outcome report. This is the custom report you previously created. The Report editor displays the report in advanced mode and assumes you have deployment data in your database.

  3. Select Tabular preview to run the report and view the result set.

You can toggle between the Report editor to edit the report and Tabular preview to view the results. Select Save when you are satisfied with the report criteria.

To change a report bundled with CloudBees Analytics, you must first copy it and change the copy.

Issuing CloudBees Analytics API requests

Use the runReports CloudBees Analytics API command to run a report. The example below uses ectool to issue the command that runs the Build outcome report.

ectool runReport "CloudBees" "Build outcome"

Results similar to the following are returned:

<response requestId="1" nodeId="192.168.5.138"> <result> <deployment_outcome_count>26</deployment_outcome_count> <total>26</total> <deployment_outcome>success</deployment_outcome> <avg_deployment_duration>530769.23</avg_deployment_duration> </result> </response>

CloudBees Analytics API commands are also available from the CloudBees CD/RO Swagger UI available via https://<cloudbees-cd-server_hostname>/rest/doc/v1.0/.

  • For complete information about runReport and all CloudBees Analytics API commands, refer to runReport.

  • For additional information about creating and using CloudBees Analytics reports, refer to Create a report.

Issuing OpenSearch API requests

This section shows you how to issue OpenSearch API requests to the database via cURL.

Prerequisites

  • OpenSearch database login credentials. Defaults are:

    • user: reportinguser

    • password: changeme

  • A tool for issuing REST POST requests. For example, cURL

  • A tool for Base64 encoding

Accessing the OpenSearch database

From a web browser, access the OpenSearch database with the URL https://<hostname>:9201, where <hostname> is the same hostname as your CloudBees Analytics server. Alternatively, navigate to the Administration  Configurations  Analytics server to determine your OpenSearch database URL.

Enter your credentials for OpenSearch in the sign-in dialog; confirm you get a response similar to this:

{ "name" : "<hostname>", "cluster_name" : "analytics", "cluster_uuid" : "Auu0hB2_QPGN4-k3PThgsA", "version" : { "distribution" : "opensearch", "number" : "2.12.0", "build_type" : "tar", "build_hash" : "2c355ce1a427e4a528778d4054436b5c4b756221", "build_date" : "2024-02-20T02:18:49.874618333Z", "build_snapshot" : false, "lucene_version" : "9.9.2", "minimum_wire_compatibility_version" : "7.10.0", "minimum_index_compatibility_version" : "7.0.0" }, "tagline" : "The OpenSearch Project: https://opensearch.org/" }

Base64 encoded credentials

Your credentials are required to be in a Base64 encoded format. To generate this encoded credential string you can use ectool or an online tool, the latter is not recommended for production use since you cannot be assured you data is held privately by an unknown party.

ectool evalDsl '"reportinguser:changeme".bytes.encodeBase64().toString()'
<response requestId="1" nodeId="10.1.1.101"> <value>cmVwb3J0aW5ndXNlcjpjaGFuZ2VtZQ==</value> </response>
The resulting key is `cmVwb3J0aW5ndXNlcjpjaGFuZ2VtZQ`.

Create the request

The following cURL request queries the ef-build table in the database. In the context of the URL below, ef-build-* tells OpenSearch to return data from the CloudBees Analytics (ef-) deployment table. The asterisk is a wildcard indicating to return deployment data for all time; the indices are tagged with the year (-2021).

curl -X POST \ 'https://<hostname>:9201/ef-build-*/_search?pretty=' \ -H 'Authorization: Basic cmVwb3J0aW5ndXNlcjpjaGFuZ2VtZQ ' \ -H 'Content-Type: application/json' \ -d '{"size": 10,"query": {"bool": {}}}'

Assuming the CloudBees Analytics server instance has deployment data, running this request should return something like the following (only the first few lines are shown here). Report data is returned in _source elements in the result set. Refer to schemas documented in Understand the CloudBees Analytics data model for description of result set fields. In this case, Understand the CloudBees Analytics data model.

{ { "took" : 8, "timed_out" : false, "_shards" : { "total" : 2, "successful" : 2, "skipped" : 0, "failed" : 0 }, "hits" : { "total" : 1624, "max_score" : 1.0, "hits" : [ { "_index" : "ef-build-2021", "_type" : "doc", "_id" : "5CVyPXcBLrhx_rZ26wl7", "_score" : 1.0, "_source" : { "timestamp" : "2021-01-26T06:47:55.751Z", "reportObjectType" : "build", "controllerName" : "inst2-test_9a715976-cf41-43c8-9429-94b0099523ce", "startTime" : "2021-01-26T06:46:55.751Z", "duration" : 60000, "buildStatus" : "SUCCESS", ...

Search the database

The following cURL request queries the ef-build-* table in the database searching for records whose buildStatus field is set to SUCCESS. In the context of the URL below, ef-build-* tells OpenSearch to return data from the CloudBees Analytics (ef-) deployment table. The asterisk is a wildcard indicating to return deployment data for all time; the indices are tagged with the year (-2021).

curl -X POST \ 'https://<hostname>:9201/ef-deployment%2A/_search?q=deploymentOutcome:success' \ -H 'Authorization: Basic cmVwb3J0aW5ndXNlcjpjaGFuZ2VtZQ ' \ -H 'Content-Type: application/json'

Assuming the instance has been used for deployments, running this request should return something like the following (only the first few lines are shown here). The field in the request is highlighted in blue.

{ { "took" : 8, "timed_out" : false, "_shards" : { "total" : 2, "successful" : 2, "skipped" : 0, "failed" : 0 }, "hits" : { "total" : 1624, "max_score" : 1.0, "hits" : [ { "_index" : "ef-build-2021", "_type" : "doc", "_id" : "5CVyPXcBLrhx_rZ26wl7", "_score" : 1.0, "_source" : { "timestamp" : "2021-01-26T06:47:55.751Z", "reportObjectType" : "build", "controllerName" : "inst2-test_9a715976-cf41-43c8-9429-94b0099523ce", "startTime" : "2021-01-26T06:46:55.751Z", "duration" : 60000, "buildStatus" : "SUCCESS", ...

OpenSearch keywords

Since report definitions are constructed using OpenSearch DSL queries behind the scenes, some knowledge of OpenSearch is valuable to build custom reports. Extensive documentation and examples are available on opensearch.org. OpenSearch training is beyond the scope of this document.