dunglas / frankenphp

🧟 The modern PHP app server
https://frankenphp.dev
MIT License
6.7k stars 221 forks source link

FrankenPHP serving stale requests #881

Open krystof018 opened 3 months ago

krystof018 commented 3 months ago

What happened?

Sometimes franken php is serving stale requests with Symfony. It returns random previous requests no matter what they contain (errors included). I'm not sure when this happens but it seems to me that it happens after multiple 5xx responses (but not everytime). Only thing that helps is restarting the docker container. I don't think it's Symfony issue because it was working just fine on fastcgi but it's true I migrated the project to Symfony 7 around the same time. I understand that this description isn't much you can work with but I hope I'm not the only one its happens to and that someone will have more insight/understanding why is this happening.

This happens no matter the symfony environment is running.

This is my Caddyfile

{
    # Debug
    frankenphp {
        worker /srv/public/index.php
    }
}
http://localhost {
    # Enable access logging (to the console)
    log
    route {
        root * public/
        php_server
    }
}

https://localhost {
    tls internal

    # Enable access logging (to the console)
    log

    route {
        root * public/
        php_server
    }
}

I'm starting my caddy server with frankenphp run --config /etc/caddy/Caddyfile --adapter caddyfile

The app is Symfony 7 with API Platform, nothing else is special about it.

Build Type

Docker (Debian Bookworm)

Worker Mode

Yes

Operating System

macOS

CPU Architecture

Apple Silicon

PHP configuration

Really long text :) ```shell PHP Version => 8.3.8 System => Linux c00d8fae2c93 6.6.31-linuxkit #1 SMP Thu May 23 08:36:57 UTC 2024 aarch64 Build Date => Jun 6 2024 19:52:37 Build System => Linux - Docker Build Provider => https://github.com/docker-library/php Configure Command => './configure' '--build=aarch64-linux-gnu' '--with-config-file-path=/usr/local/etc/php' '--with-config-file-scan-dir=/usr/local/etc/php/conf.d' '--enable-option-checking=fatal' '--with-mhash' '--with-pic' '--enable-mbstring' '--enable-mysqlnd' '--with-password-argon2' '--with-sodium=shared' '--with-pdo-sqlite=/usr' '--with-sqlite3=/usr' '--with-curl' '--with-iconv' '--with-openssl' '--with-readline' '--with-zlib' '--enable-phpdbg' '--enable-phpdbg-readline' '--with-pear' '--with-libdir=lib/aarch64-linux-gnu' '--enable-embed' '--enable-zts' '--disable-zend-signals' 'build_alias=aarch64-linux-gnu' Server API => Command Line Interface Virtual Directory Support => enabled Configuration File (php.ini) Path => /usr/local/etc/php Loaded Configuration File => (none) Scan this dir for additional .ini files => /usr/local/etc/php/conf.d Additional .ini files parsed => /usr/local/etc/php/conf.d/docker-php-ext-exif.ini, /usr/local/etc/php/conf.d/docker-php-ext-gd.ini, /usr/local/etc/php/conf.d/docker-php-ext-gmp.ini, /usr/local/etc/php/conf.d/docker-php-ext-intl.ini, /usr/local/etc/php/conf.d/docker-php-ext-mysqli.ini, /usr/local/etc/php/conf.d/docker-php-ext-pdo_mysql.ini, /usr/local/etc/php/conf.d/docker-php-ext-sodium.ini, /usr/local/etc/php/conf.d/docker-php-memlimit.ini PHP API => 20230831 PHP Extension => 20230831 Zend Extension => 420230831 Zend Extension Build => API420230831,TS PHP Extension Build => API20230831,TS Debug Build => no Thread Safety => enabled Thread API => POSIX Threads Zend Signal Handling => disabled Zend Memory Manager => enabled Zend Multibyte Support => provided by mbstring Zend Max Execution Timers => enabled IPv6 Support => enabled DTrace Support => disabled Registered PHP Streams => https, ftps, compress.zlib, php, file, glob, data, http, ftp, phar Registered Stream Socket Transports => tcp, udp, unix, udg, ssl, tls, tlsv1.0, tlsv1.1, tlsv1.2, tlsv1.3 Registered Stream Filters => zlib.*, convert.iconv.*, string.rot13, string.toupper, string.tolower, convert.*, consumed, dechunk This program makes use of the Zend Scripting Language Engine: Zend Engine v4.3.8, Copyright (c) Zend Technologies _______________________________________________________________________ Configuration Core PHP Version => 8.3.8 Directive => Local Value => Master Value allow_url_fopen => On => On allow_url_include => Off => Off arg_separator.input => & => & arg_separator.output => & => & auto_append_file => no value => no value auto_globals_jit => On => On auto_prepend_file => no value => no value browscap => no value => no value default_charset => UTF-8 => UTF-8 default_mimetype => text/html => text/html disable_classes => no value => no value disable_functions => no value => no value display_errors => STDOUT => STDOUT display_startup_errors => On => On doc_root => no value => no value docref_ext => no value => no value docref_root => no value => no value enable_dl => On => On enable_post_data_reading => On => On error_append_string => no value => no value error_log => no value => no value error_log_mode => 0644 => 0644 error_prepend_string => no value => no value error_reporting => no value => no value expose_php => On => On extension_dir => /usr/local/lib/php/extensions/no-debug-zts-20230831 => /usr/local/lib/php/extensions/no-debug-zts-20230831 fiber.stack_size => no value => no value file_uploads => On => On hard_timeout => 2 => 2 highlight.comment => #FF8000 => #FF8000 highlight.default => #0000BB => #0000BB highlight.html => #000000 => #000000 highlight.keyword => #007700 => #007700 highlight.string => #DD0000 => #DD0000 html_errors => Off => Off ignore_repeated_errors => Off => Off ignore_repeated_source => Off => Off ignore_user_abort => Off => Off implicit_flush => On => On include_path => .:/usr/local/lib/php => .:/usr/local/lib/php input_encoding => no value => no value internal_encoding => no value => no value log_errors => Off => Off mail.add_x_header => Off => Off mail.force_extra_parameters => no value => no value mail.log => no value => no value mail.mixed_lf_and_crlf => Off => Off max_execution_time => 0 => 0 max_file_uploads => 20 => 20 max_input_nesting_level => 64 => 64 max_input_time => -1 => -1 max_input_vars => 1000 => 1000 max_multipart_body_parts => -1 => -1 memory_limit => 256M => 256M open_basedir => no value => no value output_buffering => 0 => 0 output_encoding => no value => no value output_handler => no value => no value post_max_size => 8M => 8M precision => 14 => 14 realpath_cache_size => 4096K => 4096K realpath_cache_ttl => 120 => 120 register_argc_argv => On => On report_memleaks => On => On report_zend_debug => Off => Off request_order => no value => no value sendmail_from => no value => no value sendmail_path => /usr/sbin/sendmail -t -i => /usr/sbin/sendmail -t -i serialize_precision => -1 => -1 short_open_tag => On => On SMTP => localhost => localhost smtp_port => 25 => 25 sys_temp_dir => no value => no value syslog.facility => LOG_USER => LOG_USER syslog.filter => no-ctrl => no-ctrl syslog.ident => php => php unserialize_callback_func => no value => no value upload_max_filesize => 2M => 2M upload_tmp_dir => no value => no value user_dir => no value => no value user_ini.cache_ttl => 300 => 300 user_ini.filename => .user.ini => .user.ini variables_order => EGPCS => EGPCS xmlrpc_error_number => 0 => 0 xmlrpc_errors => Off => Off zend.assertions => 1 => 1 zend.detect_unicode => On => On zend.enable_gc => On => On zend.exception_ignore_args => Off => Off zend.exception_string_param_max_len => 15 => 15 zend.max_allowed_stack_size => 0 => 0 zend.multibyte => Off => Off zend.reserved_stack_size => 0 => 0 zend.script_encoding => no value => no value ctype ctype functions => enabled curl cURL support => enabled cURL Information => 7.88.1 Age => 10 Features AsynchDNS => Yes CharConv => No Debug => No GSS-Negotiate => No IDN => Yes IPv6 => Yes krb4 => No Largefile => Yes libz => Yes NTLM => Yes NTLMWB => Yes SPNEGO => Yes SSL => Yes SSPI => No TLS-SRP => Yes HTTP2 => Yes GSSAPI => Yes KERBEROS5 => Yes UNIX_SOCKETS => Yes PSL => Yes HTTPS_PROXY => Yes MULTI_SSL => No BROTLI => Yes ALTSVC => Yes HTTP3 => No UNICODE => No ZSTD => Yes HSTS => Yes GSASL => No Protocols => dict, file, ftp, ftps, gopher, gophers, http, https, imap, imaps, ldap, ldaps, mqtt, pop3, pop3s, rtmp, rtmpe, rtmps, rtmpt, rtmpte, rtmpts, rtsp, scp, sftp, smb, smbs, smtp, smtps, telnet, tftp Host => aarch64-unknown-linux-gnu SSL Version => OpenSSL/3.0.11 ZLib Version => 1.2.13 libSSH Version => libssh2/1.10.0 Directive => Local Value => Master Value curl.cainfo => no value => no value date date/time support => enabled timelib version => 2022.10 "Olson" Timezone Database Version => 2024.1 Timezone Database => internal Default timezone => UTC Directive => Local Value => Master Value date.default_latitude => 31.7667 => 31.7667 date.default_longitude => 35.2333 => 35.2333 date.sunrise_zenith => 90.833333 => 90.833333 date.sunset_zenith => 90.833333 => 90.833333 date.timezone => UTC => UTC dom DOM/XML => enabled DOM/XML API Version => 20031129 libxml Version => 2.9.14 HTML Support => enabled XPath Support => enabled XPointer Support => enabled Schema Support => enabled RelaxNG Support => enabled exif EXIF Support => enabled Supported EXIF Version => 0220 Supported filetypes => JPEG, TIFF Multibyte decoding support using mbstring => enabled Extended EXIF tag formats => Canon, Casio, Fujifilm, Nikon, Olympus, Samsung, Panasonic, DJI, Sony, Pentax, Minolta, Sigma, Foveon, Kyocera, Ricoh, AGFA, Epson Directive => Local Value => Master Value exif.decode_jis_intel => JIS => JIS exif.decode_jis_motorola => JIS => JIS exif.decode_unicode_intel => UCS-2LE => UCS-2LE exif.decode_unicode_motorola => UCS-2BE => UCS-2BE exif.encode_jis => no value => no value exif.encode_unicode => ISO-8859-15 => ISO-8859-15 fileinfo fileinfo support => enabled libmagic => 543 filter Input Validation and Filtering => enabled Directive => Local Value => Master Value filter.default => unsafe_raw => unsafe_raw filter.default_flags => no value => no value gd GD Support => enabled GD Version => bundled (2.1.0 compatible) FreeType Support => enabled FreeType Linkage => with freetype FreeType Version => 2.12.1 GIF Read Support => enabled GIF Create Support => enabled JPEG Support => enabled libJPEG Version => 6b PNG Support => enabled libPNG Version => 1.6.39 WBMP Support => enabled XBM Support => enabled WebP Support => enabled BMP Support => enabled TGA Read Support => enabled Directive => Local Value => Master Value gd.jpeg_ignore_warning => On => On gmp gmp support => enabled GMP version => 6.2.1 hash hash support => enabled Hashing Engines => md2 md4 md5 sha1 sha224 sha256 sha384 sha512/224 sha512/256 sha512 sha3-224 sha3-256 sha3-384 sha3-512 ripemd128 ripemd160 ripemd256 ripemd320 whirlpool tiger128,3 tiger160,3 tiger192,3 tiger128,4 tiger160,4 tiger192,4 snefru snefru256 gost gost-crypto adler32 crc32 crc32b crc32c fnv132 fnv1a32 fnv164 fnv1a64 joaat murmur3a murmur3c murmur3f xxh32 xxh64 xxh3 xxh128 haval128,3 haval160,3 haval192,3 haval224,3 haval256,3 haval128,4 haval160,4 haval192,4 haval224,4 haval256,4 haval128,5 haval160,5 haval192,5 haval224,5 haval256,5 MHASH support => Enabled MHASH API Version => Emulated Support iconv iconv support => enabled iconv implementation => glibc iconv library version => 2.36 Directive => Local Value => Master Value iconv.input_encoding => no value => no value iconv.internal_encoding => no value => no value iconv.output_encoding => no value => no value intl Internationalization support => enabled ICU version => 72.1 ICU Data version => 72.1 ICU TZData version => 2022e ICU Unicode version => 15.0 Directive => Local Value => Master Value intl.default_locale => no value => no value intl.error_level => 0 => 0 intl.use_exceptions => Off => Off json json support => enabled libxml libXML support => active libXML Compiled Version => 2.9.14 libXML Loaded Version => 20914 libXML streams => enabled mbstring Multibyte Support => enabled Multibyte string engine => libmbfl HTTP input encoding translation => disabled libmbfl version => 1.3.2 mbstring extension makes use of "streamable kanji code filter and converter", which is distributed under the GNU Lesser General Public License version 2.1. Multibyte (japanese) regex support => enabled Multibyte regex (oniguruma) version => 6.9.8 Directive => Local Value => Master Value mbstring.detect_order => no value => no value mbstring.encoding_translation => Off => Off mbstring.http_input => no value => no value mbstring.http_output => no value => no value mbstring.http_output_conv_mimetypes => ^(text/|application/xhtml\+xml) => ^(text/|application/xhtml\+xml) mbstring.internal_encoding => no value => no value mbstring.language => neutral => neutral mbstring.regex_retry_limit => 1000000 => 1000000 mbstring.regex_stack_limit => 100000 => 100000 mbstring.strict_detection => Off => Off mbstring.substitute_character => no value => no value mysqli MysqlI Support => enabled Client API library version => mysqlnd 8.3.8 Active Persistent Links => 0 Inactive Persistent Links => 0 Active Links => 0 Directive => Local Value => Master Value mysqli.allow_local_infile => Off => Off mysqli.allow_persistent => On => On mysqli.default_host => no value => no value mysqli.default_port => 3306 => 3306 mysqli.default_pw => no value => no value mysqli.default_socket => no value => no value mysqli.default_user => no value => no value mysqli.local_infile_directory => no value => no value mysqli.max_links => Unlimited => Unlimited mysqli.max_persistent => Unlimited => Unlimited mysqli.rollback_on_cached_plink => Off => Off mysqlnd mysqlnd => enabled Version => mysqlnd 8.3.8 Compression => supported core SSL => supported extended SSL => supported Command buffer size => 4096 Read buffer size => 32768 Read timeout => 86400 Collecting statistics => Yes Collecting memory statistics => No Tracing => n/a Loaded plugins => mysqlnd,debug_trace,auth_plugin_mysql_native_password,auth_plugin_mysql_clear_password,auth_plugin_caching_sha2_password,auth_plugin_sha256_password API Extensions => mysqli,pdo_mysql openssl OpenSSL support => enabled OpenSSL Library Version => OpenSSL 3.0.11 19 Sep 2023 OpenSSL Header Version => OpenSSL 3.0.11 19 Sep 2023 Openssl default config => /usr/lib/ssl/openssl.cnf Directive => Local Value => Master Value openssl.cafile => no value => no value openssl.capath => no value => no value pcre PCRE (Perl Compatible Regular Expressions) Support => enabled PCRE Library Version => 10.42 2022-12-12 PCRE Unicode Version => 14.0.0 PCRE JIT Support => enabled PCRE JIT Target => ARM-64 64bit (little endian + unaligned) Directive => Local Value => Master Value pcre.backtrack_limit => 1000000 => 1000000 pcre.jit => On => On pcre.recursion_limit => 100000 => 100000 PDO PDO support => enabled PDO drivers => sqlite, mysql pdo_mysql PDO Driver for MySQL => enabled Client API version => mysqlnd 8.3.8 Directive => Local Value => Master Value pdo_mysql.default_socket => no value => no value pdo_sqlite PDO Driver for SQLite 3.x => enabled SQLite Library => 3.40.1 Phar Phar: PHP Archive support => enabled Phar API version => 1.1.1 Phar-based phar archives => enabled Tar-based phar archives => enabled ZIP-based phar archives => enabled gzip compression => enabled bzip2 compression => disabled (install ext/bz2) Native OpenSSL support => enabled Phar based on pear/PHP_Archive, original concept by Davey Shafik. Phar fully realized by Gregory Beaver and Marcus Boerger. Portions of tar implementation Copyright (c) 2003-2009 Tim Kientzle. Directive => Local Value => Master Value phar.cache_list => no value => no value phar.readonly => On => On phar.require_hash => On => On posix POSIX support => enabled random Version => 8.3.8 readline Readline Support => enabled Readline library => 8.2 Directive => Local Value => Master Value cli.pager => no value => no value cli.prompt => \b \> => \b \> Reflection Reflection => enabled session Session Support => enabled Registered save handlers => files user Registered serializer handlers => php_serialize php php_binary Directive => Local Value => Master Value session.auto_start => Off => Off session.cache_expire => 180 => 180 session.cache_limiter => nocache => nocache session.cookie_domain => no value => no value session.cookie_httponly => Off => Off session.cookie_lifetime => 0 => 0 session.cookie_path => / => / session.cookie_samesite => no value => no value session.cookie_secure => Off => Off session.gc_divisor => 100 => 100 session.gc_maxlifetime => 1440 => 1440 session.gc_probability => 1 => 1 session.lazy_write => On => On session.name => PHPSESSID => PHPSESSID session.referer_check => no value => no value session.save_handler => files => files session.save_path => no value => no value session.serialize_handler => php => php session.sid_bits_per_character => 4 => 4 session.sid_length => 32 => 32 session.upload_progress.cleanup => On => On session.upload_progress.enabled => On => On session.upload_progress.freq => 1% => 1% session.upload_progress.min_freq => 1 => 1 session.upload_progress.name => PHP_SESSION_UPLOAD_PROGRESS => PHP_SESSION_UPLOAD_PROGRESS session.upload_progress.prefix => upload_progress_ => upload_progress_ session.use_cookies => On => On session.use_only_cookies => On => On session.use_strict_mode => Off => Off session.use_trans_sid => Off => Off SimpleXML SimpleXML support => enabled Schema support => enabled sodium sodium support => enabled libsodium headers version => 1.0.18 libsodium library version => 1.0.18 SPL SPL support => enabled Interfaces => OuterIterator, RecursiveIterator, SeekableIterator, SplObserver, SplSubject Classes => AppendIterator, ArrayIterator, ArrayObject, BadFunctionCallException, BadMethodCallException, CachingIterator, CallbackFilterIterator, DirectoryIterator, DomainException, EmptyIterator, FilesystemIterator, FilterIterator, GlobIterator, InfiniteIterator, InvalidArgumentException, IteratorIterator, LengthException, LimitIterator, LogicException, MultipleIterator, NoRewindIterator, OutOfBoundsException, OutOfRangeException, OverflowException, ParentIterator, RangeException, RecursiveArrayIterator, RecursiveCachingIterator, RecursiveCallbackFilterIterator, RecursiveDirectoryIterator, RecursiveFilterIterator, RecursiveIteratorIterator, RecursiveRegexIterator, RecursiveTreeIterator, RegexIterator, RuntimeException, SplDoublyLinkedList, SplFileInfo, SplFileObject, SplFixedArray, SplHeap, SplMinHeap, SplMaxHeap, SplObjectStorage, SplPriorityQueue, SplQueue, SplStack, SplTempFileObject, UnderflowException, UnexpectedValueException sqlite3 SQLite3 support => enabled SQLite Library => 3.40.1 Directive => Local Value => Master Value sqlite3.defensive => On => On sqlite3.extension_dir => no value => no value standard Dynamic Library Support => enabled Path to sendmail => /usr/sbin/sendmail -t -i Directive => Local Value => Master Value assert.active => On => On assert.bail => Off => Off assert.callback => no value => no value assert.exception => On => On assert.warning => On => On auto_detect_line_endings => Off => Off default_socket_timeout => 60 => 60 from => no value => no value session.trans_sid_hosts => no value => no value session.trans_sid_tags => a=href,area=href,frame=src,form= => a=href,area=href,frame=src,form= unserialize_max_depth => 4096 => 4096 url_rewriter.hosts => no value => no value url_rewriter.tags => form= => form= user_agent => no value => no value tokenizer Tokenizer Support => enabled xml XML Support => active XML Namespace Support => active libxml2 Version => 2.9.14 xmlreader XMLReader => enabled xmlwriter XMLWriter => enabled zlib ZLib Support => enabled Stream Wrapper => compress.zlib:// Stream Filter => zlib.inflate, zlib.deflate Compiled Version => 1.2.13 Linked Version => 1.2.13 Directive => Local Value => Master Value zlib.output_compression => Off => Off zlib.output_compression_level => -1 => -1 zlib.output_handler => no value => no value Additional Modules Module Name Environment Variable => Value HOSTNAME => c00d8fae2c93 PHP_INI_DIR => /usr/local/etc/php HOME => /root GODEBUG => cgocheck=0 PHP_LDFLAGS => -Wl,-O1 -pie PHP_CFLAGS => -fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 PHP_VERSION => 8.3.8 GPG_KEYS => 1198C0117593497A5EC5C199286AF1F9897469DC C28D937575603EB4ABB725861C0779DC5C0A9DE4 AFD8691FDAEDF03BDF6E460563F15A9B715376CA PHP_CPPFLAGS => -fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 PHP_ASC_URL => https://www.php.net/distributions/php-8.3.8.tar.xz.asc PHP_URL => https://www.php.net/distributions/php-8.3.8.tar.xz TERM => xterm PATH => /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin FRANKENPHP_CONFIG => "worker ./public/index.php" XDG_CONFIG_HOME => /config XDG_DATA_HOME => /data PHPIZE_DEPS => autoconf dpkg-dev file g++ gcc libc-dev make pkg-config re2c PWD => /srv CADDY_GLOBAL_OPTIONS => debug PHP_SHA256 => aea358b56186f943c2bbd350c9005b9359133d47e954cfc561385319ae5bb8d7 APP_RUNTIME => Runtime\FrankenPhpSymfony\Runtime PHP Variables Variable => Value $_SERVER['HOSTNAME'] => c00d8fae2c93 $_SERVER['PHP_INI_DIR'] => /usr/local/etc/php $_SERVER['HOME'] => /root $_SERVER['GODEBUG'] => cgocheck=0 $_SERVER['PHP_LDFLAGS'] => -Wl,-O1 -pie $_SERVER['PHP_CFLAGS'] => -fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 $_SERVER['PHP_VERSION'] => 8.3.8 $_SERVER['PHP_CPPFLAGS'] => -fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 $_SERVER['PHP_ASC_URL'] => https://www.php.net/distributions/php-8.3.8.tar.xz.asc $_SERVER['PHP_URL'] => https://www.php.net/distributions/php-8.3.8.tar.xz $_SERVER['TERM'] => xterm $_SERVER['PATH'] => /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin $_SERVER['FRANKENPHP_CONFIG'] => "worker ./public/index.php" $_SERVER['XDG_CONFIG_HOME'] => /config $_SERVER['XDG_DATA_HOME'] => /data $_SERVER['PHPIZE_DEPS'] => autoconf dpkg-dev file g++ gcc libc-dev make pkg-config re2c $_SERVER['PWD'] => /srv $_SERVER['CADDY_GLOBAL_OPTIONS'] => debug $_SERVER['APP_RUNTIME'] => Runtime\FrankenPhpSymfony\Runtime $_SERVER['PHP_SELF'] => $_SERVER['SCRIPT_NAME'] => $_SERVER['SCRIPT_FILENAME'] => $_SERVER['PATH_TRANSLATED'] => $_SERVER['DOCUMENT_ROOT'] => $_SERVER['REQUEST_TIME_FLOAT'] => 1718906225.8193 $_SERVER['REQUEST_TIME'] => 1718906225 $_SERVER['argv'] => Array ( ) $_SERVER['argc'] => 0 $_ENV['HOSTNAME'] => c00d8fae2c93 $_ENV['PHP_INI_DIR'] => /usr/local/etc/php $_ENV['HOME'] => /root $_ENV['GODEBUG'] => cgocheck=0 $_ENV['PHP_LDFLAGS'] => -Wl,-O1 -pie $_ENV['PHP_CFLAGS'] => -fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 $_ENV['PHP_VERSION'] => 8.3.8 $_ENV['GPG_KEYS'] => 1198C0117593497A5EC5C199286AF1F9897469DC C28D937575603EB4ABB725861C0779DC5C0A9DE4 AFD8691FDAEDF03BDF6E460563F15A9B715376CA $_ENV['PHP_CPPFLAGS'] => -fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 $_ENV['PHP_ASC_URL'] => https://www.php.net/distributions/php-8.3.8.tar.xz.asc $_ENV['PHP_URL'] => https://www.php.net/distributions/php-8.3.8.tar.xz $_ENV['TERM'] => xterm $_ENV['PATH'] => /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin $_ENV['FRANKENPHP_CONFIG'] => "worker ./public/index.php" $_ENV['XDG_CONFIG_HOME'] => /config $_ENV['XDG_DATA_HOME'] => /data $_ENV['PHPIZE_DEPS'] => autoconf dpkg-dev file g++ gcc libc-dev make pkg-config re2c $_ENV['PWD'] => /srv $_ENV['CADDY_GLOBAL_OPTIONS'] => debug $_ENV['APP_RUNTIME'] => Runtime\FrankenPhpSymfony\Runtime PHP License This program is free software; you can redistribute it and/or modify it under the terms of the PHP License as published by the PHP Group and included in the distribution in the file: LICENSE This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. If you did not receive a copy of the PHP license, or have any questions about PHP licensing, please contact license@php.net. ```

Relevant log output

No response

withinboredom commented 3 months ago

I'm pretty sure FrankenPHP isn't keeping old requests in memory anymore (we fixed that memory leak awhile ago), but even then it wasn't returning them to the wrong connection, just keeping them around in memory.

The only thing I can think of is threading shenanigans between PHP & go, or a bug in symfony (the more likely option, TBH), which could be an issue in either one (no idea without a way of reproducing it). It'd be great if you could figure out which of these is true:

  1. concurrent responses are being sent to the wrong connection
  2. old responses are being sent again
withinboredom commented 3 months ago

TBH, the most likely issue is the request/response is being stored in the container and not regenerated for every request. This would mean that if something were to take the request/response from the container, it would be a mismash between all the other requests/responses that did so.

dunglas commented 3 months ago

This can (and likely is) also be an application bug. Like a global state that isn't reset between requests.

EasyAdmin was suffering of a bug like this for instance.

dunglas commented 2 months ago

Closing for now as there is nothing we can do without more information. See this EasyAdmin path, which fixes a (likely) similar issue. If you think that it's not an issue in your app, feel free to reopen.

aleho commented 2 days ago

I can confirm this issue for a very simple setup here.

The assumption for me was that the reset interface should be enough to reset the context state. For good measure I also tagged the service with KernelEvents::FINISH_REQUEST. Yet after first visiting the page and changing data, some responses contained the correct, new data, some responses didn't.

I then completely eliminated the local variable and cache, always fetching the data from API. And still, some responses contain the old content, some the new. API responses are never cached, I also confirmed by completely flushing Redis that there's no way stale data could be fetched (even though caching was disabled completely).

EDIT: Oh, and everything, caching and local variable, works perfectly fine if I disable worker mode. EDIT2: Forgot to mention, the response(s) containing wrong data are predictable. If one response was bad, it was always delivered after 7 good responses. Even after reloading for 30 times the 8th response was bad.

dunglas commented 2 days ago

This is probably a bug in the Symfony Cache. If you have a simple reproducer, could you publish it? I'll take a look.

withinboredom commented 2 days ago

If one response was bad, it was always delivered after 7 good responses. Even after reloading for 30 times the 8th response was bad.

This is likely due to the workers. ie, you have eight workers and they deliver responses in round-robin order, so you end up with one "corrupted" worker.

If you are up for digging deeper, search for accesses to static variables (this may even include properties in your objects in your service container, as most services are not 'volatile', meaning they exist beyond a single request). Most likely there is a static variable that needs to be cleared/reset and isn't being reset on some code path.

aleho commented 2 days ago

This is probably a bug in the Symfony Cache. If you have a simple reproducer, could you publish it? I'll take a look.

I completely eliminated everything Symfony related, except for a REST API call (not even some obscure Doctrine caching was possible).

This is likely due to the workers. ie, you have eight workers and they deliver responses in round-robin order, so you end up with one "corrupted" worker.

That's exactly what I thought and the reason I wanted to mention it.

If you are up for digging deeper, search for accesses to static variables (this may even include properties in your objects in your service container, as most services are not 'volatile', meaning they exist beyond a single request). Most likely there is a static variable that needs to be cleared/reset and isn't being reset on some code path.

There's not a single static variable anywhere. I was able to reproduce the problem even after changing the code to do an API call with every access to the getter (instead of saving the context locally). The object returned is an instance created from JSON, no static variables, etc. It's a shared Symfony service, but completely stateless.

I'll try to come up with a reproducer as soon as possible.

dunglas commented 1 day ago

Would you be able to share your project? A reproducer will help a lot to find the underlying issue.

This is interesting that it occurs after 500 errors. The Symfony error handling system is quite complex. Maybe some states aren't properly reset when it is triggered?

aleho commented 1 day ago

Unfortunately I can't share that project.

I'll try to write a reproducer in a pulic repo based on symfony/docker though. This way either I'll find whats wrong with my project and report back, or I'll have a reproducer ready that hopefull helps to narrow down the problem.