Official Meeds Docker image
The image is compatible with the following databases system : MySQL
(default) / HSQLDB
/ PostgreSQL
All the following options can be defined with standard Docker -e
parameter
docker run -e MY_ENV_VARIABLE="value" ... meedsio/meeds
or Docker Compose way of defining environment variables
version: '2'
services:
...
meeds:
image: meedsio/meeds
environment:
...
MEEDS_ADDONS_LIST: meeds-poll
MEEDS_PATCHES_LIST:
MEEDS_PATCHES_CATALOG_URL:
MEEDS_ES_HOST: search
...
Some add-ons are already installed in the Meeds image but you can install other one or remove some of the pre-installed one :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_ADDONS_LIST | NO | - | commas separated list of add-ons to install (ex: meeds-wallet,meeds-perk-store:2.0.x-SNAPSHOT) |
MEEDS_ADDONS_REMOVE_LIST | NO | - | commas separated list of add-ons to uninstall |
MEEDS_ADDONS_CATALOG_URL | NO | - | The url of a valid Meeds addons Catalog |
MEEDS_ADDONS_CONFLICT_MODE | NO | - | decision to make in case of file conflicts (overwrite, ignore or fail) |
MEEDS_ADDONS_NOCOMPAT_MODE | NO | false | decision to allow to install incompatible addon |
Patches can be deployed in Meeds image :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_PATCHES_LIST | NO | - | commas separated list of patches to install (ex: patch-1.3.0:1,patch-1.3.0:2) |
MEEDS_PATCHES_CATALOG_URL | YES | - | The url of a valid Meeds Patches Catalog (mandatory if something is specified in MEEDS_PATCHES_LIST) |
The standard Meeds Server environment variables can be used :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_JVM_SIZE_MIN | NO | 512m |
specify the jvm minimum allocated memory size (-Xms parameter) |
MEEDS_JVM_SIZE_MAX | NO | 3g |
specify the jvm maximum allocated memory size (-Xmx parameter) |
MEEDS_JVM_PERMSIZE_MAX | NO | 256m |
(Java 7) specify the jvm maximum allocated memory to Permgen (-XX:MaxPermSize parameter) |
MEEDS_JVM_METASPACE_SIZE_MAX | NO | 512m |
(Java 8+) specify the jvm maximum allocated memory to MetaSpace (-XX:MaxMetaspaceSize parameter) |
MEEDS_JVM_USER_LANGUAGE | NO | en |
specify the jvm locale for langage (-Duser.language parameter) |
MEEDS_JVM_USER_REGION | NO | US |
specify the jvm local for region (-Duser.region parameter) |
MEEDS_JVM_LOG_GC_ENABLED | NO | false |
activate the JVM GC log file generation (location: $MEEDS_LOG_DIR/platform-gc.log) (1.0.0+) |
INFO: This list is not exhaustive (see ${MEEDS_HOME}/bin/setenv.sh for more parameters)
The following environment variables must be passed to the container to configure Tomcat proxy settings:
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_PROXY_VHOST | NO | localhost |
specify the virtual host name to reach Meeds Server |
MEEDS_PROXY_PORT | NO | - | which port to use on the proxy server ? if empty it will automatically defined regarding MEEDS_PROXY_SSL value (true => 443 / false => 8080) |
MEEDS_PROXY_SSL | NO | false |
is ssl activated on the proxy server ? (true / false) |
The following environment variables can be passed to the container to configure Tomcat settings
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_HTTP_THREAD_MAX | NO | 200 |
maximum number of threads in the tomcat http connector |
MEEDS_HTTP_THREAD_MIN | NO | 10 |
minimum number of threads ready in the tomcat http connector |
MEEDS_ACCESS_LOG_ENABLED | NO | false |
activate Tomcat access log with combine format and a daily log file rotation |
MEEDS_GZIP_ENABLED | NO | true |
activate Tomcat Gzip compression for assets mimetypes |
MEEDS_CONNECTION_TIMEOUT | NO | 20000 |
Tomcat Connection timeout |
A file containing the list of valves and listeners can be attached to the container in the path {{/etc/meeds/host.yml}}. If a file is specified, the default valves and listeners configuration will be overridden.
The file format is :
components:
- type: Valve
className: org.acme.myvalves.WithoutAttributes
- type: Valve
className: org.acme.myvalves.WithAttributes
attributes:
- name: param1
value: value1
- name: param2
value: value2
- type: Listener
className: org.acme.mylistener.WthAttributes
attributes:
- name: param1
value: value1
- name: param2
value: value2
The following environment variables must be passed to the container in order to work :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_DATA_DIR | NO | /srv/meeds |
the directory to store Meeds Server data |
MEEDS_FILE_STORAGE_DIR | NO | ${MEEDS_DATA_DIR}/files |
the directory to store Meeds Server data |
MEEDS_FILE_STORAGE_RETENTION | NO | 30 |
the number of days to keep deleted files on disk before definitively remove it from the disk |
MEEDS_UPLOAD_MAX_FILE_SIZE | NO | 200 |
maximum authorized size for file upload in MB. |
MEEDS_FILE_UMASK | NO | 0022 |
the umask used for files generated by Meeds |
The following environment variables must be passed to the container in order to work :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_DB_TYPE | NO | hsqldb |
Meeds server uses hsqldb by default. Possible values: mysql , postgresql or hsqldb |
MEEDS_DB_POOL_IDM_INIT_SIZE | NO | 5 |
the init size of IDM datasource pool |
MEEDS_DB_HOST | NO | db |
Meeds database server host. This is needed only when MEEDS_DB_TYPE is set to mysql or postgresql |
MEEDS_DB_PORT | NO | `` | the port to connect to the database server |
MEEDS_DB_NAME | NO | `` | the name of the database / schema to use |
MEEDS_DB_USER | NO | `` | the username to connect to the database |
MEEDS_DB_PASSWORD | YES | - | the password to connect to the database |
MEEDS_DB_POOL_IDM_MAX_SIZE | NO | 20 |
the max size of IDM datasource pool |
MEEDS_DB_POOL_JCR_INIT_SIZE | NO | 5 |
the init size of JCR datasource pool |
MEEDS_DB_POOL_JCR_MAX_SIZE | NO | 20 |
the max size of JCR datasource pool |
MEEDS_DB_POOL_JPA_INIT_SIZE | NO | 5 |
the init size of JPA datasource pool |
MEEDS_DB_POOL_JPA_MAX_SIZE | NO | 20 |
the max size of JPA datasource pool |
MEEDS_DB_TIMEOUT | NO | 60 |
the number of seconds to wait for database availability before cancelling Meeds startup |
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_DB_MYSQL_USE_SSL | NO | false |
connecting securely to MySQL using SSL (see MySQL Connector/J documentation for useSSL parameter) |
The following environment variables should be passed to the container in order to configure the search feature on an external Elastic Search server:
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_ES_SCHEME | NO | http |
the elasticsearch server scheme to use from the Meeds Server jvm perspective (http / https). |
MEEDS_ES_HOST | NO | localhost |
the elasticsearch server hostname to use from the Meeds Server jvm perspective. |
MEEDS_ES_PORT | NO | 9200 |
the elasticsearch server port to use from the Meeds Server jvm perspective. |
MEEDS_ES_USERNAME | NO | - | the username to connect to the elasticsearch server (if authentication is activated on the external elasticsearch). |
MEEDS_ES_PASSWORD | NO | - | the password to connect to the elasticsearch server (if authentication is activated on the external elasticsearch). |
MEEDS_ES_INDEX_REPLICA_NB | NO | 0 |
the number of replicat for elasticsearch indexes (leave 0 if you don't have an elasticsearch cluster). |
MEEDS_ES_INDEX_SHARD_NB | NO | 0 |
the number of shard for elasticsearch indexes. |
MEEDS_ES_TIMEOUT | NO | 60 |
the number of seconds to wait for elasticsearch availability before cancelling Meeds startup |
The following environment variables should be passed to the container in order to configure the ldap connection pool :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_LDAP_POOL_DEBUG | NO | - | the level of debug output to produce. Valid values are "fine" (trace connection creation and removal) and "all" (all debugging information). |
MEEDS_LDAP_POOL_TIMEOUT | NO | 60000 |
the number of milliseconds that an idle connection may remain in the pool without being closed and removed from the pool. |
MEEDS_LDAP_POOL_MAX_SIZE | NO | 100 |
the maximum number of connections per connection identity that can be maintained concurrently. |
The following environment variables should be passed to the container in order to configure the mail server configuration to use :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_MAIL_FROM | NO | [email protected] |
"from" field of emails sent by Meeds Server |
MEEDS_MAIL_SMTP_HOST | NO | localhost |
SMTP Server hostname |
MEEDS_MAIL_SMTP_PORT | NO | 25 |
SMTP Server port |
MEEDS_MAIL_SMTP_STARTTLS | NO | false |
true to enable the secure (TLS) SMTP. See RFC 3207. |
MEEDS_MAIL_SMTP_USERNAME | NO | - | authentication username for smtp server (if needed) |
MEEDS_MAIL_SMTP_PASSWORD | NO | - | authentication password for smtp server (if needed) |
The following environment variables should be passed to the container in order to configure JMX :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_JMX_ENABLED | NO | true |
activate JMX listener |
MEEDS_JMX_RMI_REGISTRY_PORT | NO | 10001 |
JMX RMI Registry port |
MEEDS_JMX_RMI_SERVER_PORT | NO | 10002 |
JMX RMI Server port |
MEEDS_JMX_RMI_SERVER_HOSTNAME | NO | localhost |
JMX RMI Server hostname |
MEEDS_JMX_USERNAME | NO | - | a username for JMX connection (if no username is provided, the JMX access is unprotected) |
MEEDS_JMX_PASSWORD | NO | - | a password for JMX connection (if no password is specified a random one will be generated and stored in /opt/meeds/conf/jmxremote.password) |
With the default parameters you can connect to JMX with service:jmx:rmi://localhost:10002/jndi/rmi://localhost:10001/jmxrmi
without authentication.
The following environment variables should be passed to the container in order to enable remote debugging mode :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_DEBUG_ENABLED | NO | false |
enable remote debugging listener |
MEEDS_DEBUG_PORT | NO | 8000 |
Remote debugging port |
The following environment variables should be passed to the container in order to specify rememberme token expiration :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_TOKEN_REMEMBERME_EXPIRATION_VALUE | NO | 7 |
Number of unit expiration delay |
MEEDS_TOKEN_REMEMBERME_EXPIRATION_UNIT | NO | DAY |
Unit of token expiration DAY , HOUR , MINUTE , SECOND |
The following environment variables should be passed to the container in order to configure the cluster :
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_CLUSTER | NO | false |
Activate the cluster mode |
MEEDS_CLUSTER_NODE_NAME | NO | the container id | Node name to use in the cluster for this node (ex: node1) |
MEEDS_CLUSTER_HOSTS | NO | - | space separated list of cluster hosts definitions (ex: name=node1,http_protocol=http,address=node1.cluster.local,http_port=8080,tcp1_port=7800,tcp2_port=7900 name=node2,http_protocol=http,address=node1.cluster.local,http_port=8080,tcp1_port=7800,tcp2_port=7900) |
The following environment variables should be passed to the container in order to configure Meeds Rewards wallet:
VARIABLE | MANDATORY | DEFAULT VALUE | DESCRIPTION |
---|---|---|---|
MEEDS_REWARDS_WALLET_ADMIN_KEY | YES | changeThisKey |
password used to encrypt the Admin wallet’s private key stored in database. If its value is modified after server startup, the private key of admin wallet won’t be decrypted anymore, preventing all administrative operations |
MEEDS_REWARDS_WALLET_ACCESS_PERMISSION | NO | /platform/users |
to restrict access to wallet application to a group of users (ex: member:/spaces/internal_space) |
MEEDS_REWARDS_WALLET_NETWORK_ID | NO | 1 (mainnet) |
ID of the Ethereum network to use (see: https://github.com/ethereum/EIPs/blob/master/EIPS/eip-155.md#list-of-chain-ids) |
MEEDS_REWARDS_WALLET_NETWORK_ENDPOINT_HTTP | NO | https://mainnet.infura.io/v3/a1ac85aea9ce4be88e9e87dad7c01d40 |
https url to access to the Ethereum API for the chosen network id |
MEEDS_REWARDS_WALLET_NETWORK_ENDPOINT_WEBSOCKET | NO | wss://mainnet.infura.io/ws/v3/a1ac85aea9ce4be88e9e87dad7c01d40 |
wss url to access to the Ethereum API for the chosen network id |
MEEDS_REWARDS_WALLET_TOKEN_ADDRESS | NO | 0xc76987d43b77c45d51653b6eb110b9174acce8fb |
address of the contract for the official rewarding token promoted by Meeds |
You have to specify the following environment variables to configure Meeds Server (see upper section for more parameters and details) :
docker run -d \
-p 8080:8080 \
-e MEEDS_PROXY_VHOST="my.public-facing-hostname.org" \
meedsio/meeds
You can also use Docker Compose (see the provided docker-compose.yml
file as an example).
docker logs --follow <CONTAINER_NAME>
All previously mentioned environment variables can be defined in a standard Docker way with -e ENV_VARIABLE="value"
parameters :
docker run -d \
-p 8080:8080 \
-e MEEDS_JVM_SIZE_MAX="8g" \
meedsio/meeds
Some Meeds configuration properties can also be defined in an exo.properties
file. In this case, just create this file and bind mount it in the Docker container :
docker run -d \
-p 8080:8080 \
-v /absolute/path/to/exo.properties:/etc/meeds/exo.properties:ro \
meedsio/meeds
The simplest way to build this image is to use default values :
docker build -t meedsio/meeds .
This will produce an image with the current Meeds Server.