InfluxDB 3 Core configuration options
InfluxDB 3 Core lets you customize your configuration by using
influxdb3 command options or by setting environment variables.
Configure your server
Pass configuration options using either command options or environment variables. Command options take precedence over environment variables.
Global vs serve-specific options
Some options are global (specified before the command) while others are serve-specific (specified after serve):
- Global options: Apply to the
influxdb3CLI itself (for example,--num-io-threads) - Serve options: Apply only to the
servecommand (for example,--node-id,--object-store,--verbose)
Example command with global and serve-specific options
influxdb3 --num-io-threads=4 serve \
--node-id node0 \
--object-store file \
--data-dir ~/.influxdb3 \
--verbose \
--log-filter infoExample environment variables
export INFLUXDB3_NODE_IDENTIFIER_PREFIX=my-node
export INFLUXDB3_OBJECT_STORE=file
export INFLUXDB3_DB_DIR=~/.influxdb3
export LOG_FILTER=info
influxdb3 serveGlobal configuration options
The following options apply to the influxdb3 CLI globally and must be specified before any subcommand (for example, serve):
num-io-threads
Sets the number of threads allocated to the IO runtime thread pool. IO threads handle HTTP request serving, line protocol parsing, and file operations.
--num-io-threads is a global option that must be specified before the serve command.
# Set IO threads (global option before serve)
influxdb3 --num-io-threads=8 serve --node-id=node0 --object-store=file| influxdb3 option | Environment variable |
|---|---|
--num-io-threads | INFLUXDB3_NUM_IO_THREADS |
Server configuration options
General
data-dir
For the file object store, defines the location InfluxDB 3 Core uses to store files locally.
Required when using the file object store.
| influxdb3 serve option | Environment variable |
|---|---|
--data-dir | INFLUXDB3_DB_DIR |
node-id
Specifies the node identifier used as a prefix in all object store file paths. This should be unique for any hosts sharing the same object store configuration–for example, the same bucket.
| influxdb3 serve option | Environment variable |
|---|---|
--node-id | INFLUXDB3_NODE_IDENTIFIER_PREFIX |
object-store
Specifies which object storage to use to store Parquet files. This option supports the following values:
memory: Effectively no object persistencememory-throttled: Likememorybut with latency and throughput that somewhat resembles a cloud object storefile: Stores objects in the local filesystem (must also set--data-dir)s3: Amazon S3 (must also set--bucket,--aws-access-key-id,--aws-secret-access-key, and possibly--aws-default-region)google: Google Cloud Storage (must also set--bucketand--google-service-account)azure: Microsoft Azure blob storage (must also set--bucket,--azure-storage-account, and--azure-storage-access-key)
| influxdb3 serve option | Environment variable |
|---|---|
--object-store | INFLUXDB3_OBJECT_STORE |
Security
- tls-key
- tls-cert
- tls-minimum-versions
- without-auth
- disable-authz
- admin-token-recovery-http-bind
- admin-token-file
tls-key
The path to a key file for TLS to be enabled.
| influxdb3 serve option | Environment variable |
|---|---|
--tls-key | INFLUXDB3_TLS_KEY |
tls-cert
The path to a cert file for TLS to be enabled.
| influxdb3 serve option | Environment variable |
|---|---|
--tls-cert | INFLUXDB3_TLS_CERT |
tls-minimum-version
The minimum version for TLS.
Valid values are tls-1.2 or tls-1.3.
Default is tls-1.2.
| influxdb3 serve option | Environment variable |
|---|---|
--tls-minimum-version | INFLUXDB3_TLS_MINIMUM_VERSION |
without-auth
Disables authentication for all server actions (CLI commands and API requests). The server processes all requests without requiring tokens or authentication.
| influxdb3 serve option | Environment variable |
|---|---|
--without-auth | INFLUXDB3_START_WITHOUT_AUTH |
disable-authz
Optionally disable authz by passing in a comma separated list of resources.
Valid values are health, ping, and metrics.
| influxdb3 serve option | Environment variable |
|---|---|
--disable-authz | INFLUXDB3_DISABLE_AUTHZ |
admin-token-recovery-http-bind
Enables an admin token recovery HTTP server on a separate port. This server allows regenerating lost admin tokens without existing authentication. The server automatically shuts down after a successful token regeneration.
This option creates an unauthenticated endpoint that can regenerate admin tokens. Only use this when you have lost access to your admin token and ensure the server is only accessible from trusted networks.
Default: 127.0.0.1:8182 (when enabled)
| influxdb3 serve option | Environment variable |
|---|---|
--admin-token-recovery-http-bind | INFLUXDB3_ADMIN_TOKEN_RECOVERY_HTTP_BIND |
Example usage
# Start server with recovery endpoint
influxdb3 serve --admin-token-recovery-http-bind
# In another terminal, regenerate the admin token
influxdb3 create token --admin --regenerate --host http://127.0.0.1:8182admin-token-file
Specifies an offline admin token file to use if no tokens exist when the server starts. Once started, you can interact with the server using the provided token. Offline admin tokens are designed to help with automated deployments.
| influxdb3 serve option | Environment variable |
|---|---|
--admin-token-file | INFLUXDB3_ADMIN_TOKEN_FILE |
Offline admin tokens are defined in a JSON-formatted file. Use the following command to generate an offline admin token file:
influxdb3 create token --admin \
--name "example-admin-token" \
--expiry 1d \
--offline \
--output-file ./path/to/admin-token.jsonExample usage
# Generate an admin token offline
influxdb3 create token \
--admin \
--name "example-admin-token" \
--expiry 1d \
--offline \
--output-file ./path/to/admin-token.json
# Start InfluxDB 3 Core using the generated token
influxdb3 serve --admin-token-file ./path/to/admin-token.jsonAWS
- aws-access-key-id
- aws-secret-access-key
- aws-default-region
- aws-endpoint
- aws-session-token
- aws-allow-http
- aws-skip-signature
- aws-credentials-file
aws-access-key-id
When using Amazon S3 as the object store, set this to an access key that has permission to read from and write to the specified S3 bucket.
| influxdb3 serve option | Environment variable |
|---|---|
--aws-access-key-id | AWS_ACCESS_KEY_ID |
aws-secret-access-key
When using Amazon S3 as the object store, set this to the secret access key that goes with the specified access key ID.
| influxdb3 serve option | Environment variable |
|---|---|
--aws-secret-access-key | AWS_SECRET_ACCESS_KEY |
aws-default-region
When using Amazon S3 as the object store, set this to the region that goes with the specified bucket if different from the fallback value.
Default: us-east-1
| influxdb3 serve option | Environment variable |
|---|---|
--aws-default-region | AWS_DEFAULT_REGION |
aws-endpoint
When using an Amazon S3 compatibility storage service, set this to the endpoint.
| influxdb3 serve option | Environment variable |
|---|---|
--aws-endpoint | AWS_ENDPOINT |
aws-session-token
When using Amazon S3 as an object store, set this to the session token. This is handy when using a federated login or SSO and fetching credentials via the UI.
| influxdb3 serve option | Environment variable |
|---|---|
--aws-session-token | AWS_SESSION_TOKEN |
aws-allow-http
Allows unencrypted HTTP connections to AWS.
| influxdb3 serve option | Environment variable |
|---|---|
--aws-allow-http | AWS_ALLOW_HTTP |
aws-skip-signature
If enabled, S3 object stores do not fetch credentials and do not sign requests.
| influxdb3 serve option | Environment variable |
|---|---|
--aws-skip-signature | AWS_SKIP_SIGNATURE |
aws-credentials-file
Specifies the path to your S3 credentials file. When using a credentials file, settings in the file override the corresponding CLI flags.
S3 credential files are JSON-formatted and should contain the following:
{
"aws_access_key_id": "AWS_ACCESS_KEY_ID",
"aws_secret_access_key": "AWS_SECRET_ACCESS_KEY",
"aws_session_token": "AWS_SESSION_TOKEN",
"expiry": "UNIX_SECONDS_TIMESTAMP"
}The aws_session_token and expiry fields are optional.
The file is automatically checked for updates at the expiry time or at 1-hour
intervals.
If the object store returns an “Unauthenticated” error, InfluxDB will attempt to update its in-memory credentials from this file and then retry the object store request.
| influxdb3 serve option | Environment variable |
|---|---|
--aws-credentials-file | AWS_CREDENTIALS_FILE |
Google Cloud Service
google-service-account
When using Google Cloud Storage as the object store, set this to the path to the JSON file that contains the Google credentials.
| influxdb3 serve option | Environment variable |
|---|---|
--google-service-account | GOOGLE_SERVICE_ACCOUNT |
Microsoft Azure
azure-storage-account
When using Microsoft Azure as the object store, set this to the name you see
when navigating to All Services > Storage accounts > [name].
| influxdb3 serve option | Environment variable |
|---|---|
--azure-storage-account | AZURE_STORAGE_ACCOUNT |
azure-storage-access-key
When using Microsoft Azure as the object store, set this to one of the Key values in the Storage account’s Settings > Access keys.
| influxdb3 serve option | Environment variable |
|---|---|
--azure-storage-access-key | AZURE_STORAGE_ACCESS_KEY |
azure-endpoint
When using Microsoft Azure as the object store, set this to the Azure Blob Storage endpoint.
| influxdb3 serve option | Environment variable |
|---|---|
--azure-endpoint | AZURE_ENDPOINT |
azure-allow-http
When using Microsoft Azure as the object store, allow unencrypted HTTP requests to Azure Blob Storage.
Default: false
| influxdb3 serve option | Environment variable |
|---|---|
--azure-allow-http | AZURE_ALLOW_HTTP |
Object Storage
- bucket
- object-store-connection-limit
- object-store-http2-only
- object-store-http2-max-frame-size
- object-store-max-retries
- object-store-retry-timeout
- object-store-cache-endpoint
bucket
Sets the name of the object storage bucket to use. Must also set
--object-store to a cloud object storage for this option to take effect.
| influxdb3 serve option | Environment variable |
|---|---|
--bucket | INFLUXDB3_BUCKET |
object-store-connection-limit
When using a network-based object store, limits the number of connections to this value.
Default: 16
| influxdb3 serve option | Environment variable |
|---|---|
--object-store-connection-limit | OBJECT_STORE_CONNECTION_LIMIT |
object-store-http2-only
Forces HTTP/2 connections to network-based object stores.
| influxdb3 serve option | Environment variable |
|---|---|
--object-store-http2-only | OBJECT_STORE_HTTP2_ONLY |
object-store-http2-max-frame-size
Sets the maximum frame size (in bytes/octets) for HTTP/2 connections.
| influxdb3 serve option | Environment variable |
|---|---|
--object-store-http2-max-frame-size | OBJECT_STORE_HTTP2_MAX_FRAME_SIZE |
object-store-max-retries
Defines the maximum number of times to retry a request.
| influxdb3 serve option | Environment variable |
|---|---|
--object-store-max-retries | OBJECT_STORE_MAX_RETRIES |
object-store-retry-timeout
Specifies the maximum length of time from the initial request after which no further retries are be attempted.
| influxdb3 serve option | Environment variable |
|---|---|
--object-store-retry-timeout | OBJECT_STORE_RETRY_TIMEOUT |
object-store-cache-endpoint
Sets the endpoint of an S3-compatible, HTTP/2-enabled object store cache.
| influxdb3 serve option | Environment variable |
|---|---|
--object-store-cache-endpoint | OBJECT_STORE_CACHE_ENDPOINT |
Logs
log-filter
Sets the filter directive for logs.
| influxdb3 serve option | Environment variable |
|---|---|
--log-filter | LOG_FILTER |
log-destination
Specifies the destination for logs.
This option supports the following values:
stdout(default)stderr
Default: stdout
| influxdb3 serve option | Environment variable |
|---|---|
--log-destination | LOG_DESTINATION |
log-format
Defines the message format for logs.
This option supports the following values:
full(default)
Default: full
| influxdb3 serve option | Environment variable |
|---|---|
--log-format | LOG_FORMAT |
query-log-size
Defines the size of the query log. Up to this many queries remain in the log before older queries are evicted to make room for new ones.
Default: 1000
| influxdb3 serve option | Environment variable |
|---|---|
--query-log-size | INFLUXDB3_QUERY_LOG_SIZE |
Traces
- traces-exporter
- traces-exporter-jaeger-agent-host
- traces-exporter-jaeger-agent-port
- traces-exporter-jaeger-service-name
- traces-exporter-jaeger-trace-context-header-name
- traces-jaeger-debug-name
- traces-jaeger-tags
- traces-jaeger-max-msgs-per-second
traces-exporter
Sets the type of tracing exporter.
Default: none
| influxdb3 serve option | Environment variable |
|---|---|
--traces-exporter | TRACES_EXPORTER |
traces-exporter-jaeger-agent-host
Specifies the Jaeger agent network hostname for tracing.
Default: 0.0.0.0
| influxdb3 serve option | Environment variable |
|---|---|
--traces-exporter-jaeger-agent-host | TRACES_EXPORTER_JAEGER_AGENT_HOST |
traces-exporter-jaeger-agent-port
Defines the Jaeger agent network port for tracing.
Default: 6831
| influxdb3 serve option | Environment variable |
|---|---|
--traces-exporter-jaeger-agent-port | TRACES_EXPORTER_JAEGER_AGENT_PORT |
traces-exporter-jaeger-service-name
Sets the Jaeger service name for tracing.
Default: iox-conductor
| influxdb3 serve option | Environment variable |
|---|---|
--traces-exporter-jaeger-service-name | TRACES_EXPORTER_JAEGER_SERVICE_NAME |
traces-exporter-jaeger-trace-context-header-name
Specifies the header name used for passing trace context.
Default: uber-trace-id
| influxdb3 serve option | Environment variable |
|---|---|
--traces-exporter-jaeger-trace-context-header-name | TRACES_EXPORTER_JAEGER_TRACE_CONTEXT_HEADER_NAME |
traces-jaeger-debug-name
Specifies the header name used for force sampling in tracing.
Default: jaeger-debug-id
| influxdb3 serve option | Environment variable |
|---|---|
--traces-jaeger-debug-name | TRACES_EXPORTER_JAEGER_DEBUG_NAME |
traces-jaeger-tags
Defines a set of key=value pairs to annotate tracing spans with.
| influxdb3 serve option | Environment variable |
|---|---|
--traces-jaeger-tags | TRACES_EXPORTER_JAEGER_TAGS |
traces-jaeger-max-msgs-per-second
Specifies the maximum number of messages sent to a Jaeger service per second.
Default: 1000
| influxdb3 serve option | Environment variable |
|---|---|
--traces-jaeger-max-msgs-per-second | TRACES_JAEGER_MAX_MSGS_PER_SECOND |
DataFusion
- datafusion-num-threads
- datafusion-max-parquet-fanout
- datafusion-use-cached-parquet-loader
- datafusion-config
datafusion-num-threads
Sets the maximum number of DataFusion runtime threads to use.
| influxdb3 serve option | Environment variable |
|---|---|
--datafusion-num-threads | INFLUXDB3_DATAFUSION_NUM_THREADS |
datafusion-max-parquet-fanout
When multiple Parquet files are required in a sorted way (deduplication for example), specifies the maximum fanout.
Default: 1000
| influxdb3 serve option | Environment variable |
|---|---|
--datafusion-max-parquet-fanout | INFLUXDB3_DATAFUSION_MAX_PARQUET_FANOUT |
datafusion-use-cached-parquet-loader
Uses a cached Parquet loader when reading Parquet files from the object store.
| influxdb3 serve option | Environment variable |
|---|---|
--datafusion-use-cached-parquet-loader | INFLUXDB3_DATAFUSION_USE_CACHED_PARQUET_LOADER |
datafusion-config
Provides custom configuration to DataFusion as a comma-separated list of
key:value pairs.
| influxdb3 serve option | Environment variable |
|---|---|
--datafusion-config | INFLUXDB3_DATAFUSION_CONFIG |
HTTP
max-http-request-size
Specifies the maximum size of HTTP requests.
Default: 10485760
| influxdb3 serve option | Environment variable |
|---|---|
--max-http-request-size | INFLUXDB3_MAX_HTTP_REQUEST_SIZE |
http-bind
Defines the address on which InfluxDB serves HTTP API requests.
Default: 0.0.0.0:8181
| influxdb3 serve option | Environment variable |
|---|---|
--http-bind | INFLUXDB3_HTTP_BIND_ADDR |
Memory
exec-mem-pool-bytes
Specifies the size of the memory pool used for query processing and data operations.
This memory pool is used when InfluxDB 3 Core processes queries and performs
internal data management tasks.
Can be given as absolute value in bytes or as a percentage of the total available memory–for
example: 8000000000 or 10%.
Default: 8589934592
| influxdb3 serve option | Environment variable |
|---|---|
--exec-mem-pool-bytes | INFLUXDB3_EXEC_MEM_POOL_BYTES |
force-snapshot-mem-threshold
Specifies the threshold for the internal memory buffer. Supports either a
percentage (portion of available memory) or absolute value in MB–for example: 70% or 1000.
Default: 70%
| influxdb3 serve option | Environment variable |
|---|---|
--force-snapshot-mem-threshold | INFLUXDB3_FORCE_SNAPSHOT_MEM_THRESHOLD |
Write-Ahead Log (WAL)
- wal-flush-interval
- wal-snapshot-size
- wal-max-write-buffer-size
- snapshotted-wal-files-to-keep
- wal-replay-fail-on-error
- wal-replay-concurrency-limit
wal-flush-interval
Specifies the interval to flush buffered data to a WAL file. Writes that wait
for WAL confirmation take up to this interval to complete.
Use s for seconds or ms for milliseconds. For local disks, 100 ms is recommended.
Default: 1s
| influxdb3 serve option | Environment variable |
|---|---|
--wal-flush-interval | INFLUXDB3_WAL_FLUSH_INTERVAL |
wal-snapshot-size
Defines the number of WAL files to attempt to remove in a snapshot. This, multiplied by the interval, determines how often snapshots are taken.
Default: 600
| influxdb3 serve option | Environment variable |
|---|---|
--wal-snapshot-size | INFLUXDB3_WAL_SNAPSHOT_SIZE |
wal-max-write-buffer-size
Specifies the maximum number of write requests that can be buffered before a flush must be executed and succeed.
Default: 100000
| influxdb3 serve option | Environment variable |
|---|---|
--wal-max-write-buffer-size | INFLUXDB3_WAL_MAX_WRITE_BUFFER_SIZE |
snapshotted-wal-files-to-keep
Specifies the number of snapshotted WAL files to retain in the object store. Flushing the WAL files does not clear the WAL files immediately; they are deleted when the number of snapshotted WAL files exceeds this number.
Default: 300
| influxdb3 serve option | Environment variable |
|---|---|
--snapshotted-wal-files-to-keep | INFLUXDB3_NUM_WAL_FILES_TO_KEEP |
wal-replay-fail-on-error
Determines whether WAL replay should fail when encountering errors.
Default: false
| influxdb3 serve option | Environment variable |
|---|---|
--wal-replay-fail-on-error | INFLUXDB3_WAL_REPLAY_FAIL_ON_ERROR |
wal-replay-concurrency-limit
Concurrency limit during WAL replay. Setting this number too high can lead to OOM. The default is dynamically determined.
Default: max(num_cpus, 10)
| influxdb3 serve option | Environment variable |
|---|---|
--wal-replay-concurrency-limit | INFLUXDB3_WAL_REPLAY_CONCURRENCY_LIMIT |
Compaction
gen1-duration
Specifies the duration that Parquet files are arranged into. Data timestamps
land each row into a file of this duration. Supported durations are 1m,
5m, and 10m. These files are known as “generation 1” files that the
compactor in InfluxDB 3 Enterprise can merge into larger generations.
Default: 10m
| influxdb3 serve option | Environment variable |
|---|---|
--gen1-duration | INFLUXDB3_GEN1_DURATION |
Caching
preemptive-cache-age
Specifies the interval to prefetch into the Parquet cache during compaction.
Default: 3d
| influxdb3 serve option | Environment variable |
|---|---|
--preemptive-cache-age | INFLUXDB3_PREEMPTIVE_CACHE_AGE |
parquet-mem-cache-size
Specifies the size of the in-memory Parquet cache. Accepts values in megabytes (as an integer) or as a percentage of total available memory (for example, 20%, 4096).
Default: 20%
Breaking change in v3.0.0
In v3.0.0, --parquet-mem-cache-size-mb was replaced with --parquet-mem-cache-size.
The new option accepts both megabytes (integer) and percentage values.
The default changed from 1000 MB to 20% of total available memory.
| influxdb3 serve option | Environment variable |
|---|---|
--parquet-mem-cache-size | INFLUXDB3_PARQUET_MEM_CACHE_SIZE |
parquet-mem-cache-prune-percentage
Specifies the percentage of entries to prune during a prune operation on the in-memory Parquet cache.
Default: 0.1
| influxdb3 serve option | Environment variable |
|---|---|
--parquet-mem-cache-prune-percentage | INFLUXDB3_PARQUET_MEM_CACHE_PRUNE_PERCENTAGE |
parquet-mem-cache-prune-interval
Sets the interval to check if the in-memory Parquet cache needs to be pruned.
Default: 1s
| influxdb3 serve option | Environment variable |
|---|---|
--parquet-mem-cache-prune-interval | INFLUXDB3_PARQUET_MEM_CACHE_PRUNE_INTERVAL |
parquet-mem-cache-query-path-duration
Specifies
the time window for caching recent Parquet files in memory. Default is 5h.
Only files containing data with a timestamp between now and now - duration
are cached when accessed during queries–for example, with the default 5h setting:
- Current time:
2024-06-10 15:00:00 - Cache window: Last 5 hours (
2024-06-10 10:00:00to now)
If a query requests data from 2024-06-09 (old) and 2024-06-10 14:00 (recent):
- Cached: Parquet files with data from
2024-06-10 14:00(within 5-hour window) - Not cached: Parquet files with data from
2024-06-09(outside 5-hour window)
| influxdb3 serve option | Environment variable |
|---|---|
--parquet-mem-cache-query-path-duration | INFLUXDB3_PARQUET_MEM_CACHE_QUERY_PATH_DURATION |
disable-parquet-mem-cache
Disables the in-memory Parquet cache. By default, the cache is enabled.
| influxdb3 serve option | Environment variable |
|---|---|
--disable-parquet-mem-cache | INFLUXDB3_DISABLE_PARQUET_MEM_CACHE |
table-index-cache-max-entries
Specifies the maximum number of entries in the table index cache.
Default: 1000
| influxdb3 serve option | Environment variable |
|---|---|
--table-index-cache-max-entries | INFLUXDB3_TABLE_INDEX_CACHE_MAX_ENTRIES |
table-index-cache-concurrency-limit
Limits the concurrency level for table index cache operations.
Default: 8
| influxdb3 serve option | Environment variable |
|---|---|
--table-index-cache-concurrency-limit | INFLUXDB3_TABLE_INDEX_CACHE_CONCURRENCY_LIMIT |
last-cache-eviction-interval
Specifies the interval to evict expired entries from the Last-N-Value cache,
expressed as a human-readable duration–for example: 20s, 1m, 1h.
Default: 10s
| influxdb3 serve option | Environment variable |
|---|---|
--last-cache-eviction-interval | INFLUXDB3_LAST_CACHE_EVICTION_INTERVAL |
distinct-cache-eviction-interval
Specifies the interval to evict expired entries from the distinct value cache,
expressed as a human-readable duration–for example: 20s, 1m, 1h.
Default: 10s
| influxdb3 serve option | Environment variable |
|---|---|
--distinct-cache-eviction-interval | INFLUXDB3_DISTINCT_CACHE_EVICTION_INTERVAL |
query-file-limit
Limits the number of Parquet files a query can access. If a query attempts to read more than this limit, InfluxDB 3 Core returns an error.
Default: 432
With the default 432 setting and the default gen1-duration
setting of 10 minutes, queries can access up to a 72 hours of data, but
potentially less depending on whether all data for a given 10 minute block of
time was ingested during the same period.
You can increase this limit to allow more files to be queried, but be aware of the following side-effects:
- Degraded query performance for queries that read more Parquet files
- Increased memory usage
- Your system potentially killing the
influxdb3process due to Out-of-Memory (OOM) errors - If using object storage to store data, many GET requests to access the data (as many as 2 per file)
We recommend keeping the default setting and querying smaller time ranges. If you need to query longer time ranges or faster query performance on any query that accesses an hour or more of data, InfluxDB 3 Enterprise optimizes data storage by compacting and rearranging Parquet files to achieve faster query performance.
| influxdb3 serve option | Environment variable |
|---|---|
--query-file-limit | INFLUXDB3_QUERY_FILE_LIMIT |
Processing Engine
plugin-dir
Specifies the local directory that contains Python plugins and their test files.
| influxdb3 serve option | Environment variable |
|---|---|
--plugin-dir | INFLUXDB3_PLUGIN_DIR |
plugin-repo
Specifies the base URL of the remote repository used when referencing plugins with the gh: prefix.
When you create a trigger with a plugin filename starting with gh:, InfluxDB fetches
the plugin code from this repository URL.
The URL construction automatically handles trailing slashes—both formats work identically:
https://example.com/plugins/(with trailing slash)https://example.com/plugins(without trailing slash)
Default: The official InfluxDB 3 plugins repository at https://raw.githubusercontent.com/influxdata/influxdb3_plugins/main/
| influxdb3 serve option | Environment variable |
|---|---|
--plugin-repo | INFLUXDB3_PLUGIN_REPO |
Example usage
# Use a custom organization repository
influxdb3 serve \
--plugin-dir ~/.plugins \
--plugin-repo "https://raw.githubusercontent.com/myorg/influxdb-plugins/main/"
# Use an internal mirror
influxdb3 serve \
--plugin-dir ~/.plugins \
--plugin-repo "https://internal.company.com/influxdb-plugins/"
# Set via environment variable
export INFLUXDB3_PLUGIN_REPO="https://custom-repo.example.com/plugins/"
influxdb3 serve --plugin-dir ~/.pluginsvirtual-env-location
Specifies the location of the Python virtual environment that the processing engine uses.
| influxdb3 serve option | Environment variable |
|---|---|
--virtual-env-location | VIRTUAL_ENV |
package-manager
Specifies the Python package manager that the Processing Engine uses to install plugin dependencies.
This option supports the following values:
discover(default): Automatically detect and use available package manager (uvorpip)pip: Use pip package manager exclusivelyuv: Use uv package manager exclusivelydisabled: Disable automatic package installation (all dependencies must be pre-installed)
Default: discover
Security mode (disabled)
When set to disabled, InfluxDB 3 Core blocks all package installation attempts for security and compliance requirements.
The Processing Engine and plugins continue to function normally, but package installation requests (via CLI or API) return a 403 Forbidden error.
This mode is designed for:
- Enterprise security requirements: Prevent arbitrary package installation
- Compliance environments: Control exactly which packages are available
- Air-gapped deployments: Pre-install all dependencies before deployment
- Multi-tenant scenarios: Prevent tenants from installing potentially malicious packages
Before using --package-manager disabled, administrators must pre-install all required Python packages into the virtual environment that plugins will use.
Example:
# Start InfluxDB 3 with disabled package manager
influxdb3 serve \
--node-id node0 \
--object-store file \
--data-dir ~/.influxdb3 \
--plugin-dir ~/.plugins \
--package-manager disabledFor more information about plugins and package management, see Processing Engine plugins.
| influxdb3 serve option | Environment variable |
|---|---|
--package-manager | INFLUXDB3_PACKAGE_MANAGER |
Resource Limits
datafusion-num-threads
Sets the number of threads allocated to the DataFusion runtime thread pool. DataFusion threads handle:
- Query execution and processing
- Data aggregation and transformation
- Snapshot creation (sort/dedupe operations)
- Parquet file generation
Default: All available cores minus IO threads
DataFusion threads are used for both query processing and snapshot operations.
| influxdb3 serve option | Environment variable |
|---|---|
--datafusion-num-threads | INFLUXDB3_DATAFUSION_NUM_THREADS |
Data Lifecycle Management
gen1-lookback-duration
Specifies how far back to look when creating generation 1 Parquet files.
Default: 24h
| influxdb3 serve option | Environment variable |
|---|---|
--gen1-lookback-duration | INFLUXDB3_GEN1_LOOKBACK_DURATION |
retention-check-interval
The interval at which retention policies are checked and enforced.
Enter as a human-readable time–for example: 30m or 1h.
Default: 30m
| influxdb3 serve option | Environment variable |
|---|---|
--retention-check-interval | INFLUXDB3_RETENTION_CHECK_INTERVAL |
delete-grace-period
Specifies the grace period before permanently deleting data.
Default: 24h
| influxdb3 serve option | Environment variable |
|---|---|
--delete-grace-period | INFLUXDB3_DELETE_GRACE_PERIOD |
hard-delete-default-duration
Sets the default duration for hard deletion of data.
Default: 90d
| influxdb3 serve option | Environment variable |
|---|---|
--hard-delete-default-duration | INFLUXDB3_HARD_DELETE_DEFAULT_DURATION |
Telemetry
telemetry-disable-upload
Disables the upload of telemetry data to InfluxData.
Default: false
| influxdb3 serve option | Environment variable |
|---|---|
--telemetry-disable-upload | INFLUXDB3_TELEMETRY_DISABLE_UPLOAD |
telemetry-endpoint
Specifies the endpoint for telemetry data uploads.
| influxdb3 serve option | Environment variable |
|---|---|
--telemetry-endpoint | INFLUXDB3_TELEMETRY_ENDPOINT |
TCP Listeners
tcp-listener-file-path
Specifies the file path for the TCP listener configuration.
| influxdb3 serve option | Environment variable |
|---|---|
--tcp-listener-file-path | INFLUXDB3_TCP_LISTINER_FILE_PATH |
admin-token-recovery-tcp-listener-file-path
Specifies the TCP listener file path for admin token recovery operations.
| influxdb3 serve option | Environment variable |
|---|---|
--admin-token-recovery-tcp-listener-file-path | INFLUXDB3_ADMIN_TOKEN_RECOVERY_TCP_LISTENER_FILE_PATH |
Was this page helpful?
Thank you for your feedback!
Support and feedback
Thank you for being part of our community! We welcome and encourage your feedback and bug reports for InfluxDB 3 Core and this documentation. To find support, use the following resources:
Customers with an annual or support contract can contact InfluxData Support.