settings.php — настройки окружения сайта

Содержание

settings.php — файл с настройками для конкретного сайта. Данный файл содержит специфичные настройки для конкретного сайта.

В данном файле настраиваются такие параметры, как подключение к базе данных, пути до конфигураций, соль и т.д. Он может быть использован сторонними модулями для управления собственным поведением, для этого присутствует соответствующий API.

Настройки – в отличие от конфигураций – предназначены только для хранения read-only значений, которые необходимы на очень ранних этапах запуска ядра. Иными словами, это настройки, которые определяют значения для текущего окружения.

Файл является read-only и Drupal регулярно проверяет факт его защиты от записи. Для внесения в него правок на действующем сайте потребуются права на запись.

Создание файла

Данный файл необходим для работы Drupal и обязательно должен присутствовать. Создать его можно двумя способами:

  • Ручной режим. Вы можете скопировать файл настроек по умолчанию default.settings.php и переименовать его в settings.php, а затем указать и изменить нужные вам настройки.

  • Автоматический режим. Данный файл будет автоматически создан и настроен для корректной работы сайта в процессе установки Drupal. Данные - такие, как параметры подключения к БД и пр. - будут запрошены у вас в ходе установки.

Если settings.php у вас уже существует, при установке нового сайта он и будет использован для автозаполнения настроек.

Где находится settings.php?

Чаще всего вы можете обнаружить его по пути /sites/default, однако, фактически это зависит от того, как произведена настройка Drupal и какой подход в разработке был использован.

По умолчанию проверяется только /sites/default, но, если вы настроите мультисайтинг (т.е., присутствует файл /sites/sites.php), то поиск будет происходить по различным директориям.

Рассмотрим на примере. Если Drupal установлен по пути https://www.drupal.org:8080/mysite/test/ то файл settings.php будет искаться движком Drupal в следующих директориях, в порядке убывания их приоритета:

  • sites/8080.www.drupal.org.mysite.test
  • sites/www.drupal.org.mysite.test
  • sites/drupal.org.mysite.test
  • sites/org.mysite.test
  • sites/8080.www.drupal.org.mysite
  • sites/www.drupal.org.mysite
  • sites/drupal.org.mysite
  • sites/org.mysite
  • sites/8080.www.drupal.org
  • sites/www.drupal.org
  • sites/drupal.org
  • sites/org
  • sites/default

Программное получение настроек

В Drupal присутствует специальный утилитарный объект \Drupal\Core\Site\Settings. При помощи данного объекта вы можете получать актуальные настройки которые используются для текущего запроса.

get()

Возвращает значение конкретной настройки, принимает два аргумента:

  • $name: Название настройки значение которой необходимо получить.
  • $default = NULL: (опционально) Значение по умолчанию, если оно не найдено в файле.

Данный метод вызовет ошибку если вы захотите получить значение для install_profile. Если вы хотите получить название инсталяционного профиля используйте сервис install_profile.

Пример:

$batch_size = Settings::get('entity_update_batch_size', 50);

getAll()

Возвращает все настройки и предназначен только для тестирования.

$settings = Settings::getAll();

getHashSalt()

Возвращает значение настройки hash_salt. Если данной настройки нет или она является пустой, то вызывается исключение.

$salt = Settings::getHashSalt();

Структура settings.php

$databases

В переменной $databases задаются настройки соединения с базами данных. Drupal имеет возможность работать в пределах одного запроса сразу с несколькими базами данных, в том числе разных типов.

Простой пример настройки подключения к БД:

$databases['default']['default'] = [
  'database' => 'databasename',
  'username' => 'sqlusername',
  'password' => 'sqlpassword',
  'host' => 'localhost',
  'port' => '3306',
  'driver' => 'mysql',
  'prefix' => '',
  'collation' => 'utf8mb4_general_ci',
];

Многие значения данного массива могут быть изменены под конкретные нужды проекта или системы.

Свойство driver отвечает какой драйвер соединения с БД должен использовать Drupal. Как правило, оно равно названию типа базы данных, например mysql или sqlite, но не всегда. Прочие свойства будут сильно зависеть от выбранного вами драйвера. Для SQLite вы должны указать файл баз данных в который Drupal может производить запись. Для большинства других драйверов вы должны указать username, password, host и database свойства.

Для каждой базы данных, опционально вы можете указать несколько «целей» БД. Целевая БД позволит Drupal пробовать отправлять некоторые запросы в другую БД, а если это не выйдет, будет использована БД по умолчанию. Это полезная особенность для репликаций БД. Drupal может подключаться к серверу с репликой когда это необходимо и если она недоступна, переключаться на основной сервер (термины основной сервер и реплика обычно обозначаются как master/slave в документациях БД).

Общий формат для массива $database следует структуре:

$databases['default']['default'] = $info_array;
$databases['default']['replica'][] = $info_array;
$databases['default']['replica'][] = $info_array;
$databases['extra']['default'] = $info_array;

В примере выше, $info_array — массив с настройками подключения БД описанные выше. Первая строка задаёт настройки для набора «default», которая имеет настройки подключения к БД по умолчанию «default» (второй ключ). Вторая и третья строки задают настройки для потенциальных реплик БД. Drupal выберет одно из значений случайным образом в пределах запроса. В четвёртой строке создаётся новая БД с именем «extra».

Опционально вы можете задать префикс для таблиц используя свойство prefix. Если префикс указан, название таблицы будет получать данный префикс перед основным названием. Убедитесь что вы указали допустимые символы и значения для БД, обычно это латинские буквы, цифры и нижнее подчёркивание. Если префиксов не требуется или не нужны, используется пустая строка ''.

Для того чтобы все таблицы были с префиксом, задайте необходимое значение в prefix:

'prefix' => 'main_',

Продвинутые пользователи могут добавлять или переопределять первичные команды, которые выполняются перед подключением к серверу баз данных, а также настройки подключения PDO.

Например, для включения возможности MySQL SELECT превышать системное значение max_join_size и уменьшить таймаут подключения к БД до 5 секунд, используется следующая конфигурация:

$databases['default']['default'] = [
  'init_commands' => [
    'big_selects' => 'SET SQL_BIG_SELECTS=1',
  ],
  'pdo' => [
    PDO::ATTR_TIMEOUT => 5,
  ],
];

Пример настройки подключения к PostgreSQL (pgsql):

$databases['default']['default'] = [
  'driver' => 'pgsql',
  'database' => 'databasename',
  'username' => 'sqlusername',
  'password' => 'sqlpassword',
  'host' => 'localhost',
  'prefix' => '',
];

Пример настройки подключения к SQLite (sqlite):

$databases['default']['default'] = [
  'driver' => 'sqlite',
  'database' => '/path/to/databasefilename',
];

$settings

В массиве $settings указываются настройки для Drupal которые могут корректировать его поведение.

Соль

Соль используемая для генерации одноразовых ссылок, токенов форм, ссылок отписки и т.д.

Значение для данной переменной задаётся случайной генерацией в процессе установки. Если вы поменяете это значение на рабочем сайте, то все ссылки одноразового входа будут инвалидированы.

Для более продвинутой защиты вы можете вынести значение соли за пределы Drupal и запрашивать его из файла или иных мест. Вы также должны убедиться что данный файл не попадает в бэкапы сайта и не хранится в БД.

Пример:

$settings['hash_salt'] = file_get_contents('/home/example/salt.txt');

Идентификатор деплоя

Контейнер Drupal для Dependency Injection автоматически инвалидируется и перестраивается при изменении версии ядра. Когда обновляете контриб или кастом модули которые меняют контейнер, изменение данного идентификатора также инвалидирует и перестроит контейнер как только код будет задеплоен.

Пример:

$settings['deployment_identifier'] = Drupal::VERSION;

Контроль доступа для update.php

Когда вы обновляете Drupal при помощи /update.php производится проверка на наличие прав доступа «Управление обновлениями» (administer software updates) у пользователя. Если у пользователя нету данных прав, то обновление не будет запущено.

Благодаря этой настройке вы можете временно отключить данную проверку, если по каким-то причинам у вас нет возможности авторизоваться под соответствующим пользователем или пользователя с такими правами не существует.

Значение TRUE — пропускает проверку прав, FALSE (по умолчанию) — будет проверять права доступа.

Пример:

$settings['update_free_access'] = FALSE;

Прокси

Если сайту необходимо обращаться во внешний интернет через прокси, вы можете указать соответствующие настройки.

Для различных запросов может использоваться различный прокси. Для этого имеется три настройки:

  • $settings['http_client_config']['proxy']['http'] — для проксирования запросов с HTTP.
  • $settings['http_client_config']['proxy']['https'] — для проксирования запросов с HTTPS.
  • $settings['http_client_config']['proxy']['no'] — массив из доверенных хостов, запросы к которым будут идти напрямую, без использования прокси.

Пример:

$settings['http_client_config']['proxy']['http'] = 'http://proxy_user:proxy_pass@example.com:8080';
$settings['http_client_config']['proxy']['https'] = 'http://proxy_user:proxy_pass@example.com:8080';
$settings['http_client_config']['proxy']['no'] = ['127.0.0.1', 'localhost'];

Обратный прокси

Обратные прокси часто используются для улучшения производительности высоконагруженных сайтов и также могут предоставить новые способы кеширования, безопасности и шифрования. В окружении где Drupal находится за обратным прокси, должен быть получен реальный IP адрес клиента для корректной работы различных подсистем, таких как логирование, статистика и управление доступом. В самом простом сценарии прокси сервер добавляет заголовок X-Forwarded-For в запрос, который содержит IP адрес клиента. Тем не менее HTTP заголовки уязвимы к спуфингу, что позволяет получить доступ к заголовку X-Forwarded-For. Следовательно, Drupal требует указывать адреса всех удалённых прокси для корректной работы.

Включение данной настройки позволяет корректно определять IP адрес клиента. Если ваш сайт работает на шаред хостинге или не имеет обратного прокси, данные настройки должны быть закомментированы (по умолчанию).

Для того чтобы данная настройка работала вы должны указать все возможные IP адреса обратных прокси в reverse_proxy_addresses. Если полный список адресов не доступен в вашем окружении (например, вы используете CDN) вы можете указать $_SERVER['REMOTE_ADDR'] прямо в настройках. Но будьте аккуратны, это открывает возможности для спуфинга если вы не предпримите дополнительных мер предосторожности.

Вы также можете настроить доверенные HTTP заголовки для обратного прокси. Общие значения:

  • \Symfony\Component\HttpFoundation\Request::HEADER_X_FORWARDED_ALL
  • \Symfony\Component\HttpFoundation\Request::HEADER_FORWARDED

Имейте в виду что значение по умолчанию \Symfony\Component\HttpFoundation\Request::HEADER_X_FORWARDED_ALL | \Symfony\Component\HttpFoundation\Request::HEADER_FORWARDED небезопасно. Вы должны указать только те заголовки, которые используются обратным прокси.

Например \Symfony\Component\HttpFoundation\Request::HEADER_X_FORWARDED_ALL будет считать доверенными следующие заголовки: X-Forwarded-For, X-Forwarded-Host, X-Forwarded-Proto, X-Forwarded-Port.

Пример:

use Symfony\Component\HttpFoundation\Request;
$settings['reverse_proxy_trusted_headers'] = Request::HEADER_X_FORWARDED_ALL | Request::HEADER_FORWARDED;

По умолчанию Drupal отправляет HTTP заголовок «Vary: Cookie» для всех анонимных пользователей. Это говорит HTTP прокси что он может возвращать результат страницы из своего локального кеша без обращения к веб-серверу если пользователь обращается с тем же заголовком Cookie как оригинальный запрос.

Без использования «Vary: Cookie», авторизованные пользователи также будут получать результат из анонимного кеша. Если сайт по большей части статичен и предназначен для анонимных пользователей, за исключением заранее известных редакторов и администраторов, то данный заголовок можно опустить.

Данное поведение позволяет организовать более продвинутое кеширование на стороне прокси и обратного прокси. Например, если пользователи будут слать разные куки файлы, они все равно будут получать содержимое из кеша. Тем не менее, авторизованные пользователи должны обращаться к сайту напрямую (в обход прокси и обратного прокси) для того чтобы не получать результаты страниц из кеша прокси.

Пример:

$settings['omit_vary_cookie'] = TRUE;

TTL кеша для ответов 4xx

Элементы кеша которые хранятся на основе URL приводят к увеличению общего числа кеш элементов. Данное поведение может стать проблемой на 404 страницах, которых может быть очень много. Для данных страницы вы можете задать свой собственный TTL (Time To Live) в секундах. По умолчанию это значение равняется одному часу (3600 секунд). Для того чтобы отключить кеширование 4хх ответов, нужно задать значение 0.

Пример:

$settings['cache_ttl_4xx'] = 3600;

Время жизни кеша форм

Form API Drupal хранит часть информации форм в кеше. По умолчанию время жизни данного кеша 6 часов (21600 секунд). Устаревшие данные удаляются при первом запуске cron.

При помощи данной настройки вы можете задать своё собственное время жизни кеша форм.

Пример:

$settings['form_cache_expiration'] = 21600;

Загрузчик классов

Если для PHP включено расширение APC, то для увеличения производительности используется загрузчик классов Symfony APC. Данное поведение можно отключить при помощи данной опции.

Пример:

$settings['class_loader_auto_detect'] = FALSE;

Если APC расширение не найдено, или оно отключено, то будет использован автозагрузчик Composer, который хорошо подходит для разработки, так как не сломается если код был перемещён в файловой системе. Вы также можете задекорировать базовый загрузчик с любым другим решением, а не только Symfony APC, так как все продакшен сайты должны иметь кеш для загрузчика в том или ином виде.

Для того чтобы задекорировать автозагрузчик, нужно переопределить переменную $class_loader.

Пример использования Symfony APC без автоматического обнаружения:

if ($settings['hash_salt']) {
  $prefix = 'drupal.' . hash('sha256', 'drupal.' . $settings['hash_salt']);
  $apc_loader = new ApcClassLoader($prefix, $class_loader);
  unset($prefix);
  $class_loader->unregister();
  $apc_loader->register();
  $class_loader = $apc_loader;
}

Разрешение авторизованных операций

Менеджер обновлений (модуль update) предоставляет администраторам сайта механизм безопасной установки обновлений для сайта напрямую через веб-интерфейс. На серверах с дополнительной защитой менеджер обновлений потребует предоставить доступы для SSH или FTP прежде чем операция будет выполнена. Это позволяет обновлять файлы сайта от лица пользователя который владеет ими, вместо того чтобы обновлять их под пользователем веб-сервера. На серверах где пользователь веб-сервера также является и владельцем файлов сайта запрос на доступ будет пропущен. Обычно такое поведение применимо для шаред хостингов, где пользователь веб-сервера и владельца сайта находятся в одной группе, что не очень безопасно.

Благодаря данной настройке вы можете отключить это поведение и обновление сайта будет доступно только по SSH и FTP.

Пример:

$settings['allow_authorize_operations'] = FALSE;

Права доступа файлов

При помощи настроек file_chmod_directory и file_chmod_file вы можете задать права по умолчанию для папки с файлами и непосредственно файлов. Значение должны быть задано в соответствии с Linux chmod в восьмеричном виде (с ведущим нулём).

Пример:

$settings['file_chmod_directory'] = 0775;
$settings['file_chmod_file'] = 0664;

Основной URL публичных файлов

В настройке file_public_base_url вы можете указать альтернативный основной URL который будет использован для публичных файлов.

Значение отличное от основного домена Drupal сайта будет использовано для доступа к публичным файлам. Эта настройка может быть использована как простая интеграция с CDN или для улучшения безопасности путём обслуживания загруженных пользователями файлов с другого домена или поддомена но ведущие на тот же сервер.

Например, если указать в настройке http://downloads.example.com/files то все пути типа /sites/default/files/js/js_tzTgUlQwCuDqAJy4wyzIGJDhQU5AS7XxLzo_MCisroE.js будут заменены на http://downloads.example.com/files/js/js_tzTgUlQwCuDqAJy4wyzIGJDhQU5AS7XxLzo_MCisroE.js.

Пример:

$settings['file_public_base_url'] = 'http://downloads.example.com/files';

Путь до публичных файлов

В настройке file_public_path вы можете поменять стандартный путь (sites/default/files) до папки где должны храниться публичные файлы. Указанная директория должна существовать и Drupal (веб-сервер) должен иметь права на запись в неё. Путь до директории должны быть относительно установки Drupal (index.php) и доступен из сети.

Пример:

$settings['file_public_path'] = 'sites/default/files';

Путь до приватных файлов

В настройке file_private_path вы можете указать путь до директории где будут храниться приватные файлы. Данная директория должна находиться за пределами установки Drupal (index.php) и не быть доступна из сети.

Пример:

$settings['file_private_path'] = '../private';

Интервал записи сессии

В настройке session_write_interval вы можете указать минимальный интервал в секундах, который должен пройти для записи данных сессии в БД после предыдущей записи. В целях производительности по умолчанию задано значение 180.

$settings['session_write_interval'] = 180;

Переопределение строк локали

Для того чтобы переопределить некоторые строки на вашем сайте без включения модуля Locale, вы можете добавить их записи в данную настройку. Данный функционал позволяет вам менять небольшие порции текста из интерфейса на необходимые вам.

Настройка задаётся с ключом locale_custom_strings_[langcode] — где [langcode] вы должны заменить на кодовое обозначение языка, в котором вы хотите производить замену. Например для русского языка будет locale_custom_strings_ru.

Пример:

$settings['locale_custom_strings_en'][''] = [
  'forum' => 'Discussion board',
  '@count min' => '@count minutes',
];

Тема оформления для режима обслуживания

В настройке maintenance_theme вы можете указать машинное имя темы оформления, которая должна использоваться для страниц, когда сайт находится в режиме обслуживания.

Данная настройки применятся только тогда, когда сайт явно находится на обслуживании. Не забудьте переопределить шаблон maintenance-page.html.twig на необходимый вам.

Пример:

$settings['maintenance_theme'] = 'bartik';

Хранилище активных конфигураций

По умолчанию, активные конфигурации хранятся в таблице {config} базы данных. Для того чтобы использовать отличное хранилище вы можете сделать следующие действия перед установкой Drupal:

  • Создать «active» директорию и указать её в $config_directories. Для безопасности, эта папка должна находиться за пределами инсталяции Drupal.
  • Переопределить значение для bootstrap_config_storage. В качестве значения должен быть объект который реализует \Drupal\Core\Config\StorageInterface.
  • Переопределить сервис config.storage.active. Для этого новое определение должно быть помещено в services.yml файл рядом с settings.php файлом.

Пример:

$settings['bootstrap_config_storage'] = ['Drupal\Core\Config\BootstrapConfigStorageFactory', 'getFileStorage'];

Сервисы

В настройке container_yamls вы можете указывать дополнительные файлы сервисов который будут загружены. Пути должны быть относительно установки Drupal (index.php).

По умолчанию данная конфигурация загружает стандартный services.yml.

Пример:

$settings['container_yamls'][] = $app_root . '/' . $site_path . '/services.yml';

Класс Dependency Injection контейнера

В настройке container_base_class вы можете указать класс, который будет использован в качестве контейнера для Dependency Injection. Это может быть полезно для сбора информации о производительности и тестирования.

Пример:

$settings['container_base_class'] = '\Drupal\Core\DependencyInjection\Container';

Парсер YAML

В настройке yaml_parser_class вы можете указать класс, который будет вызываться для парсинга YAML (.yml) файлов. Например, данная возможность может оказаться полезной если вам нужен альтернативный парсерс. Класс должен реализовывать интерфейс \Drupal\Component\Serialization\SerializationInterface.

Пример:

$settings['yaml_parser_class'] = NULL;

Шаблоны доверенных хостов

Drupal может использовать механизм доверенных хостов Symfony для предотвращения спуфинга HTTP Host заголовка.

Для того чтобы включить данный механизм, необходимо указать доверенные хосты в $settings['trusted_host_patterns']. Это должен быть массив с регулярными выражениями, без разделителей, с хостами которым вы доверяете.

Пример:

$settings['trusted_host_patterns'] = [
  '^www\.example\.com$',
];

Данная настройка разрешит работать сайту только с запросами по адресу www.example.com.

Если у вас мультисайтинг или сайт имеет несколько доменных имён, то необходимо указать все доступные значения.

Например, чтобы разрешить сайту работать с запросами example.com и example.org, а также всеми поддоменами нужно задать следующую настройку:

$settings['trusted_host_patterns'] = [
  '^example\.com$',
  '^.+\.example\.com$',
  '^example\.org$',
  '^.+\.example\.org$',
];

Чёрный список директорий на сканирование

В настройке file_scan_ignore_directories вы можете задать название директорий которые должен игнорировать File API при сканировании.

По умолчанию запрещено сканирование node_mobules и bower_components для того чтобы избежать проблем при сканировании расширений Drupal (могут оказаться схожие файлы, но не являться расширением Drupal).

Пример:

$settings['file_scan_ignore_directories'] = [
  'node_modules',
  'bower_components',
];

Количество обрабатываемых сущностей за раз

В настройке entity_update_batch_size вы можете изменить какое количество сущностей будет обрабатываться за один этап обработки массовых операций в процессе обновлений.

Данная настройка используется ядром в хуках обновлений (hook_update() и hook_post_update()) при обработке больших объёмов сущностей. Это позволяет снизить потребление памяти и увеличить скорость обработки.

Также данная настройки иногда используется модулями как значение по умолчанию, чтобы сохранять требования к массовым операциям при больших объёмах данных.

Пример:

$settings['entity_update_batch_size'] = 50;

Резервная копия сущностей при обновлении

В настройке entity_update_backup вы можете включать и отключать создание резервных копий для таблиц сущностей с их данными при обновлении схем и полей.

Данные таблицы остаются в БД и их нужно удалять в ручном режиме. Это позволяет в случае проблем не потерять данные и иметь точку возврата.

Пример:

$settings['entity_update_backup'] = TRUE;

Отключение принудительного изменения прав на запись для директории сайта

При помощи настройки skip_permissions_hardening вы можете выключить принудительное удаление прав на запись для папки сайта (/sites/default).

По умолчанию Drupal регулярно сбрасывает права доступа к папке сайта, полностью убирая возможность записи. Это может повлечь за собой проблемы при управлении сайтом при помощи Composer и чаще всего встречается при попытке создания скафолд файлов в соответствующей директории плагином drupal/core-composer-scaffold.

Если вы не работаете с сайтом через FTP и управляете им при помощи Composer, вы можете без последствий отключить данное поведение.

Пример:

$settings['skip_permissions_hardening'] = TRUE;

Проверка схемы БД для синонимов

В настройке system.path_alias_schema_check вы можете отключить проверку схему БД при сохранении сущностей синонимов.

В Drupal 8.8.0 синонимы были конвертированы в сущности и их хранение соответственно изменилось. Если вы не применяли соответствующие обновления БД, то при попытке сохранить синонимы используя сущности будет фатальная ошибка. В Drupal 8.9.0 была добавлена проверка что данные обновления применены, и если их нет, мягко выдавать ошибку и продолжать выполнение. При помощи данной настройки вы можете отключить данное поведение.

Пример:

$settings['system.path_alias_schema_check'] = FALSE;

Включение классических миграций нод

При помощи настройки migrate_node_migrate_type_classic вы можете активировать старую версию миграций нод, которая предоставлялась ядром до Drupal 8.9.0.

Начиная с Drupal 8.9.0 появились новые миграции, которые мигрируют ноды, со всеми их переводами, ревизиями и переводами ревизий, которые отличаются от тех что были ранее. Если ваш код или миграции основывались на старых миграциях, данная настройка позволит вернуть прежнее поведение.

Пример:

$settings['migrate_node_migrate_type_classic'] = TRUE;

Получение информации об обновлениях по HTTP

При помощи настройки update_fetch_with_http_fallback вы можете выключить получение информации об обновлениях с использованием HTTP.

Начиная с Drupal 9.1.0 Drupal использует HTTPS протокол для получения информации об обновлениях. Данная особенность требует чтобы на сервере было установлено OpenSSL расширение для PHP, в противном случае получить информацию об обновлениях будет невозможно.

Данная настройка отключает данные проверки и использует HTTP протокол для получения информации. Включение данной настройки открывает потенциальную возможность для MITM атак на сайт. Вы должны попробовать установить OpenSSL расширение прежде чем включать данную нстройку.

$settings['update_fetch_with_http_fallback'] = TRUE;

Управление заголовком для ответов Permissions-Policy

По умолчанию, Drupal устанавливает на все ответы заголовок Permissions-Policy: interest-cohort=() для того чтобы отключить Google Federated Learning of Cohorts (FLoC) которая доступна начиная с Chrome 89.

Если вы не хотите отключить данную возможность, вы можете установить данное значение в FALSE и заголовок не будет добавляться:

$settings['block_interest_cohort'] = FALSE;

$config

При помощи переменной $config вы можете переопределить значения конфигураций на глобальном уровне. Как правило, это не требуется. Эта возможность полезна для переопределения адреса сайта или путей для локального окружения.

Существуют конфигурации которые опасно перезаписывать. Например перезапись списка активных модулей для core.extension лишь сломает сайт, так как изменения не вызовут соответствующие процессы установки и деинсталяции. Другой пример это хранилища полей, которые также повлекут за собой проблемы, так как эти изменения не вызовут изменения схемы БД. Поэтому часть из данных конфигураций не подвержены данным изменениям.

Также учтите, что изменение данных значений через текущий подход — не вызовет никаких событий, и подписчики ничего об этом не узнают.

Пример:

$config['system.file']['path']['temporary'] = '/tmp';
$config['system.site']['name'] = 'My Drupal site';
$config['system.theme']['default'] = 'stark';
$config['user.settings']['anonymous'] = 'Visitor';

Быстрые 404 страницы

Drupal может генерировать полноценное оформление для 404 ответов. Тем не менее часть ответов происходит на запросы картинок или прочих файлов, которые не отображаются для пользователя, так как это создаст дополнительную нагрузку и потребление интернет канала.

При помощи изменения некоторых конфигурационных настроек, вы можете настроить быстрые 404 ответы в соответствии с паттернами:

  • $config['system.performance']['fast_404']['exclude_paths']: Регулярное выражение для путей которые необходимо исключить. Например, картинки, сгенерированные для стилей изображений или динамически обрезанные картинки. Значение по умолчанию также исключает файлы из приватной файловой системы. Если вы хотите добавить дополнительные пути, вы можете дополнить регулярно выражения при помощи выражения |path.
  • $config['system.performance']['fast_404']['paths']: Регулярное выражение для путей 404 ответ для которых нужно отдавать быстро, вместо полностью оформленной страницы. Если вы не используете алиасы с окончаниями htm или html, вы можете добавить выражение |s?html? чтобы для таких путей отдавались быстрые 404 ответы.
  • $config['system.performance']['fast_404']['html']: HTML разметка, которую необходимо возвращать в случае активации быстрого ответа 404.

Пример:

$config['system.performance']['fast_404']['exclude_paths'] = '/\/(?:styles)|(?:system\/files)\//';
$config['system.performance']['fast_404']['paths'] = '/\.(?:txt|png|gif|jpe?g|css|js|ico|swf|flv|cgi|bat|pl|dll|exe|asp)$/i';
$config['system.performance']['fast_404']['html'] = '<!DOCTYPE html><html><head><title>404 Not Found</title></head><body><h1>Not Found</h1><p>The requested URL "@path" was not found on this server.</p></body></html>';

Настройки PHP

В определённых местах settings.php файла вы можете встретиться с различными примерами настроек для PHP которые могут вам пригодиться.

Для задавания настроек PHP нужно использовать ini_set().

Настройка во время выполнения

Если у вас возникают ситуации когда пользователь публикует большой объём текста, а результат обрезается в момент просмотра, при этом, в режиме редактирования текст на месте и может быть отредактирован, это значит что фильтры Drupal не располагают достаточным объёмом памяти для обработки текста. Для того чтобы решить данную проблему, вы можете переопределить настройки во время выполнения.

Пример:

ini_set('pcre.backtrack_limit', 200000);
ini_set('pcre.recursion_limit', 200000);

Изменения в релизах

  • Drupal 9.1.0 (02.12.20): Настройка для базы данных $databases[$database][$target]['transactions'] помечена устаревшей и будет удалена в Drupal 10.
  • Drupal 9.1.0 (02.12.20): Добавлена новая настройка update_fetch_with_http_fallback.
  • Drupal 9.2.0 (02.06.21): Добавлена новая настройка block_interest_cohort.
  • Drupal 9.3.0 (08.12.21): Возможность указывать префиксы для конкретных таблиц помечена устаревшей.

Смотрите также

🌱 Помогите нам сделать документацию лучше!

Вся документация Druki с отрытым исходным кодом. Нашли ошибку или неточность? Создайте pull request.

Редактировать текущий документ Обсудить улучшение

Или узнайте как контрибутить.

🤔 По-прежнему нужна помощь?

Не нашли ответа на свой вопрос? Попросите помощи у сообщества!

Задайте вопрос на GitHub Смотрите другие ресурсы сообщества