Experimental configuration settings#
Both self-hosted and Cloud admins can access the following configuration settings in the System Console. Self-hosted admins can also edit the config.json
file as described in the following tables.
Experimental System Console configuration settings#
Available on all plans
Cloud and self-hosted deployments
Access the following experimental configuration settings in the System Console by going to Experimental > Features.
Change authentication method#
Note
Available only on Enterprise and Professional plans
True: Users can change their sign-in method to any that is enabled on the server, either via their Profile or the APIs.
False: Users cannot change their sign-in method, regardless of which authentication options are enabled.
This feature’s |
Link metadata timeout#
Adds a configurable timeout for requests made to return link metadata. If the metadata is not returned before this timeout expires, the message will post without requiring metadata. This timeout covers the failure cases of broken URLs and bad content types on slow network connections.
This feature’s |
Email batching buffer size#
Specify the maximum number of notifications batched into a single email.
Note
We recommend increasing the buffer size from the default value if you see the following error in the Mattermost logs:
Email batching job's receiving buffer was full. Please increase the EmailBatchingBufferSize. Falling back to sending immediate mail.
Increasing this value will ensure emails are queued up, without impacting server performance.Notifications will be sent instantly if the queue of emails exceeds the email batching interval configured.
This feature’s |
Email batching interval#
Specify the maximum frequency, in seconds, which the batching job checks for new notifications.
Note
We recommend decreasing the email batching interval from the default value if you see the following error in the Mattermost logs:
Email batching job's receiving buffer was full. Please increase the EmailBatchingBufferSize. Falling back to sending immediate mail.
.Longer batching intervals may increase performance.
Notifications will be sent instantly if the queue of emails exceeds the email batching interval configured.
This feature’s |
Enable account deactivation#
True: Ability for users to deactivate their own account from Settings > Advanced > Deactivate Account. If a user deactivates their own account, they will get an email notification confirming they were deactivated. Available only when authentication is set to use email/password. Not available when authentication uses SAML or AD/LDAP.
False: Ability for users to deactivate their own account is disabled.
This feature’s |
Enable automatic replies#
True: Users can enable Automatic Replies in Settings > Notifications. Users set a custom message that will be automatically sent in response to Direct Messages.
False: Disables the Automatic Direct Message Replies feature and hides it from Settings.
This feature’s |
Enable channel viewed websocket messages#
This setting determines whether channel_viewed WebSocket
events are sent, which synchronize unread notifications across clients and devices. Disabling the setting in larger deployments may improve server performance.
This feature’s |
Enable default channel leave/join system messages#
This setting determines whether team leave/join system messages are posted in the default town-square
channel.
True: Enables leave/join system messages in the default town-square
channel.
False: Disables leave/join messages from the default town-square
channel. These system messages won’t be added to the database either.
This feature’s |
Enable hardened mode#
True: Enables a hardened mode for Mattermost that makes user experience trade-offs in the interest of security.
False: Disables hardened mode.
Changes made when hardened mode is enabled:
Failed login returns a generic error message instead of a specific message for username and password.
If multi-factor authentication (MFA) is enabled, the route to check if a user has MFA enabled always returns true. This causes the MFA input screen to appear even if the user does not have MFA enabled. The user may enter any value to pass the screen. Note that hardened mode does not affect user experience when MFA is enforced.
Password reset does not inform the user that they can not reset their SSO account through Mattermost and instead claims to have sent the password reset email.
Mattermost sanitizes all 500 errors before returned to the client. Use the supplied
request_id
to match user facing errors with the server logs.Standard users authenticated via username and password can’t use post props reserved for integrations, such as
override_username
oroverride_icon_url
.
This feature’s |
Enable theme selection#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E10 or E20
True: Enables the Display > Theme tab in Settings so users can select their theme.
False: Users cannot select a different theme. The Display > Theme tab is hidden in Settings.
This feature’s |
Allow custom themes#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E10 or E20
True: Enables the Display > Theme > Custom Theme section in Settings.
False: Users cannot use a custom theme. The Display > Theme > Custom Theme section is hidden in Settings.
This feature’s |
Default theme#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E10 or E20
Set a default theme that applies to all new users on the system.
This feature’s |
Enable tutorial#
True: Users are prompted with a tutorial when they open Mattermost for the first time after account creation.
False: The tutorial is disabled. Users are placed in Town Square when they open Mattermost for the first time after account creation.
This feature’s |
Enable onboarding flow#
True: New Mattermost users are shown key tasks to complete as part of initial onboarding.
False: User onboarding tasks are disabled. Users are placed in Town Square when they open Mattermost for the first time after account creation.
This feature’s |
Enable user typing messages#
This setting determines whether “user is typing…” messages are displayed below the message box. Disabling the setting in larger deployments may improve server performance.
This feature’s |
User typing timeout#
This setting defines how frequently “user is typing…” messages are updated, measured in milliseconds.
This feature’s |
User’s status and profile fetching poll interval#
This setting configures the number of milliseconds to wait between fetching user statuses and profiles periodically. Set to 0
to disable.
This feature’s |
Primary team#
The primary team of which users on the server are members. When a primary team is set, the options to join other teams or leave the primary team are disabled.
If the team URL of the primary team is https://example.mattermost.com/myteam/
, then set the value to myteam
in config.json
.
This feature’s |
Use channel name in email notifications#
True: Channel and team name appears in email notification subject lines. Useful for servers using only one team.
False: Only team name appears in email notification subject line.
This feature’s |
User status away timeout#
This setting defines the number of seconds after which the user’s status indicator changes to “Away”, when they are away from Mattermost.
This feature’s |
Disable data refetching on browser refocus#
This setting disables re-fetching of channel and channel members on browser focus.
True: Mattermost won’t refetch channels and channel members when the browser regains focus. This may result in improved performance for users with many channels and channel members.
False: (Default) Mattermost will refetch channels and channel members when the browser regains focus.
This feature’s |
Disable wake up reconnect handler#
This setting disables attempts to detect when the computer has woken up and refetch data.
True: Mattermost won’t attempt to detect when the computer has woken up and refetch data. This might reduce the amount of regular network traffic the app is sending.
False: (Default) Mattermost attempts to detect when the computer has woken up and refreshes data.
This feature’s |
Delay channel autocomplete#
This setting controls whether or not the channel link autocomplete triggers immediately when after a tilde is typed when composing a message. This setting makes the channel autocomplete, such as ~town-square
, less obtrusive for people who use tildes ~
as punctuation.
True: The autocomplete appears after the user types a tilde followed by two or more characters. For example, typing ~to
will show the autocomplete, but typing ~
will not.
False: (Default) The autocomplete appears immediately after the user types a tilde. For example, typing ~
will show the autocomplete.
This feature’s |
Enable dedicated export filestore target#
This setting enables you to specify an alternate filestore target for Mattermost bulk exports and compliance exports.
True: A new ExportFileBackend()
is generated under FileSettings
using new configuration values for the following configuration settings:
ExportDriverName
ExportDirectory
ExportAmazonS3AccessKeyId
ExportAmazonS3SecretAccessKey
ExportAmazonS3Bucket
ExportAmazonS3PathPrefix
ExportAmazonS3Region
ExportAmazonS3Endpoint
ExportAmazonS3SSL
ExportAmazonS3SignV2
ExportAmazonS3SSE
ExportAmazonS3Trace
ExportAmazonS3RequestTimeoutMilliseconds
ExportAmazonS3PresignExpiresSeconds
False: Standard file storage is used (or when the configuration setting is omitted).
When an alternate filestore target is configured, Mattermost Cloud admins can generate an S3 presigned URL for exports using the /exportlink [job-id|zip file|latest]
slash command. See the Mattermost workspace migration documentation for details. Alternatively, Cloud and self-hosted admins can use the mmctl export generate-presigned-url command to generate a presigned URL directly from mmctl.
Note
Generating an S3 presigned URL requires the feature flag EnableExportDirectDownload
to be set to true
, the storage must be compatible with generating an S3 link, and this experimental configuration setting must be set to true
. Presigned URLs for exports aren’t supported for systems with shared storage.
This feature’s |
Experimental Bleve configuration settings#
Available on all plans
self-hosted deployments
Access the following configuration settings in the System Console by going to Experimental > Bleve, or by editing the config.json
file as described in the following tables:
Enable Bleve indexing#
True: The indexing of new posts occurs automatically. Search queries will not use bleve search until Enable Bleve for search queries is enabled.
False: The indexing of new posts does not occur automatically.
This feature’s |
Index directory#
Directory path to use for storing bleve indexes.
Tip
The bleve index directory path isn’t required to exist within the mattermost
directory. When it exists outside of the mattermost
directory, no additional steps are needed to preserve or reindex these files as part of a Mattermost upgrade. See our Upgrading Mattermost Server documentation for details.
This feature’s |
Bulk index now#
Select Index Now to index all users, channels, and posts in the database from oldest to newest. Bleve is available during indexing, but search results may be incomplete until the indexing job is complete.
Purge indexes#
Select Purge Index to remove the contents of the Bleve index directory. Search results may be incomplete until a bulk index of the existing database is rebuilt.
Enable Bleve for search queries#
True: Search queries will use bleve search.
False: Search queries will not use bleve search.
This feature’s |
Enable Bleve for autocomplete queries#
True: Autocomplete queries will use bleve search.
False: Autocomplete queries will not use bleve search.
This feature’s |
Experimental audit logging configuration settings (Beta)#
Enable the following settings to output audit events in the System Console by going to Experimental > Features, or in the config.json
file.
Note
The ability to configure audit logging in the System Console requires the feature flag ExperimentalAuditSettingsSystemConsoleUI
to be set to true
.
Advanced logging#
Available only on Enterprise plans
Available only for Cloud deployments
Output log and audit records to any combination of console, local file, syslog, and TCP socket targets for a Mattermost Cloud deployment. See the advanced logging documentation for details about logging options.
Enable audit logging#
Available on Enterprise plans
Cloud and self-hosted deployments
When audit logging is enabled in a self-hosted instance, you can specify size, backup interval, compression, maximium age to manage file rotation, and timestamps for audit logging, as defined below. You can specify these settings independently for audit events and AD/LDAP events.
True: Audit logging files are enabled, and audit files are written locally to a file for a self-hosted deployment.
False: Audit logging files aren’t enabled, and audit logs aren’t written locally to a file for a self-hosted deployment.
This feature’s |
File name#
Available on Enterprise plans
self-hosted deployments
Specify the path to the audit file for a self-hosted deployment.
This feature’s |
Max file size#
Available on Enterprise plans
self-hosted deployments
This is the maximum size, in megabytes, that the file can grow before triggering rotation for a self-hosted deployment. The default setting is 100
.
This feature’s |
Max file age#
Available on Enterprise plans
self-hosted deployments
This is the maximum age, in days, a file can reach before triggering rotation for a self-hosted deployment. The default value is 0
, indicating no limit on the age.
This feature’s |
Maximum file backups#
Available on Enterprise plans
self-hosted deployments
This is the maximum number of rotated files kept for a self-hosted deployment. The oldest is deleted first. The default value is 0
, indicating no limit on the number of backups.
This feature’s |
File compression#
Available on Enterprise plans
self-hosted deployments
When true
, rotated files are compressed using gzip
in a self-hosted deployment.
This feature’s |
Maximum file queue#
Available on Enterprise plans
self-hosted deployments
This setting determines how many audit records can be queued/buffered at any point in time when writing to a file for a self-hosted deployment. The default is 1000
records.
This setting can be left as default unless you are seeing audit write failures in the server log and need to adjust the number accordingly.
This feature’s |
Advanced logging#
Available on Enterprise plans
self-hosted deployments
Output log and audit records to any combination of console, local file, syslog, and TCP socket targets for a Mattermost self-hosted deployment. See the advanced logging documentation for details about logging options.
Experimental configuration settings for self-hosted deployments only#
Available on all plans
self-hosted deployments
Access the following self-hosted configuration settings by editing the config.json
file as described in the following tables. These configuration settings are not accessible through the System Console.
Tip
Each configuration value below includes a JSON path to access the value programmatically in the config.json
file using a JSON-aware tool. For example, the SiteURL
value is under ServiceSettings
.
If using a tool such as jq, you’d enter:
cat config/config.json | jq '.ServiceSettings.SiteURL'
When working with the
config.json
file manually, look for the keyServiceSettings
, then within that object, find the keySiteURL
.
Allowed themes#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E10 or E20
This setting isn’t available in the System Console and can only be set in config.json
.
Select the themes that can be chosen by users when EnableThemeSelection
is set to true
.
This feature’s |
Maximum users for statistics#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E10 or E20
This setting isn’t available in the System Console and can only be set in config.json
.
Sets the maximum number of users on the server before statistics for total posts, total hashtag posts, total file posts, posts per day, and activated users with posts per day are disabled.
This setting is used to maximize performance for large Enterprise deployments.
This feature’s |
Latest Android version#
This setting isn’t available in the System Console and can only be set in config.json
.
The latest version of the Android React Native app that is recommended for use.
This feature’s |
Minimum Android version#
This setting isn’t available in the System Console and can only be set in config.json
.
The minimum version of the Android React Native app that is required to be used.
This feature’s |
Latest iOS version#
This setting isn’t available in the System Console and can only be set in config.json
.
The latest version of the iOS app that is recommended for use.
This feature’s |
Minimum iOS version#
This setting isn’t available in the System Console and can only be set in config.json
.
The minimum version of the iOS React Native app that is required to be used.
This feature’s |
Batch size#
Note
Available only on Enterprise plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Determines how many new posts are batched together to a compliance export file.
This feature’s |
File Location#
Note
Available only on Enterprise plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Set the file location of the compliance exports. By default, they are written to the exports
subdirectory of the configured Local Storage directory.
This feature’s |
Push notification buffer#
This setting isn’t available in the System Console and can only be set in config.json
.
Used to control the buffer of outstanding Push Notification messages to be sent. If the number of messages exceeds that number, then the request making the Push Notification will be blocked until there’s room.
This feature’s |
Restrict system admin#
This setting isn’t available in the System Console and can only be set in config.json
.
True: (Default for Cloud deployments) Restricts the system admin from viewing and modifying a subset of server configuration settings from the System Console. Not recommended for use in on-prem installations. This is intended to support Mattermost Private Cloud in giving the system admin role to users but restricting certain actions only for Cloud Admins.
False: (Default for self-host deployments) No restrictions are applied to the system admin role.
This feature’s |
Remote clusters#
Note
Available only on Enterprise plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Enable this setting to add, remove, and view remote clusters for shared channels.
True: System admins can manage remote clusters using the System Console.
False: Remote cluster management is disabled.
This feature’s |
Enable client-side certification#
Note
Available only on Enterprise plans
Also available in legacy Mattermost Enterprise Edition E20
True: Enables client-side certification for your Mattermost server. See the documentation to learn more.
False: Client-side certification is disabled.
This feature’s |
Client-side certification login method#
Note
Available only on Enterprise plans
Also available in legacy Mattermost Enterprise Edition E20
Used in combination with the ClientSideCertEnable
configuration setting.
Primary: After the client side certificate is verified, user’s email is retrieved from the certificate and is used to log in without a password.
Secondary: After the client side certificate is verified, user’s email is retrieved from the certificate and matched against the one supplied by the user. If they match, the user logs in with regular email/password credentials.
This feature’s |
Export output directory#
This setting isn’t available in the System Console and can only be set in config.json
.
The directory where the exported files are stored. The path is relative to the FileSettings
directory. By default, exports are stored under ./data/export
.
This feature’s |
Export retention days#
This setting isn’t available in the System Console and can only be set in config.json
.
The number of days to retain the exported files before deleting them.
This feature’s |
Maximum image resolution#
This setting isn’t available in the System Console and can only be set in config.json
.
Maximum image resolution size for message attachments in pixels.
This feature’s |
Maximum image decoder concurrency#
This setting isn’t available in the System Console and can only be set in config.json
.
Indicates how many images can be decoded concurrently at once. The default value of -1
configures Mattermost to automatically use the number of CPUs present.
Note
This configuration setting affects the total memory consumption of the server. The maximum memory of a single image is dictated by
MaxImageResolution * 24 bytes
, where the default maximum image resolution value is 33MB.Therefore, a good rule of thumb to follow is that
33MB * MaxImageDecoderConcurrency * 24
should be less than the total memory for the server.For example, if you have a 4-core server, you should leave aside at least
33 * 4 * 24 = 3168MB
memory for image processing. Otherwise, adjust the MaxImageResolution configuration setting to adjust the amount of memory needed for image processing.
This feature’s |
Initial font#
This setting isn’t available in the System Console and can only be set in config.json
.
Font used in auto-generated profile pics with colored backgrounds.
This feature’s |
Amazon S3 signature v2#
This setting isn’t available in the System Console and can only be set in config.json
.
By default, Mattermost uses Signature V4 to sign API calls to AWS, but under some circumstances, V2 is required. For more information about when to use V2, see https://docs.aws.amazon.com/general/latest/gr/signature-version-2.html.
True: Use Signature Version 2 Signing Process.
False: Use Signature Version 4 Signing Process.
This feature’s |
Amazon S3 path#
This setting isn’t available in the System Console and can only be set in config.json
.
Allows using the same S3 bucket for multiple deployments.
This feature’s |
GitLab scope#
This setting isn’t available in the System Console and can only be set in config.json
.
Standard setting for OAuth to determine the scope of information shared with OAuth client. Not currently supported by GitLab OAuth.
This feature’s |
Global relay SMTP server timeout#
Note
Available only on Enterprise plans
Available as an add-on to legacy Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
The number of seconds that can elapse before the connection attempt to the SMTP server is abandoned. The default value is 1800 seconds. This setting is currently not available in the System Console and can only be set in config.json
.
This feature’s |
Google scope#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Standard setting for OAuth to determine the scope of information shared with OAuth client. Recommended setting is profile email
.
This feature’s |
Import input directory#
This setting isn’t available in the System Console and can only be set in config.json
.
The directory where the imported files are stored. The path is relative to the FileSettings
directory. By default, imports are stored under ./data/import
.
This feature’s |
Import retention days#
This setting isn’t available in the System Console and can only be set in config.json
.
The number of days to retain the imported files before deleting them.
This feature’s |
Export from timestamp#
Note
Available only on Enterprise plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Set the Unix timestamp (seconds since epoch, UTC) to export data from.
This feature’s |
Block profile rate#
This setting isn’t available in the System Console and can only be set in config.json
. Changes to this setting require a server restart before taking effect.
Value that controls the fraction of goroutine blocking events reported in the blocking profile.
The profiler aims to sample an average of one blocking event per rate nanoseconds spent blocked.
To include every blocking event in the profile, set the rate to 1
. To turn off profiling entirely, set the rate to 0
.
This feature’s |
App custom URL schemes#
This setting isn’t available in the System Console and can only be set in config.json
.
Define valid custom URL schemes for redirect links provided by custom-built mobile Mattermost apps. This ensures users are redirected to the custom-built mobile app and not Mattermost’s mobile client.
When configured, after OAuth or SAML user authentication is complete, custom URL schemes sent by mobile clients are validated to ensure they don’t include default schemes such as http
or https
. Mobile users are then redirected back to the mobile app using the custom scheme URL provided by the mobile client. We recommend that you update your mobile client values as well with valid custom URL schemes.
This feature’s |
Entra ID Scope#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Standard setting for OAuth to determine the scope of information shared with OAuth client. Recommended setting is User.Read
.
This feature’s |
Enable plugin uploads#
This setting isn’t available in the System Console and can only be set in config.json
.
True: Enables plugin uploads by system admins at Plugins > Management. If you do not plan to upload a plugin, set to false
to control which plugins are installed on your server. See documentation to learn more.
False: Disables plugin uploads on your Mattermost server.
This feature’s |
Allow insecure download URL#
This setting isn’t available in the System Console and can only be set in config.json
.
True: Enables downloading and installing a plugin from a remote URL.
False: Disables downloading and installing a plugin from a remote URL.
This feature’s |
Enable plugin health check#
This setting isn’t available in the System Console and can only be set in config.json
.
True: Enables plugin health check to ensure all plugins are periodically monitored, and restarted or deactivated based on their health status. The health check runs every 30 seconds. If the plugin is detected to fail 3 times within an hour, the Mattermost server attempts to restart it. If the restart fails 3 successive times, it’s automatically disabled.
False: Disables plugin health check on your Mattermost server.
This feature’s |
Plugin directory#
This setting isn’t available in the System Console and can only be set in config.json
.
The location of the plugin files. If blank, they are stored in the ./plugins
directory. The path that you set must exist and Mattermost must have write permissions in it.
This feature’s |
Client plugin directory#
This setting isn’t available in the System Console and can only be set in config.json
.
The location of client plugin files. If blank, they are stored in the ./client/plugins
directory. The path that you set must exist and Mattermost must have write permissions in it.
This feature’s |
Scoping IDP provider ID#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Allows an authenticated user to skip the initial login page of their federated Azure AD server, and only require a password to log in.
This feature’s |
Scoping IDP provider name#
Note
Available only on Enterprise and Professional plans
Also available in legacy Mattermost Enterprise Edition E20
This setting isn’t available in the System Console and can only be set in config.json
.
Adds the name associated with a user’s Scoping Identity Provider ID.
This feature’s |
Group unread channels#
This setting isn’t available in the System Console and can only be set in config.json
.
This setting applies to the new sidebar only. You must disable the Enable Legacy Sidebar configuration setting to see and enable this functionality in the System Console.
Default Off: Disables the unread channels sidebar section for all users by default. Users can enable it in Settings > Sidebar > Group unread channels separately.
Default On: Enables the unread channels sidebar section for all users by default. Users can disable it in Settings > Sidebar > Group unread channels separately.
This feature’s |
Strict CSRF token enforcement#
This setting isn’t available in the System Console and can only be set in config.json
.
True: Enables CSRF protection tokens for additional hardening compared to the currently used custom header. When the user logs in, an additional cookie is created with the CSRF token contained.
False: Disables CSRF protection tokens.
This feature’s |
Developer flags#
This setting isn’t available in the System Console and can only be set in config.json
.
This configuration setting specifies a list of strings where each string is a flag used to set the content security policy (CSP) for the Mattermost Web App. Each flag must be in the format flag=true
(e.g. unsafe-eval=true,unsafe-inline=true
). Not recommended for production environments.
The following values are currently supported:
unsafe-eval
: Adds theunsafe-eval
CSP directive to the root webapp, allowing increased debugging in developer environments.unsafe-inline
: Adds theunsafe-inline
CSP directive to the root webapp, allowing increased debugging in developer environments.
This configuration setting is disabled by default and requires developer mode to be enabled.
This feature’s |
Enable post search#
This setting isn’t available in the System Console and can only be set in config.json
.
If this setting is enabled, users can search messages. Disabling search can result in a performance increase, but users get an error message when they attempt to use the search box.
This feature’s |
Enable file search#
This setting isn’t available in the System Console and can only be set in config.json
.
This configuration setting enables users to search documents attached to messages by filename. To enable users to search documents by their content, you must also enable the ExtractContent
configuration setting. See our Enable Document Search by Content documentation for details. Document content search is available in Mattermost Server from v5.35, with mobile support coming soon.
True: Supported document types are searchable by their filename.
False: File-based searches are disabled.
This feature’s |
Enable user status updates#
This setting isn’t available in the System Console and can only be set in config.json
.
Turn status updates off to improve performance. When status updates are off, users appear online only for brief periods when posting a message, and only to members of the channel in which the message is posted.
This feature’s |
Websocket secure port#
This setting isn’t available in the System Console and can only be set in config.json
. Changes to this setting require a server restart before taking effect.
(Optional) This setting defines the port on which the secured WebSocket is listening using the wss
protocol. Defaults to 443
. When the client attempts to make a WebSocket connection it first checks to see if the page is loaded with HTTPS. If so, it will use the secure WebSocket connection. If not, it will use the unsecure WebSocket connection. IT IS HIGHLY RECOMMENDED PRODUCTION DEPLOYMENTS ONLY OPERATE UNDER HTTPS AND WSS.
This feature’s |
Note
This is a client only override that doesn’t affect the listening port of the server process which is controlled by the Web server listen address setting.
Websocket port#
This setting isn’t available in the System Console and can only be set in config.json
. Changes to this setting require a server restart before taking effect.
(Optional) This setting defines the port on which the unsecured WebSocket is listening using the ws
protocol. Defaults to 80
. When the client attempts to make a WebSocket connection it first checks to see if the page is loaded with HTTPS. If so, it will use the secure WebSocket connection. If not, it will use the unsecure WebSocket connection. IT IS HIGHLY RECOMMENDED PRODUCTION DEPLOYMENTS ONLY OPERATE UNDER HTTPS AND WSS.
This feature’s |
Note
This is a client only override that doesn’t affect the listening port of the server process which is controlled by the Web server listen address setting.
Enable OpenTracing#
This setting isn’t available in the System Console and can only be set in config.json
.
True: A Jaeger client is instantiated and is used to trace each HTTP request as it goes through App and Store layers. Context is added to App and Store and is passed down the layer chain to create OpenTracing ‘spans’.
By default, in order to avoid leaking sensitive information, no method parameters are reported to OpenTracing. Only the name of the method is reported.
False: OpenTracing is not enabled.
This feature’s |
Enable local mode for mmctl#
This setting isn’t available in the System Console and can only be set in config.json
.
True: Enables local mode for mmctl.
False: Prevents local mode for mmctl.
This feature’s |
Tip
When trying to use local mode with mmctl, ensure you’re using the same user when running the server and mmctl, or clean up the socket file before switching to a new user. If you encounter an error like socket file "/var/tmp/mattermost_local.socket" doesn't exists, please check the server configuration for local mode
, this can be resolved by setting this configuration setting to true
.
Enable local mode socket location#
This setting isn’t available in the System Console and can only be set in config.json
.
The path for the socket that the server will create for mmctl to connect and communicate through local mode. If the default value for this key is changed, you will need to point mmctl to the new socket path when in local mode, using the --local-socket-path /new/path/to/socket
flag in addition to the --local
flag.
If nothing is specified, the default path that both the server and mmctl assumes is /var/tmp/mattermost_local.socket
.
This feature’s |
Default channels#
This setting isn’t available in the System Console and can only be set in config.json
.
Default channels every user is added to automatically after joining a new team. Only applies to Public channels, but affects all teams on the server.
When not set, every user is added to the off-topic
and town-square
channels by default.
Note
Even if town-square
and off-topic
aren’t listed, every user is added to these channels automatically when joining a new team.
This feature’s |
Experimental job configuration settings#
Available on all plans
self-hosted deployments
Settings to configure how Mattermost schedules and completes periodic tasks such as the deletion of old posts with Data Retention enabled or indexing posts with Elasticsearch. These settings control which Mattermost servers are designated as a Scheduler, a server that queues the tasks at the correct times, and as a Worker, a server that completes the given tasks.
When running Mattermost on a single machine, both RunJobs
and RunScheduler
should be enabled. Without both of these enabled, Mattermost will not function properly.
When running Mattermost in High Availability mode, RunJobs
should be enabled on one or more servers while RunScheduler
should be enabled on all servers under normal circumstances. A High Availability cluster-based deployment will have one Scheduler and one or more Workers. See the below sections for more information.
Run jobs#
This setting isn’t available in the System Console and can only be set in config.json
.
Set whether or not this Mattermost server will handle tasks created by the Scheduler. When running Mattermost on a single machine, this setting should always be enabled.
When running Mattermost in High Availablity mode, one or more servers should have this setting enabled. We recommend that your High Availability cluster-based deployment has one or more dedicated Workers with this setting enabled while the remaining Mattermost app servers have it disabled.
This feature’s |
Run scheduler#
This setting isn’t available in the System Console and can only be set in config.json
.
Set whether or not this Mattermost server will schedule tasks that will be completed by a Worker. When running Mattermost on a single machine, this setting should always be enabled.
When running Mattermost in High Availablity mode, this setting should always be enabled. In a High Availability cluster-based deployment, exactly one of the servers will be designated as the Scheduler at a time to ensure that duplicate tasks aren’t created. See High Availability documentation for more details.
Warning
We strongly recommend that you not change this setting from the default setting of true
as this prevents the ClusterLeader
from being able to run the scheduler. As a result, recurring jobs such as LDAP sync, Compliance Export, and data retention will no longer be scheduled. In previous Mattermost Server versions, and this documentation, the instructions stated to run the Job Server with RunScheduler: false
. The cluster design has evolved and this is no longer the case.
This feature’s |
Clean up old database jobs#
This setting isn’t available in the System Console and can only be set in config.json
.
Defines the threshold in days beyond which older completed database jobs are removed. This setting is disabled by default, and must be set to a value greater than or equal to 0
to be enabled.
This feature’s |
Clean up outdated database entries#
This setting only applies to configuration in the database. It isn’t available in the System Console and can be set via mmctl or changed in the database.
Defines the threshold in days beyond which outdated configurations are removed from the database.
This feature’s |