Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

php_admin_[flag|value] falsely applies config changes #10117

Open
pavel-rossinsky opened this issue Dec 16, 2022 · 1 comment
Open

php_admin_[flag|value] falsely applies config changes #10117

pavel-rossinsky opened this issue Dec 16, 2022 · 1 comment

Comments

@pavel-rossinsky
Copy link

pavel-rossinsky commented Dec 16, 2022

Description

Quick explanation of the problem.

When using strace I noticed stat system calls for the files already in opcache, even though opcache.enable_file_override is set to 1. The system calls are triggered by is_file() being invoked from PHP.

php_admin_flag[opcache.enable_file_override] = On is set in the pool config /etc/php/8.1/fpm/pool.d/www.conf

var_dump(opcache_get_configuration()) when being invoked through an fpm process says:

["opcache.enable_file_override"]=>
  | bool(true)

phpinfo() says the same, enable_file_override is On.

I suspect the actual value of the flag is Off.

How to reproduce the issue.

  1. Ensure that opcache is enabled and enable_file_override is disabled (disabled by default). Also, set in the ini file:
opcache.file_update_protection=0
opcache.validate_permission=0
opcache.validate_timestamps=0
  1. Apply the fpm pool settings for simplicity of testing:
pm = static
pm.max_children = 1
  1. Add three test scripts to the document root of apache server:
    test_opcache.php
<?php

echo "test begin\n";

$file1 = 'include_1.php';
$file2 = 'include_2.php';

if (is_file($file1)) {
    include $file1;
}

if (is_file($file2)) {
    include $file2;
}

echo "test end\n";

plus two more scripts in the same directory:
include_1.php

<?php

echo __FILE__ . "\n";

include_2.php

<?php

echo __FILE__ . "\n";
  1. Invoke the test_opcache.php to warm up the opcache via curl request or browser.
  2. Attach to the child fpm process using strace -p <pid> -e newfstatat,fstat,stat.
  3. Invoke the test_opcache.php again. Expected strace output:
newfstatat(AT_FDCWD, "/", {st_mode=S_IFDIR|0755, st_size=4096, ...}, 0) = 0
newfstatat(AT_FDCWD, "include_1.php", {st_mode=S_IFREG|0644, st_size=29, ...}, 0) = 0
newfstatat(AT_FDCWD, "include_2.php", {st_mode=S_IFREG|0644, st_size=29, ...}, 0) = 0
  1. Set php_admin_flag[opcache.enable_file_override] = On in the pool config and restart apache and fpm.
  2. Check if the config value is changed via var_dump(opcache_get_configuration()).
  3. Repeat steps 4, 5, and 6. The strace output won't change.
  4. Set opcache.enable_file_override=1 in the php.ini file and repeat steps 4, 5, and 6. The output will change to
newfstatat(AT_FDCWD, "/", {st_mode=S_IFDIR|0755, st_size=4096, ...}, 0) = 0

Conclusion

The opcache.enable_file_override flag works only when it's set in the ini file.
The worst thing is that setting the flag in the pool config gives a false positive result in opcache_get_configuration() and phpinfo(), which might be very misleading.

PHP Version

PHP 8.1.13

Operating System

Ubuntu 18.04

@bukka
Copy link
Member

bukka commented Dec 26, 2022

This is related to #8699 and should get fixed once the solution for that is implement - it will at least properly fails for system inis that cannot be supported.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants