Specifying Jahia properties
October 8, 2024
Jahia features and services can be configured in the jahia.properties
file or in OSGi configuration files. Clustering settings can be specified in the jahia.node.properties
file. The jahia.properties
file and the jahia.node.properties
file are located in the digital-factory-config/jahia
directory. OSGi configuration files are located in the digital-factory-data/karaf/etc
directory.
Jahia property descriptions
The following tables shows properties that you can add or modify in the jahia.properties
file.
Jahia modes
Property name |
Description |
Default value |
operatingMode |
Specifies a mode, either development , production , or distantPublicationServer |
development |
maintenanceMode |
Enables maintenance mode, where no requests are served except to /tools/. For more information, see Enabling system maintenance and read-only modes. |
false |
readOnlyMode |
Enables read-only mode and disables access to Page Composer, Content Editor, Studio, and administration modes. For more information, see Enabling system maintenance and read-only modes. |
false |
sessionExpiryTime |
Sets the session lifetime in minutes |
60 |
Disk paths
Configures where Jahia stores runtime data on disk, such repository, modules, temporary files
Property name |
Description |
Default value |
jahiaVarDiskPath |
Defines the main location of runtime data. If the jahia.data.dir system property is not set, this value is used for that setting. Otherwise, this value is ignored. |
${jahiaWebAppRoot}/../../../digital-factory-data |
tmpContentDiskPath |
Defines the location of temporary files |
${jahia.data.dir}/content/tmp/ |
jahiaModulesDiskPath |
Defines the location of modules |
${jahia.data.dir}/modules/ |
jahiaImportsDiskPath |
Defines the location of imported files |
${jahia.data.dir}/imports/ |
modulesSourcesDiskPath |
Defines the location of modules sources |
${jahia.data.dir}/sources/ |
jahiaGeneratedResourcesDiskPath |
Defines where dynamically generated resources like aggregated CSS and JS files are stored. Unlike other DiskPath parameters, when running a Jahia cluster, it must reference a directory shared between cluster nodes. See Configuring Jahia features for more details. |
${jahia.data.dir}/generated-resources/ |
jahia.jackrabbit.home |
JCR repository home folder |
${jahia.data.dir}/repository |
jahia.jackrabbit.datastore.path |
JCR file datastore path in case of the file-based binary storage |
${jahia.jackrabbit.home}/datastore |
URL settings
Property name |
Description |
Default value |
jahiaWebAppsDeployerBaseURL |
Provides your custom URL for the WAR deployer, if you use non-standard URL |
http://127.0.0.1:8080/manager/html/ |
permanentMoveForVanityURL |
If vanity URLs exists for a node and it is accessed with a non-default vanity URL, Jahia informs the client that the resource has permanently moved (HTTP status code 301). Note: this property doesn't apply if the server name of your project is not correctly set. |
true |
urlRewriteSeoRulesEnabled |
Enables the URL rewrite engine to shorten content URLs in Live mode. For example, shortening http://my.acme.org/cms/render/live/en/site/myAcme/home.html to http://my.acme.org/home.html |
true |
urlRewriteRemoveCmsPrefix |
Removes the /cms prefix from URLs when SEO URL rewriting is activated (urlRewriteSeoRulesEnabled is set to true) |
true |
urlRewriteUseAbsoluteUrls |
Enables generating absolute URLs for links to resources on other sites
|
true |
siteURLPortOverride |
Forces the generation of siteURLs to a specified port. This bypasses the request.getServerPort() calls and everything else. Specify a port to force generation of the site URL (notably used in the Exit Administration button) to that port. Set to 0 to disable port overrides.
Note: This property may cause issues with cookies or if you access Jahia through multiple front-end machines. |
0 |
disableJsessionIdParameter |
Disables the JsessionId parameter added by the application server to track sessions when no cookie is present |
true |
shiro.blockSemicolon |
Block request with a 400 Bad Request error if semicolon is found in the request URI (optional) |
true |
Mail service configuration
Note: Mail server connection settings can be found in the /settings/mail-server
repository node
Property name |
Description |
Default value |
mail_maxRegroupingOfPreviousException |
Controls mail regrouping of a repeating exception. If a repeating exception occurs more than the maximum specified here, mail is sent and you are informed with an error. |
500 |
Database properties
Note: Database connections are configured through the container-managed datasource connection. In Tomcat, the connection is set in the <jahia-web-app-dir>/META-INF/context.xml file.
Property name |
Description |
Default value |
db_script |
|
derby_embedded.script |
hibernate.dialect |
Specifies the DB dialect used by Hibernate |
org.hibernate.dialect.DerbyTenSevenDialect |
org.quartz.driverDelegateClass |
Specifies the Quartz scheduler driver delegate class |
org.quartz.impl.jdbcjobstore.StdJDBCDelegate |
Template set
Property name |
Description |
Default value |
default_templates_set |
Default value for template set |
sample-bootstrap-templates |
File manager
Property name |
Description |
Default value |
jahiaFileUploadMaxSize |
Configuration of the file manager that uses JCR as a back-end |
104857600 |
Multilingual support
Property name |
Description |
Default value |
characterEncoding |
Specifies character encoding (MIME charset) of the response that is sent to the client, request character encoding and e-mail charset |
UTF-8 |
org.jahia.multilang.default_language_code |
Specifies the fall-back language code after Jahia tries resolving the current browsing code from the session, the browser's settings, and the site's language list |
en |
considerPreferredLanguageAfterLogin |
Specifies whether to switch to the user's preferred language after login. Language switch only occurs if the current site has entries in the user's preferred language |
false |
Authentication
The following table describes container and cookie authentication, and CAS and SPNEGO authentication properties.
Property name |
Description |
Default value |
auth.container.enabled |
Enables the container authentication valve
|
false |
auth.cookie.enabled |
Enables cookie authentication for login. The cookie authentication valve uses cookies to store an identifier corresponding to a specific Jahia user when they select the Remember me option in the login engine. |
true |
auth.cas.enabled |
Enables the CAS authentication valve |
false |
auth.cas.serverUrlPrefix |
Specifies the URL prefix of the CAS server |
https://localhost:8443/cas |
auth.cas.loginUrl |
Specifies the redirect URL to the CAS server for login |
${auth.cas.serverUrlPrefix}/login |
auth.cas.logoutUrl |
Specifies the logout URL to invalidate the user session on the CAS server |
${auth.cas.serverUrlPrefix}/logout |
auth.spnego.enabled |
Enables the SpnegoHttpFilter and adjust its configuration in the applicationcontext-spnego.xml file |
false |
Custom errorDocument site property
Property name |
Description |
Default value |
site.error.enabled |
Enables specific error document pages for each site |
true |
User and group name validation
Property name |
Description |
Default value |
userManagementUserNamePattern |
Specifies the pattern for the user name validation. The new user name will be tested against this regular expression (see java.util.regex.Pattern) pattern.
Please update the resource bundle message: org.jahia.admin.users.ManageUsers.onlyCharacters.label (JahiaInternalResources.properties) to reflect the pattern changes. |
[0-9a-z_A-Z\\-\\{\\}\\.@]+ |
userManagementGroupNamePattern |
Specifies the pattern for the group name validation. The new group name will be tested against this regular expression (see java.util.regex.Pattern) pattern.
Please update the resource bundle message: org.jahia.admin.users.ManageGroups.onlyCharacters.label (JahiaInternalResources.properties) to reflect the pattern changes. |
= [0-9a-z_A-Z\\-\\{\\}]+ |
File error dumping
By default, Jahia dumps contain errors in files. Dump files are created in temp directory and have the following format:
error-DATE-TIME-EXCEPTION_COUNT_SINCE_STARTUP.txt
Generated files contain information to help you understand the context of an error. When submitting an error to Jahia support, activate this logging and submit files into the support tracking system.
Property name |
Description |
Default value |
dumpErrorsToFiles |
Enables file error dumping |
true |
fileDumpMaxRegroupingOfPreviousException |
Controls file regrouping of a repeating exception. If a repeating exception occurs more than this maximum, a file will be dumped anyway, just so that we are still informed in case this is the only error sent. |
500 |
useJstackForThreadDumps |
If set to true, a call to an external jstack tool (from Oracle Java Platform SE package) will be done by Jahia to generate a thread dump. This generate more accurate thread dumps, although the thread dump is slower.
Note: It is not guaranteed that a dump can be read by any thread dump analyzer tool available on the market.
Ensure that "jstack" is available on your PATH before enabling this property. |
false |
Concurrent processing options
Property name |
Description |
Default value |
maxModulesToGenerateInParallel |
Specifies how many threads can perform heavy weight processing (module creation not served from the cache) |
50 |
moduleGenerationWaitTime |
Specifies how long threads wait before starting to generate modules in heavy load situations (in milliseconds) |
10,000 |
moduleGenerationThreadDumpToSystemOut |
Generates a thread dump into System.out for troubleshooting the cause of a slowdown
|
true |
moduleGenerationTthreadDumpToFile |
Generates a thread dump into a separate file, under the ${java.io.temp}/jahia-threads/<current-date> folder, for troubleshooting the cause of a slowdown |
true |
minimumIntervalAfterLastAutoThreadDump |
When Jahia does not respond fast enough (see moduleGenerationWaitTime) an automatic thread dump will be created to help figuring out what caused the slowdown. In order to not spam the log file, a minimum interval between two dumps can be defined. Set to -1 to disable automatic thread dumps. |
60,000 |
maxRequestRenderTime |
Specifies the maximum time, in milliseconds, that request rendering continues before an error is thrown and the request processing is stopped. Specify a value of -1 or 0 to apply no timeout to request processing.
Note: A fragment rendering cannot be canceled. This timeout check is applied after the fragment rendering completes and before other fragments start to render. |
60,000 |
Search Indexes Consistency Check and Fix
See http://jackrabbit.apache.org/api/2.2/org/apache/jackrabbit/core/query/lucene/ConsistencyCheck.html for details.
Property name |
Description |
Default value |
jahia.jackrabbit.searchIndex.enableConsistencyCheck |
Specifies whether to perform a consistency check for the Jackrabbit search indexes, depending on the forceConsistencyCheck parameter. If set to false, no consistency check is performed on startup. |
false |
jahia.jackrabbit.searchIndex.forceConsistencyCheck |
Runs a consistency check for search indexes on every startup. If false, a consistency check is only performed when the search index detects a prior forced shutdown. |
false |
jahia.jackrabbit.searchIndex.autoRepair |
Repairs errors detected by a consistency check of search indexes. If false, errors are only written to the log. |
true |
jahia.jackrabbit.searchIndex.spellChecker.distanceImplementation |
Specifies the distance implementation for suggested words for the spell checker |
org.apache.lucene.search.spell.LevensteinDistance |
jahia.jackrabbit.searchIndex.spellChecker.minimumScore |
Specifies the minimum similarity score for suggested words for the spell checker. A lower value increases the amount of suggestions. |
0.7 |
Workspace Persistence Manager Consistency Check and Fix
Property name |
Description |
Default value |
jahia.jackrabbit.consistencyCheck |
Specifies whether to perform a consistency check of the JCR repository during startup |
false |
jahia.jackrabbit.consistencyFix |
Specifies whether the consistency check should attempt to fix issues that it discovers |
false |
repositoryDirectoryListingDisabled |
Disables the directory listing for the /repository servlet.
Note: The WebDAV client access won't work in such a case. |
false |
repositoryAllowedNodeTypes |
Specifies the node types that can be exposed through the /repository WebDAV servlet. Node types not listed here are unavailable. |
rep:root,jnt:virtualsitesFolder,
jnt:virtualsite,jnt:folder,jnt:file |
jahia.publication.versionedTypes |
Specifies the list of node types that Jahia creates versions for when publishing. Also determines visibility of versioning tab in content editor advanced options. Also determines visibility of versioning tab in content editor advanced options. |
jmix:editorialContent,jnt:file |
jahia.publication.excludedVersionedTypes |
Specifies the list of node types that Jahia excludes for creating versions for when publishing. This takes priority over jahia.publication.versionedTypes . Also determines visibility of versioning tab in content editor advanced options. |
<empty list> |
jahia.fileServlet.statisticsEnabled |
Enables access statistics logging in the Files servlet that serves files from the JCR repository |
false |
jahia.jcr.maxNameSize |
Specifies the maximum size of node names |
32 |
jahia.ui.contentTab.defaultSynchronizeNameWithTitle |
Enables the automatic synchronization of the title with the system name in Page Composer and Content Editor |
true |
accessManagerPathPermissionCacheMaxSize |
Specifies the maximum number of entries for the JCR access manager cache that optimizes the resolution of permissions for node paths. The cache is an LRU cache that retains the specified number of entries in memory and removes the least recently used entries. The cache is instantiated for each JCR session and is usually short-lived, except in the case of long-running operations such as exports, publications, and copies.
It is recommended to keep this value low as the cache can grow quite fast on large JCR repositories. If no value is specified, the default value is 100 entries. |
100 |
jahia.jcr.nodesCachePerSessionMaxSize |
Specifies the maximum number of entries allowed in the JCRNodeWrapper instances cache. These caches are designed to optimize direct access to JCR nodes by storing recently accessed entries. The caches are implemented as LRU (Least Recently Used) caches, retaining the specified number of entries in memory and removing the least recently used entries when the limit is exceeded.
Two caches are created for each JCR session: one cache per path and one cache per identifier.
JCR sessions are typically short-lived, except in cases of long-running operations such as exports, publications, and copies.
If no value is specified, the default value is 100 entries.
Setting this property to zero or a negative value will disable the limit.
Available from Jahia 8.1.8.0 and Jahia 8.2.1.0
|
100 |
jahia.jackrabbit.queryStatsEnabled |
Enables the collection of JCR query execution statistics. You can view the list of slowest queries and most popular queries in JCR Query Statistics in Jahia Tools. |
true |
Video thumbnails service
Property name |
Description |
Default value |
jahia.dm.thumbnails.video.enabled |
Enables the video thumbnails service. The service automatically creates thumbnail images for uploaded video files. |
false |
jahia.dm.thumbnails.video.ffmpeg |
The path to the ffmpeg utility executable file, which is required by the video thumbnails service. The path is typically /usr/bin/ffmpeg for Linux and c:/Program Files (x86)ffmpeg-20120503-git-c1fe2db-win64-static/bin/ffmpeg.exe for Windows.
If the ffmpeg/bin folder is present in your PATH, you can specify only the executable name here. |
ffmpeg |
Image conversion service
Property name |
Description |
Default value |
imageService |
Specifies the image service to use. The native Java service is ImageJAndJava2DImageService .
To use ImageMagick, set the value to ImageMagickImageService and the ImageMagick path to the proper value. Note: ImageMagic will by default use a lot of memory for conversions. If you want to limit memory usage (for example in Docker containers), you should use an environment variable such as MAGIC_MEMORY_LIMIT=1GiB. |
ImageJAndJava2DImageService |
imageMagickPath |
The path to ImageMagick and exiftools. For Windows the path is typically C:\\Programs\\ImageMagick;C:\\Programs\\exiftool <p< p="<> </p<> |
|
Source control and Maven executables
Property name |
Description |
Default value |
gitPath |
Specifies the path to git executable |
git |
svnPath |
Specifies the path to svn executable |
svn |
mvnPath |
Specifies the path to mvn executable |
mvn |
System users resources
Property name |
Description |
Default value |
guestUserResourceModuleName |
Associates users with a resource bundle. Set the module name that contains the resource for guest |
DefaultJahiaTemplates |
guestUserResourceKey |
Specifies the key for guest |
label.user.guest |
System group resources
Property name |
Description |
Default value |
guestGroupResourceModuleName |
Associates groups with a resource bundle. Set the module name that contains the resource for guest. |
DefaultJahiaTemplates |
guestGroupResourceKey |
Specifies the key for guest |
label.group.guest |
Users and groups
Property name |
Description |
Default value |
jahiaJCRUserCountLimit |
Limits the number of JCR users which are read for the Users page in Server Settings>Users and Roles. By default, 100 JCR users are retrieved. |
100 |
jahia.settings.userDisplayLimit |
Limits the number of users that display by default in the Users page in Server Settings>Users and Roles. By default, 100 users display. |
100 |
jahia.settings.memberDisplayLimit |
Limits the total number of group members that display by default in the Groups page in Server Settings>Users and Roles. By default, 100 groups display. |
100 |
OSGi settings
Property name |
Description |
Default value |
karaf.remoteShell.port |
Specifies the port which the Apache Karaf OSGi command line shell listens for SSH connections. Set it to a negative value to disable this feature. |
8101 |
karaf.remoteShell.host |
Specifies the bind address for the SSH shell. 127.0.0.1 means the SSH shell only allows local connections to be established. You may define a dedicated IP address, the console will bind to, or 0.0.0.0 which means it will be bound to all available network interfaces. |
127.0.0.1 |
Mass imports
Define whether you want to first expand all binary files on your hard drive before import instead of searching them in the zip files. Expanding is much faster for thousands of files. You can configure the path where to expand those files. Files will be deleted at the end of import. You can also configure at what rate you want to save your node.
Property name |
Description |
Default value |
expandImportedFilesOnDisk |
Specifies whether to first expand all binary files on your hard drive before performing a mass import, instead of searching them in the zip files. Expanding is much faster for thousands of files. |
false |
expandImportedFilesOnDiskPath |
Specifies the path to expand binary files in when performing a mass import. Files are deleted at the end of import. |
/tmp |
importMaxBatch |
Specifies the rate at which to save your node during a mass import |
500 |
Search and indexing
Property name |
Description |
Default value |
queryApproxCountLimit |
Specifies how many results should be iterated through before calculating approximate number of further results |
100 |
jahia.jackrabbit.reindexOnStartup |
Specifies whether to reindex all repository content on server startup
Note: Reindexing can take a significant amount of time depending on the volume of data |
false |
Work in progress
Property name |
Description |
Default value |
wip.checkbox.checked |
Specifies whether work in progress checkbox should be checked when opening Content Editor. |
false |
Tagging service
Property name |
Description |
Default value |
tag.suggester.faceted |
Specifies whether the query used to suggest tags uses a faceted query to retrieve the tags. The faceted suggester sorts tags by usage count and provides the count in the result map. The faceted suggester can be slower than the default suggester. Set to true to enable the faceted suggester. |
false |
Publication settings
Property name |
Description |
Default value |
jahia.ui.pickers.suppressPublicationInfo |
Specifies whether publication status information is present in content picker UIs. If suppressed, publication status is not calculated, which can speed up the rendering of corresponding UI elements. |
false |
jahia.publication.batchSize |
Defines the size of publication batch, including how many nodes can be published at once. If the number of nodes in the publication job exceeds this limit, the publication action is performed in batches. Specify a value of -1 to define no limit on the batch. In this case, the publication job processes all specified nodes at once. |
100 |
jahia.publicationManagerNodeTypes |
Specifies which additional items display in the Publication Manager, such as menu labels, and internal and external links |
jmix:publication,jmix:workflowRulesable,
jnt:navMenuText |
area.auto.activated |
Specifies whether areas are automatically activated the first time a page display in Page Composer |
true |
external.users.properties.readonly |
Lists the external user properties that are read-only. All the other user properties can be overridden locally. You can also set read-only properties for a specific provider by setting the same property suffixed with a period (.) and the provider key, for example external.users.properties.readonly.ldap=j:firstName,j:lastName,j:organization . |
j:firstName,j:lastName,j:organization,
j:email |
REST API
Property name |
Description |
Default value |
jahia.find.disabled |
Disables the find servlet and prevents queries through the API. Setting to false allow users to perform free-form JCR queries on {workspace}/{language}/query . This setting does not affect usage of JCR prepared queries. |
true |
jahia.find.nodeTypesToSkip |
Specifies the node types that are skipped by the JCR REST API |
jnt:passwordHistory,jnt:passwordHistoryEntry |
Aggregate and cache
Property name |
Description |
Default value |
useNewAggregateAndCacheImplementation |
Switches between the Render chain V1 (false) and V2 (true) implementation |
false |
Documentation
Property name |
Description |
Default value |
documentation.link |
Defines the link to the documentation |
https://academy.jahia.com/documentation/digital-experience-manager/7.3 |
sql2CheatSheet.link |
Defines the link to the JCR-SQL2 Query cheat sheet topic in the Academy. The link displays below advanced searches in jContent. |
https://academy.jahia.com/documentation/techwiki/search/jcrsql2-query-cheat-sheet |
whatsNew.link |
Defines the link to the What's New? page in the Academy |
https://www.jahia.com/$ui-lang([en,fr],en)/customers/whatsnew?dxversion |
whatsNew.display |
Specifies whether to display the What's New? button in the Jahia menu |
true |
Contribution UI customization
Property name |
Description |
Default value |
jahia.ui.dragAndDrop |
Defines drag and drop behavior in Edit mode. You can specify the following values:
ENABLED : All entire content is draggable
DRAG_ZONE_IN_EDIT_AREA : A drag zone displays at the top left of the module. Content can only be dragged in this zone
DISABLED : All dragging and dropping is disabled |
DRAG_ZONE_IN_EDIT_AREA |
jahia.ui.createChildrenDirectButtons.limit |
Sets the threshold to display a single "Any Content" button in Page Composer to create content, instead of displaying one button per available content type.
Available since Jahia 8.1.4
|
5 |
JQuery configuration
Property name |
Description |
Default value |
jahia.jquery.version |
The JQuery version for using JQuery in a page. The system looks for jquery-[version].min.js. The JQuery module provides versions 1.12.4, 3.4.1 and 3.6.0. Other versions can be added in a separate module. |
3.6.0 |
JQuery-migratecanbeaddedhere:jahia.jquery.plugins |
JQuery mapping plugins. Includes one or more JS files every time JQuery is called in a page. Note that JQuery-migrate (jquery-migrate-3.0.1.min.js ) can be added here. |
jquery-migrate-3.0.1.min.js |
Site import
Property name |
Description |
Default value |
jahia.site.import.scanner.interval |
Specifies the interval of the site import file observer in milliseconds |
30000 |
Other settings
Property name |
Description |
Default value |
jahia.atmosphere.heartbeat |
Specifies the interval (in seconds) at which the system checks the validity of the session. Ask for assistance before changing this value. Introduced with Jahia 8.0.1.0. |
60 |
loadJahiaContext |
Automatically injects javascript/initJahiaContext.js in live mode, this is necessary for CKEditor to be loaded while in live mode. Turning this setting to false might be needed for some deployments. Introduced with Jahia 8.1.6.0 |
true |
protectedResourceAccessStrategy |
Define behaviour when the user has no access to a resource (page or file)
silent : returns a 404 when the resource does not exist or is not accessible
authorizationError : returns a 401 for guest users and 403 for authenticated users without access |
silent |
Jahia node property descriptions
Cluster settings
The following table shows properties that you can add or modify in the jahia.node.properties
file.
Property name |
Description |
Default value |
cluster.activated |
Activates most of the clustering communicating |
false |
cluster.node.serverId |
The serverId must be unique for each node in the cluster |
dx-8f590fe5-02c3-4f8f-9cf0-a83f080d10f6 |
processingServer |
Specifies whether this instance of Jahia will execute long-running operations such as background jobs (for example workflow, imports, and text extraction). Only one cluster node may be a processing server. All other nodes must set this value to false . |
true |
cluster.tcp.bindAddress |
The IP or unambiguous hostname to start the server socket on. If left empty, the IP address of first non-loopback network interface that can be detect on the machine is used. |
|
cluster.tcp.bindPort |
The port number to bind the server socket to JGroups-based cluster communication for caches and Atmosphere messages |
7870 |
cluster.hazelcast.bindPort |
The port number to bind the server socket to Hazelcast-based clustered communication for bundle deployment |
7860 |
jContent and Content Editor configuration
org.jahia.modules.jcontent.cfg
Property name |
Description |
Default value |
showPageComposer |
Display a new version of Page Composer inside jContent.
This feature is currently under development and is not supported yet. This shall not be enabled on production environments.
|
false |
org.jahia.modules.contentEditor.cfg
Property name |
Description |
Default value |
createChildrenDirectButtons.limit |
Threshold to display a single "New Content" button in jContent to create content, instead of displaying one button per available content type.
Since Content Editor 4.3.0
|
5 |