These docs are for Cribl Stream 4.12 and are no longer actively maintained.
See the latest version (4.14).
Configure mTLS Authentication On-Prem
Once you have configured the Leader for encrypted TLS communication, you can implement client certificate exchange to enable mutual authentication (mTLS). This allows Cribl Stream to permit only explicitly authorized clients, which hold valid certificates, to connect to the Leader.
When a client certificate is presented to a Leader, two things happen:
- The Leader validates the client certificate presented to Cribl Stream. The Validate Client Certssetting is optional, but highly recommended. When enabled, the Leader checks the certificate against the trust store, to see if it has been signed by a valid certificate authority (CA).
The Leader checks the list of certificates in the CA Certificates Path box first (if populated), then against the list of built-in system certificates.
- The Leader checks whether the Common Name(CN) matches the regular expression in the configuration. Cribl Stream’s default is to accept any value in theCommon Namefield. You can customize this as needed.
Within the Common Name, we validate against the value after the CN=string. If your Common Name is CN=logstream.worker, you would enter logstream\.worker in the Common Name field – including the backslash, because the value entered is a regular expression.
The Cribl.Cloud Leader connections on port
4200/tcpdo not currently support mutual TLS (mTLS).
Limitations on mTLS Authentication
When configuring mTLS authentication on Worker Nodes, make sure you place your certificates into a separate directory outside of $CRIBL_HOME. If you place the certificates inside $CRIBL_HOME, they’ll be removed when the next config bundle is deployed from the Leader.
Similarly, you can’t bootstrap Worker Nodes with mutual authentication already populated. To bootstrap Worker Nodes, you supply only the shared authentication token. Certificates should be viewed as two-factor authentication; so placing the certificates in the config bundle defeats the purpose of two-factor authentication.
Configure via the UI
mTLS authentication in Cribl.Cloud is configured separately for each Source.
Below is a sample configuration on the Leader:

In the above configuration, note:
- You can set both the Minimum TLS version and Maximum TLS version. 
- The - Common Nameregex contains an additional check for- \d+. This allows checking for the format:- logstream1.worker,- logstream2.worker,- logstream3.worker, etc.
Using YAML Config File
To set up mTLS authentication via the Worker Node’s instance.yml config file, you need to change some values and also add a few keys, as shown in this example:
distributed:
  mode: managed-edge
  master:
    host: <hostname>
    port: 4200
    authToken: <token>
    tls:
      disabled: false
      rejectUnauthorized: true # false if ignoring untrusted certs
      requestCert: true
      privKeyPath: /path/to/certs/worker.key
      certPath: /path/to/certs/worker.pem
      caPath: /path/to/certs/root.pem
    resiliency: none
  group: default_fleet     Using Environment Variables
You can set up mTLS authentication by configuring this environment variable, using the format shown in this example:
CRIBL_DIST_LEADER_URL="tls://<authToken>@leader.cribl:4200?tls.privKeyPath=/path/to/certs/worker.key&tls.certPath=/path/to/certs/workers.pem&tls.caPath=/path/to/certs/root.pem&tls.requestCert=true&tls.rejectUnauthorized=true"Once you’ve set this variable, restart the Worker Node. You should see the Worker Node successfully reconnect to the Leader.
If the Worker Node doesn’t connect, check cribl.log on both the Worker Node and Leader for more context about the problem. You should see errors related to dist leader communications.
To build your own Certificate Authority (a self-signed CA), see our blog post on How to Secure Cribl Stream Worker-to-Leader Communications.