Tempo CLI
Tempo CLI is a separate executable that contains utility functions related to the Tempo software. Although it’s not required for a working installation, Tempo CLI can be helpful for deeper analysis or for troubleshooting.
Tempo CLI command syntax
The general syntax for commands in Tempo CLI is:
tempo-cli command [subcommand] [options] [arguments...]--help or -h displays the help for a command or subcommand.
Example:
tempo-cli -h
tempo-cli command [subcommand] -hRun Tempo CLI
Tempo CLI is currently available as source code. A working Go installation is required to build it. It can be compiled to a native binary and executed normally, or it can be executed using the go run command.
It can be packaged as a Docker container using make docker-tempo-cli.
Example:
./tempo-cli [arguments...]
go run ./cmd/tempo-cli [arguments...]make docker-tempo-cli
docker run docker.io/grafana/tempo-cli [arguments...]Backend options
Tempo CLI connects directly to the storage backend for some commands, meaning that it requires the ability to read from S3, GCS, Azure or file-system storage. The backend can be configured in a few ways:
- Load an existing tempo configuration file using the --config-file(-c) option. This is the recommended option for frequent usage. Refer to Configuration documentation for more information.
- Specify individual settings:- --backend <value>The storage backend type, one of- s3,- gcs,- azure, and- local.
- --bucket <value>The bucket name. The meaning of this value is backend-specific. Refer to Configuration documentation for more information.
- --s3-endpoint <value>The S3 API endpoint (i.e. s3.dualstack.us-east-2.amazonaws.com).
- --s3-user <value>,- --s3-pass <value>The S3 user name and password (or access key and secret key). Optional, as Tempo CLI supports the same authentication mechanisms as Tempo. See S3 permissions documentation for more information.
- --insecure-skip-verifyskip TLS verification, only applies to S3 and GCS.
 
Each option applies only to the command in which it is used. For example, --backend <value> does not permanently change where Tempo stores data. It only changes it for command in which you apply the option.
Query API command
Trace ID
Call the Tempo API and retrieve a trace by ID.
tempo-cli query api trace-id <api-endpoint> <trace-id>Arguments:
- api-endpointURL for tempo API.
- trace-idTrace ID as a hexadecimal string.
Options:
- --org-id <value>Organization ID (for use in multi-tenant setup).
- --v1use v1 API (use /api/traces endpoint to fetch traces, default: /api/v2/traces).
Example:
tempo-cli query api trace-id http://tempo:3200 f1cfe82a8eef933bSearch
Call the Tempo API and search using TraceQL.
tempo-cli query api search <host-port> <trace-ql> [<start> <end>]Arguments:
- host-portA host/port combination for Tempo. The scheme will be inferred based on the options provided.
- trace-qlTraceQL query.
- startStart of the time range to search: (YYYY-MM-DDThh:mm:ss)
- endEnd of the time range to search: (YYYY-MM-DDThh:mm:ss)
Options:
- --org-id <value>Organization ID (for use in multi-tenant setup).
- --use-grpcUse GRPC streaming
- --spss <value>Number of spans to return for each spanset
- --limit <value>Number of results to return
- --path-prefix <value>String to prefix search paths with
Note
Streaming over HTTP requires the
stream_over_http_enabledflag to be set. For more information, refer to Tempo GRPC API documentation.
Search tags
Call the Tempo API and search attribute names.
tempo-cli query api search-tags <host-port> [<start> <end>]Arguments:
- host-portA host/port combination for Tempo. The scheme will be inferred based on the options provided.
- startStart of the time range to search: (YYYY-MM-DDThh:mm:ss)
- endEnd of the time range to search: (YYYY-MM-DDThh:mm:ss)
Options:
- --org-id <value>Organization ID (for use in multi-tenant setup).
- --use-grpcUse GRPC streaming
- --path-prefix <value>String to prefix search paths with
Note
Streaming over HTTP requires the
stream_over_http_enabledflag to be set. For more information, refer to Tempo GRPC API documentation.
Search tag values
Call the Tempo API and search attribute values.
tempo-cli query api search-tag-values <tag> <host-port> [<start> <end>]Arguments:
- host-portA host/port combination for Tempo. The scheme will be inferred based on the options provided.
- tagThe fully qualified traceql tag to search for. e.g.- resource.service.name
- startStart of the time range to search: (YYYY-MM-DDThh:mm:ss)
- endEnd of the time range to search: (YYYY-MM-DDThh:mm:ss)
Options:
- --org-id <value>Organization ID (for use in multi-tenant setup).
- --use-grpcUse GRPC streaming
- --path-prefix <value>String to prefix search paths with
Note
Streaming over HTTP requires the
stream_over_http_enabledflag to be set. For more information, refer to Tempo GRPC API documentation.
Metrics
Call the Tempo API and generate metrics from traces using TraceQL.
tempo-cli query api metrics <host-port> <trace-ql metrics query> [<start> <end>]Arguments:
- host-portA host/port combination for Tempo. The scheme will be inferred based on the options provided.
- trace-ql metrics queryTraceQL metrics query.
- startStart of the time range to search: (YYYY-MM-DDThh:mm:ss)
- endEnd of the time range to search: (YYYY-MM-DDThh:mm:ss)
Options:
- --org-id <value>Organization ID (for use in multi-tenant setup).
- --use-grpcUse GRPC streaming
- --path-prefix <value>String to prefix search paths with
Note
Streaming over HTTP requires the
stream_over_http_enabledflag to be set. For more information, refer to Tempo GRPC API documentation.
Query blocks command
Iterate over all backend blocks and dump all data found for a given trace id.
tempo-cli query blocks <trace-id> <tenant-id>Note
This can be intense as it downloads every bloom filter and some percentage of indexes/trace data.
Arguments:
- trace-idTrace ID as a hexadecimal string.
- tenant-idTenant to search.
Options: See backend options above.
Example:
tempo-cli query blocks f1cfe82a8eef933b single-tenantQuery trace summary command
Iterate over all backend blocks and dump a summary for a given trace id.
The summary includes:
- number of blocks the trace is found in
- span count
- trace size
- trace duration
- root service name
- root span info
- top frequent service names
tempo-cli query trace-summary <trace-id> <tenant-id>Note: can be intense as it downloads every bloom filter and some percentage of indexes/trace data.
Arguments:
- trace-idTrace ID as a hexadecimal string.
- tenant-idTenant to search.
Options: See backend options above.
Example:
tempo-cli query trace-summary f1cfe82a8eef933b single-tenantList blocks
Lists information about all blocks for the given tenant, and optionally perform integrity checks on indexes for duplicate records.
tempo-cli list blocks <tenant-id>Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
Options:
- --include-compactedInclude blocks that have been compacted. Default behavior is to display only active blocks.
Output: Explanation of output:
- IDBlock ID.
- LvlCompaction level of the block.
- ObjectsNumber of objects stored in the block.
- SizeData size of the block after any compression.
- EncodingBlock encoding (compression algorithm).
- VersBlock version.
- WindowThe window of time that was considered for compaction purposes.
- StartThe earliest timestamp stored in the block.
- EndThe latest timestamp stored in the block.
- DurationDuration between the start and end time.
- AgeThe age of the block.
- CmpWhether the block has been compacted (present when –include-compacted is specified).
Example:
tempo-cli list blocks -c ./tempo.yaml single-tenantList block
Lists information about a single block, and optionally, scan its contents.
tempo-cli list block <tenant-id> <block-id>Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
- block-idThe block ID as UUID string.
Options:
- --scanAlso load the block data, perform integrity check for duplicates, and collect statistics. Note: can be intense.
Example:
tempo-cli list block -c ./tempo.yaml single-tenant ca314fba-efec-4852-ba3f-8d2b0bbf69f1List compaction summary
Summarizes information about all blocks for the given tenant based on compaction level. This command is useful to analyze or troubleshoot compactor behavior.
tempo-cli list compaction-summary <tenant-id>Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
Example:
tempo-cli list compaction-summary -c ./tempo.yaml single-tenantList cache summary
Prints information about the number of bloom filter shards per day per compaction level. This command is useful to estimate and fine-tune cache storage. Read the caching topic for more information.
tempo-cli list cache-summary <tenant-id>Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
Example:
tempo-cli list cache-summary -c ./tempo.yaml single-tenantList index
Lists basic index info for the given block.
tempo-cli list index <tenant-id> <block-id>Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
- block-idThe block ID as UUID string.
Example:
tempo-cli list index -c ./tempo.yaml single-tenant ca314fba-efec-4852-ba3f-8d2b0bbf69f1View index
View the index contents for the given block.
tempo-cli view index <tenant-id> <block-id>Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
- block-idThe block ID as UUID string.
Example:
tempo-cli view index -c ./tempo.yaml single-tenant ca314fba-efec-4852-ba3f-8d2b0bbf69f1Generate bloom filter
To generate the bloom filter for a block if the files were deleted/corrupted.
Note: ensure that the block is in a local backend in the expected directory hierarchy, i.e. path / tenant / blocks.
Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
- block-idThe block ID as UUID string.
- bloom-fpThe false positive to be used for the bloom filter.
- bloom-shard-sizeThe shard size to be used for the bloom filter.
Example:
tempo-cli gen bloom --backend=local --bucket=./cmd/tempo-cli/test-data/ single-tenant b18beca6-4d7f-4464-9f72-f343e688a4a0 0.05 100000The bloom filter will be generated at the required location under the block folder.
Generate index
To generate the index/bloom for a block if the files were deleted/corrupted.
Note: ensure that the block is in a local backend in the expected directory hierarchy, i.e. path / tenant / blocks.
Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
- block-idThe block ID as UUID string.
Example:
tempo-cli gen index --backend=local --bucket=./cmd/tempo-cli/test-data/ single-tenant b18beca6-4d7f-4464-9f72-f343e688a4a0The index will be generated at the required location under the block folder.
Search blocks command
Search blocks in a given time range for a specific key/value pair.
tempo-cli search blocks <name> <value> <start> <end> <tenant-id>Note: can be intense as it downloads all relevant blocks and iterates through them.
Arguments:
- nameName of the attribute to search for e.g.- http.post
- valueValue of the attribute to search for e.g.- GET
- startStart of the time range to search: (YYYY-MM-DDThh:mm:ss)
- endEnd of the time range to search: (YYYY-MM-DDThh:mm:ss)
- tenant-idTenant to search.
Options: See backend options above.
Example:
tempo-cli search blocks http.post GET 2021-09-21T00:00:00 2021-09-21T00:05:00 single-tenant --backend=gcs --bucket=tempo-trace-dataParquet convert command
Converts a parquet file from its existing schema to the one currently in the repository. This utility command is useful when attempting to determine the impact of changing compression or encoding of columns.
tempo-cli parquet convert <in file> <out file>Arguments:
- in fileFilename of an existing parquet file containing Tempo trace data
- out fileFile to write to. (Existing file is overwritten.)
Example:
tempo-cli parquet convert data.parquet out.parquetParquet convert 2 to 3 command
Converts a vParquet2 file (actual data.parquet) to a vParquet3 block with an optional list of dedicated attribute columns. This utility command is useful when testing the impact of different combinations of dedicated columns. Currently, all listed columns are assumed to be at the span scope.
tempo-cli parquet convert-2-to-3 <in file> <out path> <list of dedicated columns>Arguments:
- in fileFilename of an existing vParquet2 file containing Tempo trace data
- out pathPath to write the vParquet3 block to.
- list of dedicated columnsAdditional params indicating which columns to make dedicated. Max 10. Dedicated columns should be named using TraceQL syntax with scope. i.e.- span.db.statementor- resource.namespace.
Example:
tempo-cli parquet convert-2-to-3 data.parquet ./out db.statement db.nameMigrate tenant command
Copy blocks from one backend and tenant to another. Blocks can be copied within the same backend or between two
different backends. Data format will not be converted but tenant ID in meta.json will be rewritten.
tempo-cli migrate tenant <source tenant> <dest tenant>Arguments:
- source tenantTenant to copy blocks from
- dest tenantTenant to copy blocks into
Options:
- --source-config-file <value>Configuration file for the source backend
- --config-file <value>Configuration file for the destination backend
Example:
tempo-cli migrate tenant --source-config source.yaml --config-file dest.yaml my-tenant my-other-tenantMigrate overrides config command
Migrate overrides config from inline format (legacy) to idented YAML format (new).
tempo-cli migrate overrides-config <source config file>Arguments:
- source config fileConfiguration file to migrate
Options:
- --config-dest <value>Destination file for the migrated config. If not specified, config is printed to stdout.
- --overrides-dest <value>Destination file for the migrated overrides. If not specified, overrides are printed to stdout.
Example:
tempo-cli migrate overrides-config config.yaml --config-dest config-tmp.yaml --overrides-dest overrides-tmp.yamlAnalyse block
Analyses a block and outputs a summary of the block’s generic attributes. It’s of particular use when trying to determine candidates for dedicated attribute columns in vParquet3.
Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
- block-idThe block ID as UUID string.
Options:
- Backend options
- --num-attr <value>Number of attributes to output (default: 10)
Example:
tempo-cli analyse block --backend=local --bucket=./cmd/tempo-cli/test-data/ single-tenant b18beca6-4d7f-4464-9f72-f343e688a4a0Analyse blocks
Analyses all blocks in a given time range and outputs a summary of the blocks’ generic attributes. It’s of particular use when trying to determine candidates for dedicated attribute columns in vParquet3 and vParquet4.
Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single-tenant setups.
Options:
- Backend options
- --num-attr <value>Number of attributes to output (default: 10)
- --min-compaction-level <value>Minimum compaction level to include in the analysis (default: 3)
- --max-blocks <value>Maximum number of blocks to analyze (default: 10)
- --max-start-time <value>Oldest start time for a block to be processed. RFC3339 format (default: disabled)
- --min-end-time <value>Newest end time for a block to be processed. RFC3339 format (default: disabled)
Example:
tempo-cli analyse blocks --backend=local --bucket=./cmd/tempo-cli/test-data/ single-tenantDrop traces by ID
Rewrites all blocks for a tenant that contain a specific trace IDs. The traces are dropped from the new blocks and the rewritten blocks are marked compacted so they will be cleaned up.
Arguments:
- tenant-idThe tenant ID. Use- single-tenantfor single tenant setups.
- trace-idsThe comma-separated trace IDs to drop (also supports single trace ID)
Options:
- Backend options
- --drop-tracesBy default, this command runs in dry run mode. Supplying this argument causes it to actually rewrite blocks with the traces dropped.
Examples
Drop one trace:
tempo-cli rewrite-blocks drop-trace --backend=local --bucket=./cmd/tempo-cli/test-data/ single-tenant 04d5f549746c96e4f3daed6202571db2Drop multiple traces:
tempo-cli rewrite-blocks drop-trace --backend=local --bucket=./cmd/tempo-cli/test-data/ single-tenant 04d5f549746c96e4f3daed6202571db2,111fa1850042aea83c17cd7e674210b8





