New in version 4.4: MongoDB Enterprise
Synopsis
Starting in version 4.4, MongoDB Enterprise provides
mongokerberos for testing MongoDB's Kerberos and GSSAPI
configuration options against a
running Kerberos deployment. mongokerberos can be used
in one of two modes: server and client.
| Mode | Description | 
|---|---|
| Server | In server mode,  | 
| Client | In client mode,  | 
Error messages for both modes include information on specific errors encountered and potential advice for resolving the error.
mongokerberos supports the following deployment types,
in both server and client modes:
- Linux MongoDB clients authenticating to MIT Kerberos deployments on supported Linux platforms. 
- Windows MongoDB clients authenticating to Windows Active Directory deployments on supported Windows platforms. 
- Linux MongoDB clients authenticating to Windows Active Directory deployments. 
Note
MongoDB Enterprise and mongokerberos only support the
MIT implementation
of Kerberos.
Generally, when configuring options related to
Kerberos authentication, it is good practice
to verify your configuration with mongokerberos.
mongokerberos is a testing and verification tool; it does not
edit any files or configure any services. For configuring Kerberos on
your platform please consult the MIT Kerberos documentation, or your platform's
documentation. For configuring MongoDB to authenticate using Kerberos,
please reference the following tutorials:
This document provides a complete overview of all command line options
for mongokerberos.
Installation
The mongokerberos tool is part of the MongoDB Database Tools Extra
package, and can be installed with the MongoDB Server or as a
standalone installation.
Install with Server
To install mongokerberos as part of a MongoDB Enterprise Server
installation:
- Follow the instructions for your platform: Install MongoDB Enterprise Server 
- After completing the installation, - mongokerberosand the other included tools are available in the same location as the Server.- Note- For the Windows - .msiinstaller wizard, the Complete installation option includes- mongokerberos.
Install as Standalone
To install mongokerberos as a standalone installation:
- Follow the download link for MongoDB Enterprise Edition: MongoDB Enterprise Download Center 
- Select your Platform (operating system) from the dropdown menu, then select the appropriate Package for your platform according to the following chart: OSPackage- Linux - tgzpackage- Windows - zippackage- macOS - tgzpackage
- Once downloaded, unpack the archive and copy - mongokerberosto a location on your hard drive.- Tip- Linux and macOS users may wish to copy - mongokerberosto a filesystem location that is defined in the- $PATHenvironment variable, such as- /usr/bin. Doing so allows referencing- mongokerberosdirectly on the command line by name, without needing to specify its full path, or first navigating to its parent directory. See the installation guide for your platform for more information.
Usage
mongokerberos can be run in two modes: server and
client.
Run mongokerberos from the system command line, not the mongo shell.
Server Mode
Running mongokerberos in server mode performs a series of
verification steps against your system's Kerberos configuration,
including checking for proper DNS resolution, validation of the Kerberos
system keytab file, and testing against the MongoDB service principal
for your mongod or mongos instance.
Before you can use mongokerberos in server mode, you must:
- Configure Kerberos on your platform according to your platform's documentation. 
- Create the MongoDB service principal for use with your - mongodor- mongosinstance, as described in the following steps:
Once you have completed these steps, you can run
mongokerberos in server mode using the
--server flag as follows:
mongokerberos --server 
If Kerberos has been configured properly on the server, and the service principal created successfully, the output might resemble the following:
Resolving kerberos environment... [OK] Kerberos environment resolved without errors. Verifying DNS resolution works with Kerberos service at <hostname>... [OK] DNS test successful. Getting MIT Kerberos KRB5 environment variables...   * KRB5CCNAME: not set.   * KRB5_CLIENT_KTNAME: not set.   * KRB5_CONFIG: not set.   * KRB5_KTNAME: not set.   * KRB5_TRACE: not set. [OK] Verifying existence of KRB5 keytab FILE:/etc/krb5.keytab... [OK] KRB5 keytab exists and is populated. Checking principal(s) in KRB5 keytab... Found the following principals for MongoDB service mongodb:   * mongodb/server.example.com@SERVER.EXAMPLE.COM Found the following kvnos in keytab entries for service mongodb:   * 3 [OK] KRB5 keytab is valid. Fetching KRB5 Config... KRB5 config profile resolved as:    <Your Kerberos profile file will be output here> [OK] KRB5 config profile resolved without errors. Attempting to initiate security context with service credentials... [OK] Security context initiated successfully. 
The final message indicates that the system's Kerberos configuration is ready to be used with MongoDB. If any errors are encountered with the configuration, they will be presented as part of the above output.
Client Mode
Running mongokerberos in client mode tests authentication
against your system's Kerberos environment, performing each step in the
Kerberos authentication process, including checking for proper DNS
resolution, verification of the Kerberos client keytab file, and testing
whether a ticket can be successfully granted. Running
mongokerberos in client mode simulates the client
authentication procedure of the mongo shell.
Before you can use mongokerberos in client mode, you must
first have configured Kerberos on your platform according to your
platform's documentation. Optionally, you may also choose to run
mongokerberos in
server mode first to verify that your
platform's Kerberos configuration is valid before using client mode.
Once you have completed these steps, you can run
mongokerberos in client mode to test user authentication,
using the --client flag as follows:
mongokerberos --client --username <username> 
You must provide a valid username, which is used to request a Kerberos ticket as part of the authentication procedure. Your platform's Kerberos infrastructure must be aware of this user.
If the provided credentials are valid, and the Kerberos options in the configuration files are valid, the output might resemble the following:
 Resolving kerberos environment...  [OK] Kerberos environment resolved without errors.  Verifying DNS resolution works with Kerberos service at <hostname>...  [OK] DNS test successful.  Getting MIT Kerberos KRB5 environment variables...    * KRB5CCNAME: not set.    * KRB5_CLIENT_KTNAME: not set.    * KRB5_CONFIG: not set.    * KRB5_KTNAME: not set.    * KRB5_TRACE: not set.  [OK]  Verifying existence of KRB5 client keytab FILE:/path/to/client.keytab...  [OK] KRB5 client keytab exists and is populated.  Checking principal(s) in KRB5 keytab...  [OK] KRB5 keytab is valid.  Fetching KRB5 Config...  KRB5 config profile resolved as:     <Your Kerberos profile file will be output here>  [OK] KRB5 config profile resolved without errors.  Attempting client half of GSSAPI conversation...  [OK] Client half of GSSAPI conversation completed successfully. 
The final message indicates that client authentication completed successfully for the user provided. If any errors are encountered during the authentication steps, they will be presented as part of the above output.
Options
- --server
- Runs - mongokerberosin server mode to test that your platform's Kerberos configuration is valid for use with MongoDB.- See Server Mode for example usage and expected output. 
- --client
- Runs - mongokerberosin client mode to test client authentication against your system's Kerberos environment. Requires specifying a valid username with- --usernamewhen running in client mode.- mongokerberoswill request a Kerberos ticket for this username as part of the validation procedure. Running- mongokerberosin client mode simulates the client authentication procedure of the- mongoshell.- See Client Mode for example usage and expected output. 
- --config <filename>, -f <filename>
- Specifies a configuration file for runtime configuration options. The options are equivalent to the command-line configuration options. See Configuration File Options for more information. - mongokerberoswill read the values for- saslHostNameand- saslServiceNamefrom this file if present. These values can alteratively be specified with the- --setParameteroption instead.- Ensure the configuration file uses ASCII encoding. The - mongokerberosinstance does not support configuration files with non-ASCII encoding, including UTF-8.- Only valid in server mode. 
- --setParameter <options>
- Sets a configurable parameter. You can specify multiple - setParameterfields.- While you can use any supported parameters with - setParameter,- mongokerberosonly checks for the value of the following:- If using the - --configoption with a configuration file that also contains these values, the- setParametervalues will override the values from the configuration file.- Valid in both server mode and client mode. 
- --host <hostname>
- Specify the hostname of the MongoDB server to connect to when testing authentication. - If - --hostis not specified,- mongokerberosdoes not perform any DNS validation of the hostname (i.e. PTR record verification)- Only valid in client mode. 
- --username <username>, -u <username>
- Username for - mongokerberosto use when attempting Kerberos authentication. This value is required when running in client mode.- Only valid in client mode. 
- --gssapiServiceName <servicename>
- default: 'mongodb' - Service principal name to use when authenticating using GSSAPI/Kerberos. - Only valid in client mode. 
- --gssapiHostName <hostname>
- Remote hostname to use for purpose of GSSAPI/Kerberos authentication. - Only valid in client mode.