Why I Don't Use Debian's PHP Packages
From their 4.3.10-3 changelog:
Enable Zend Thread Safety for all SAPIs, meaning that our modules are now compiled for ZTS APIs as well.
I couldn't believe that they did this, so I checked it in the source... their rules indeed include the --enable-experimental-zts switch. Tip: Compile your own PHP packages for Debian!
Comments
Could your explain why this is a "bad" thing? Because I updated my php setup using apt today :)
Is it because its "experimental" or some "zts" specific thing?
This setting is only there for developers that want to build a ZTS build to test with without having to use a threaded webserver.
ZTS is going to slow down Apache (1.3) a lot and simply not meant to be used there - it also may cause problems with shared objects. Using ZTS in a CLI doesn't make sense at all - it also prohibits some extensions from being enabled there.
or get them from dotdeb.org :)
When PHP is compiled with thread-safety support it ends up performing numerous (slow) operations to ensure thread-safety. Because PHP in most cases runs in a non-threaded environment these are completely pointless.
"When [Perl] is compiled with thread-safety support it ends up performing numerous operations to ensure thread-safety."
"Because Perl in most cases runs in a non-threaded environment these are completely pointless."
But wait. Perl is generally always compiled threadsafe now, and has been for several years. This, among other things, facilitated mod_perl Just Working on threaded webservers. I have yet to hear anyone complain that mod_perl on apache 1.3 is "slow", so they should recompile libperl.
Seriously. If the concern is that it's "a bit slower", so what? So is compiling in every extension under the sun, which distributions do. If you want it as fast as possible, do Linux From Scratch, and compile everything the way you want it.
ZTS /does/ work, despite scare-mongering to the contrary. Yes, it can expose problems in underlying libraries, and we warn against that. Of course, it will only do so when ALSO run in a threaded webserver, so if you aren't prepared to deal with that, run apache1.3 or apache2-mpm-prefork. If you do want to take the plunge, hey, Debian won't stop you and so "no, that's bad, you bad, bad PHP user, don't dare try to use PHP threaded." Seriously, Derick. This debate has been going on for years. I made a decision to distribute the software in a certain way. It works. Get over it.
About two years ago I mailed the debian php package maintainers to ask for the addition of a pcntl-enabled CLI-php binary in the package ... I was told that php was only a web scripting language and was meant for nothing else ... When I pointed out that the source dist also built the CLI sapi by default, I got about the same response - something in the lines of "I know better than core developpers how PHP should be used". Months after that, the CLI-php (and with pcntl support) was silently added to the debian php4 package ... So I think it's just a question of time before the packager realizes he's just wrong by doing this ...
Life Line
I walked 9.7km in 5h29m12s
Updated a gate
Staring Contest with a Squirrel
On my walk on the weekend, I sat down on a tree branch of a tree that had fallen over some time ago. Just listening to the birds.
Then after hearing rustling in the foliage above me, I looked up, and saw this chap staring at me.
I walked 3.0km in 41m38s
I walked 1.1km in 12m20s
Bluebell Carpet
I had a lovely walk on Hampstead Heath yesterday, finding all the nooks and crannies away from the busy paths.
This field of bluebells under the colourful tree was a stand-out quiet spot.
I walked 2.3km in 21m51s
Fix paths
Created a memorial
Created a bench
@Edent Seems like my Android stopped sending coordinates to @openbenches as well, which is surprising as I haven't updated anything as far as I'm aware. Could it be a problem with the reader in your side after the latest changes and the addition of the warning?
I walked 5.8km in 2h15m45s
I walked 1.7km in 17m46s
I walked 4.8km in 1h39m40s
Add the new Queen Elizabeth II garden.
Updated a bench and a crossing; Deleted 2 kerbs
Created 3 gates and a waste_basket
Created 6 benches
Created a bench; Updated 4 benches
Created 2 benches and a bicycle_parking; Updated a telephone and a waste_basket
I walked 10.3km in 2h34m24s
Updated 2 restaurants and an address; Confirmed a restaurant and a fitness_centre
Updated a restaurant
Merged pull request #1077
PHP 8.6: Add new PHP version to Linux jobs for GitHub Actions



Shortlink
This article has a short URL available: https://drck.me/widud-php-p-3wm