Customizing An Environment
Further information on customizing or extending an environment is forthcoming. For now, this section is limited to very simple and somewhat common customizations.
To configure your project with a non-default PHP version, add the following to the project’s .env.roll
file and run roll env up
to re-create the affected containers:
PHP_VERSION=8.1
The versions of MariaDB/Mysql, Elasticsearch, Varnish, Redis, NodeJS and Composer may also be similarly configured using variables in the .env.roll
file:
DB_DISTRIBUTION_VERSION
(Available distributions:DB_DISTRIBUTION=mysql
orDB_DISTRIBUTION=mariadb
)ELASTICSEARCH_VERSION
OPENSEARCH_VERSION
REDIS_VERSION
VARNISH_VERSION
RABBITMQ_VERSION
NODE_VERSION
COMPOSER_VERSION
Start of some environments could be skipped by using variables in .env.roll
file:
ROLL_DB=0
ROLL_REDIS=0
Docker Specific Customizations
To override default docker settings, add a custom configuration file in your project root
folder: /.roll/roll-env.yml
This file will be merged with the default environment configuration.
One example for a use case is the setup of multiple domains.
If that’s not enough, it’s possible to extend the environment config by leveraging, like for example (.roll/environments/magento2/magento2.base.yml
):
services:
nginx:
image: my_custom_nginx_image:latest
environment:
- NGINX_PUBLIC=/
volumes:
- ./.roll/nginx/custom.conf:/etc/nginx/default.d/custom.conf
It is a silly example (set pub root to /
instead of /pub
and include some custom NGINX config), but it shows how you can add configuration to a certain RollDev environment type for a specific project. It is very useful when you want to keep using .roll/roll-env.yml
for your very own environment, but want to share environment config with your teammates.
PHP Specific Customizations
To override default php settings, follow the docker customization above and include your custom php.ini
file.
In this case the roll-env.yml
should look like this:
services:
php-fpm:
volumes:
- ./.roll/php/zz-config.ini:/usr/local/etc/php/conf.d/zz-config.ini
php-debug:
volumes:
- ./.roll/php/zz-config.ini:/usr/local/etc/php/conf.d/zz-config.ini
Now add the referenced .roll/php/zz-config.ini
file with your wanted changes.
For example you could change the error reporting value:
error_reporting=(E_ALL ^ E_DEPRECATED)
The config file will be merged with the default 01-php.ini
resp. override the values
included there. The default values are the following:
date.timezone = UTC
max_execution_time = 3600
max_input_vars = 10000
memory_limit = 2G
display_errors = On
post_max_size = 25M
session.auto_start = Off
upload_max_filesize = 25M
Nginx Specific Customizations
To override the default nginx configuration of your project, add a new file
.roll/roll-env.yml
to your project root with the following content:
services:
nginx:
volumes:
- ./.roll/nginx/custom.conf:/etc/nginx/default.d/custom.conf
There you can specify a custom Nginx configuration which will be included following the .conf
files within the /etc/nginx/available.d
directory: include /etc/nginx/default.d/*.conf
Magento 1 Specific Customizations
If you use a modman
structure, initialize the environment in your project path.
The .modman
folder and the corresponding .basedir
file will be recognized and set up automatically.
Magento 2 Specific Customizations
The following variables can be added to the project’s .env.roll
file to enable additional database containers for use with the Magento 2 (Commerce Only) split-database solution.
ROLL_SPLIT_SALES=1
ROLL_SPLIT_CHECKOUT=1
Start of some Magento 2 specific environments could be skipped by using variables in .env.roll
file:
ROLL_ELASTICSEARCH=0
ROLL_OPENSEARCH=0
ROLL_VARNISH=0
ROLL_RABBITMQ=0