Задать вопрос

Почему в access-логах PHP-FPM неверный request URI?

Конфигурация nginx'а включает в себя следующие настройки.

site.conf:
server {
    ...
    location / {
        try_files $uri /index.php$is_args$args;
    }

    location ~ ^/index\.php(/|$) {
        fastcgi_pass unix:/run/php/php8.0-fpm.sock;
        fastcgi_split_path_info ^(.+\.php)(/.*)$;

        include fastcgi.conf;
        internal;
    }
    ...
}


fastcgi.conf:
fastcgi_param  QUERY_STRING       $query_string;
fastcgi_param  REQUEST_METHOD     $request_method;
fastcgi_param  CONTENT_TYPE       $content_type;
fastcgi_param  CONTENT_LENGTH     $content_length;

fastcgi_param  SCRIPT_FILENAME    $realpath_root$fastcgi_script_name;
fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
fastcgi_param  PATH_INFO          $fastcgi_path_info;
fastcgi_param  PATH_TRANSLATED    $realpath_root$fastcgi_path_info;
fastcgi_param  REQUEST_URI        $request_uri;
fastcgi_param  DOCUMENT_URI       $document_uri;
fastcgi_param  DOCUMENT_ROOT      $realpath_root;
fastcgi_param  SERVER_PROTOCOL    $server_protocol;
fastcgi_param  REQUEST_SCHEME     $scheme;
fastcgi_param  HTTPS              $https if_not_empty;

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;

fastcgi_param  REMOTE_ADDR        $remote_addr;
fastcgi_param  REMOTE_PORT        $remote_port;
fastcgi_param  REMOTE_USER        $remote_user;
fastcgi_param  SERVER_ADDR        $server_addr;
fastcgi_param  SERVER_PORT        $server_port;
fastcgi_param  SERVER_NAME        $server_name;

# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param  REDIRECT_STATUS    200;

# Mitigate https://httpoxy.org/ vulnerabilities
fastcgi_param  HTTP_PROXY         "";


Согласно документации PHP-FPM, использование "%r" в директиве access.format конфигурации pool'а должно выводить в access-лог "the request URI (without the query string)". Но по факту туда выводится "/index.php" (то есть SCRIPT_NAME).

Если вместо "%r" использовать "%{REQUEST_URI}e" — в логи пишется что надо.

Вопрос: что я делаю не так?
Раскопки в исходниках PHP-FPM не помогли, кажется, что всё должно быть нормально.
  • Вопрос задан
  • 330 просмотров
Подписаться 3 Средний 1 комментарий
Пригласить эксперта
Ответы на вопрос 1
karabanov
@karabanov
Системный администратор
Всё верно $uri - это /index.php, то есть without the query string, $request_uri - это /index.php?foo=1&bar=2 то есть with the query string

%r %q ты видимо ищешь.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы