- 2 Minutes à lire
- Impression
- PDF
Configuration
- 2 Minutes à lire
- Impression
- PDF
JVM Configuration
Memory parameters
These parameters are probably the most important ones for Tomcat, and they must be set at the JVM level through the tomcat configuration tool, or directly at console level.
The following table give the recommended values for these parameters, depending on the package selected:
JVM Parameters | Pack 2 | Pack 3 | Pack 4 | Pack 5 | Pack 6 | Pack 7 | Pack 8 | Pack 9 | Pack 10 |
-XX:XMX | 4G | 10G | 21G | 21G | 47G | 63G | 63G | 63G | 94G |
-XX:XMS | 4G | 10G | 21G | 21G | 47G | 63G | 63G | 63G | 94G |
-XX:XMN | 1G | 3G | 7G | 7G | 16G | 21G | 21G | 21G | 31G |
-XX:MaxMetaspaceSize | 1G | 3G | 7G | 7G | 16G | 21G | 21G | 21G | 31G |
G1 Garbage collector
With Java 8 and more, the garbage collector G1 has overall better performance than the default (concurrent) GC.
Recommendation:
It is recommended to activate it with the following option: -XX:+UseG1GC
You can find more explanations for fine-tuning of the GC here.
Other parameters
An other option that might help to save some resources is:
-XX:+UseStringDeduplication: its actual impact might be really neglectable in most situations, it doesn't hurt to activate this option.
Tomcat Configuration
There are many options for the configuration of Tomcat, that will be found in the server.xml file in the Tomcat configuration folder.
This file is preconfigured with minimal options upon installation and it is very important to adjust the values of the parameters listed below to get the best results according to the configuration shown below.
Tomcat configuration is based on a “Connector” that can itself be related to an “Executor’”for managing a separate thread pool, as explained in the official documentation here.
Example of configuration for https
<Connector SSLEnabled="true"
port="443"
keystoreFile="C:/var/iobeya/settings/.keystore" keystorePass="iobeya"
protocol="org.apache.coyote.http11.Http11NioProtocol"
scheme="https"
secure="true"
sslProtocol="TLS"
clientAuth="false"
maxThreads="480"
minSpareThreads="24"
processorCache="720"
compression="on"
compressionMinSize="1024"
compressibleMimeType="text/html,text/xml,text/plain,text/css,text/javascript,application/javascript,application/json,application/vnd.ms-fontobject,application/xml,image/svg+xml,font/otf,font/ttf"/>
To go beyond the simple example above, refer to the Tomcat reference documentation, such as:
Important parameters
The most important parameters for optimization of Tomcat performances are the ones highlighted in bold in the previous example:
maxThreads: indicates how many threads can be run simultaneously, this value will change with platform sizing (see table below).
compression: in any configuration, you would activate http compression that will lower the amount of data sent over https.
compressionMinSize: It’s inefficient to compress data < 1024 bytes.
compressibleMimeType: only compress the text data, not images or binary.
Parameters table
The parameters that must be adjusted depending on the package are listed below:
Tomcat Parameters | Pack 2 | Pack 3 | Pack 4 | Pack 5 | Pack 6 | Pack 7 | Pack 8 | Pack 9 | Pack 10 |
maxThreads | 200 | 200 | 200 | 200 | 200 | 480 | 480 | 480 | 720 |
minSpareThreads | 10 | 10 | 10 | 10 | 24 | 24 | 24 | 24 | 36 |
processorCache | 200 | 400 | 800 | -1 | -1 | -1 | -1 | -1 | -1 |
iObeya Configuration
In the iObeya context file for Tomcat (ROOT.xml), the important parameter to modify is maxActive and its should follow the values in the table below:
iObeya Parameters | Pack 2 | Pack 3 | Pack 4 | Pack 5 | Pack 6 | Pack 7 | Pack 8 | Pack 9 | Pack 10 |
maxActive | 50 | 100 | 150 | 200 | 300 | 500 | 700 | 1000 | 1500 |
MySQL Configuration
The configuration file of MySQL (my.ini/mysql.ini or my.cnf) will be edited and the following values updated:
MySQL Parameters | Pack 2 | Pack 3 | Pack 4 | Pack 5 | Pack 6 | Pack 7 | Pack 8 | Pack 9 | Pack 10 |
innodb_buffer_pool_size | 1GB | 2GB | 5GB | 11GB | 11GB | 23GB | 46GB | 92GB | 138GB |
innodb_buffer_pool_instances | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 |
Innodb_thread_concurrency | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
max_connections | 170 | 341 | 682 | 1365 | 1365 | 2730 | 5461 | 10922 | 16384 |
Global view of all parameters
| Pack 2 | Pack 3 | Pack 4 | Pack 5 | Pack 6 | Pack 7 | Pack 8 | Pack 9 | Pack 10 |
Active users | >20 et <50 | 50 et <100 | >100 et <150 | >150 et <200 | >200 <300 | > 300 | > 700 | >1000 | >1500 |
Nb users | <500 | <1000 | >1000 | >1000 | >1000 | >1000 | >1000 | >1500 | >2000 |
Rooms | < 20 | >20 et <100 | > 100 et <500 | >500 | >500 | >500 | >500 | >1000 | >1500 |
Host RAM | 8GB | 16GB | 32GB | 32 GB | 72 GB | 96 GB | 96 GB | 96 GB | 144 GB |
Host CPUs | 2 | 4 | 8 | 16 | 36 | 48 | 48 | 48 | 72 |
DB vCPUs | 2 | 2 | 2 | 4 | 4 | 8 | 16 | 32 | 48 |
DB RAM | 2 | 4 | 8 | 16 | 16 | 32 | 64 | 128 | 192 |
-XX:XMX | 4G | 10G | 21G | 21G | 47G | 63G | 63G | 63G | 94G |
-XX:XMS | 4G | 10G | 21G | 21G | 47G | 63G | 63G | 63G | 94G |
-XX:XMN | 1G | 3G | 7G | 7G | 16G | 21G | 21G | 21G | 31G |
-XX:MaxMetaspaceSize | 1G | 3G | 7G | 7G | 16G | 21G | 21G | 21G | 31G |
maxThreads | 200 | 200 | 200 | 200 | 200 | 480 | 480 | 480 | 720 |
minSpareThreads | 10 | 10 | 10 | 10 | 24 | 24 | 24 | 24 | 36 |
processorCache | 200 | 400 | 800 | -1 | -1 | -1 | -1 | -1 | -1 |
maxActive | 50 | 100 | 150 | 200 | 300 | 500 | 700 | 1000 | 1500 |
innodb_buffer_pool_size | 1GB | 2GB | 5GB | 11GB | 11GB | 23GB | 46GB | 92GB | 138GB |
innodb_buffer_pool_instances | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 |
Innodb_thread_concurrency | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
max_connections | 170 | 341 | 682 | 1365 | 1365 | 2730 | 5461 | 10922 | 16384 |
Monitoring
Monitoring iObeya using JMX interface is fully documented here.