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 or DB_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