Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:89217 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 63944 invoked from network); 15 Nov 2015 00:03:33 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 15 Nov 2015 00:03:33 -0000 Authentication-Results: pb1.pair.com header.from=rasmus@lerdorf.com; sender-id=pass Authentication-Results: pb1.pair.com smtp.mail=rasmus@lerdorf.com; spf=pass; sender-id=pass Received-SPF: pass (pb1.pair.com: domain lerdorf.com designates 209.85.213.42 as permitted sender) X-PHP-List-Original-Sender: rasmus@lerdorf.com X-Host-Fingerprint: 209.85.213.42 mail-vk0-f42.google.com Received: from [209.85.213.42] ([209.85.213.42:33433] helo=mail-vk0-f42.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 15/52-38992-3DBC7465 for ; Sat, 14 Nov 2015 19:03:32 -0500 Received: by vkbs1 with SMTP id s1so10931769vkb.0 for ; Sat, 14 Nov 2015 16:03:29 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lerdorf_com.20150623.gappssmtp.com; s=20150623; h=content-type:mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=rcfDSQ443IZkUEUyrlD/uIDXffyotMlW3+HcrKGDkEI=; b=BlHtZvkb4LtJor01qE7IWt4anHOvpDHroNFmXj9a10+PhV46t7vg+0WdhtI1/2AybS Z/RSQrGF4qYgEWaplEXPGxX2JYt2W5xbQiUArORbmN0J4/ZbkJgCMXHtXddjlHf7E1yD MhvADEKlKcYq+VRAxj9Whe/VJW/YcmfFgOr6gor8j2D+mRvenvlFA3ekzzWjQCoiiF22 jgm2Uz87CZML0BVfD8n1urMEQO2ilQJswMtINjUvpFaUxLMiOLNRZbIF4g7jlT+r0ZOb 6wqp9vpwGHDMZCQ0BJgPO2wpC/v+gXakeoYhWYkUxVpzdEBzzAuY8OaEGFoIdxWTbPqn SHmA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:content-type:mime-version:subject:from :in-reply-to:date:cc:content-transfer-encoding:message-id:references :to; bh=rcfDSQ443IZkUEUyrlD/uIDXffyotMlW3+HcrKGDkEI=; b=j01hSv+ZZQkcxky1p6eSHVZnU8NfvSQoOab3vh+NkYaZ7knshwrwVlgAlbtYzTBMOa 2NGbxEJ/r2PBmSaAofZTxg7lotGZvHMMZMZXgNj7Mr+UB2Xh+VDc5JiIrU3NT425Wzq4 ibVNerrSEiAI9zJJ7cRuZIN7+GVHLcPYT1CT8ZpyVmUeaEdbELU/5EHqX1NWPO5Pujn9 VRzVGCIMzCy/U3gOmGHcDvKszo+vAIK2Wa/mUb/hW2G0eYhtBdzP0jII/T01JEAfRHnJ FT1giE9y7BQJJPZjHOszvs+vnJvVESX0pAVAFvhAVQwTfRvkmjMeE0ye/h1GP8HjeOpc mclg== X-Gm-Message-State: ALoCoQkwHmxpbU72GgZlh7CeVBnbsL0M8UqG6DgN0Xock+yuGgqWaZSWk0jNFlhP2WfzioVALKq+ X-Received: by 10.31.9.4 with SMTP id 4mr5520678vkj.120.1447545808935; Sat, 14 Nov 2015 16:03:28 -0800 (PST) Received: from [10.10.10.2] (static-72-69-215-68.nycmny.fios.verizon.net. [72.69.215.68]) by smtp.gmail.com with ESMTPSA id o194sm6032219vkd.27.2015.11.14.16.03.25 (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Sat, 14 Nov 2015 16:03:26 -0800 (PST) Content-Type: multipart/signed; boundary=Apple-Mail-49541D5D-6F26-4C4E-8862-1555B7CFFB8B; protocol="application/pkcs7-signature"; micalg=sha1 Mime-Version: 1.0 (1.0) X-Mailer: iPad Mail (13A452) In-Reply-To: <54.63.62946.75D96465@pb1.pair.com> Date: Sat, 14 Nov 2015 19:03:24 -0500 Cc: internals@lists.php.net Content-Transfer-Encoding: 7bit Message-ID: References: <12.A1.62946.CB756465@pb1.pair.com> <564659DF.5070904@php.net> <77.62.62946.F6D56465@pb1.pair.com> <80ED4CA4-1548-48B5-A94B-B3FA1377C755@lerdorf.com> <54.63.62946.75D96465@pb1.pair.com> To: Stephen Coakley Subject: Re: [PHP-DEV] Support for writing and executing compiled opcode From: rasmus@lerdorf.com (Rasmus Lerdorf) --Apple-Mail-49541D5D-6F26-4C4E-8862-1555B7CFFB8B Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: quoted-printable On Nov 13, 2015, at 21:32, Stephen Coakley wrote: >=20 >> On 11/13/2015 05:46 PM, Rasmus Lerdorf wrote: >>> On Nov 13, 2015, at 17:00, Stephen Coakley wrote= : >>>=20 >>>>> On 11/13/2015 03:45 PM, Sebastian Bergmann wrote: >>>>> On 11/13/2015 04:35 PM, Stephen Coakley wrote: >>>>> This is quite similar to Python's ability to execute Python scripts >>>>> compiled to bytecode as *.pyc files. The feature has seen great >>>>> success in >>>>> Python, mostly for distributing releases of software or deploying to a= >>>>> server. >>>>=20 >>>> Correct me if I'm wrong, but this should already be possible with OpCa= che >>>> and its filesystem backend in PHP 7.0. >>>>=20 >>>> See http://talks.php.net/froscon15#/php7pcache1 and following for >>>> details. >>>=20 >>> That's great! That's about halfway toward what I'm looking for. That mea= ns that the engine is likely already capable of doing these things -- the ne= xt step is to be able to execute any given .php.bin file like in that talk. T= he idea would be to be able to bypass the caching mentality by executing an a= lready compiled file, instead of checking if the original .php file has a co= rresponding bin file in the cache >>=20 >> You could simply deploy both the .php and the .bin files to achieve this t= oday. >>=20 >> -Rasmus >=20 > Would the bin files not have to be placed in the special OPcache file stor= e location though? That seems sub-optimal. But that is just a matter of copying the .bin files into a configurable dire= ctory. However, as others have said, this is completely pointless. If you ar= e worried about initial compile latency on initial requests after a deeply o= f new code then simply run a couple of warmup requests before flipping your s= ymlink to the new code. Beyond that I can't picture what possible use this c= ould be. Hiding source code? No chance, getting PHP code from bytecode is tr= ivial. -Rasmus= --Apple-Mail-49541D5D-6F26-4C4E-8862-1555B7CFFB8B Content-Type: application/pkcs7-signature; name=smime.p7s Content-Disposition: attachment; filename=smime.p7s Content-Transfer-Encoding: base64 MIAGCSqGSIb3DQEHAqCAMIACAQExCzAJBgUrDgMCGgUAMIAGCSqGSIb3DQEHAQAAoIIGWTCCBlUw ggU9oAMCAQICAlhvMA0GCSqGSIb3DQEBCwUAMIGMMQswCQYDVQQGEwJJTDEWMBQGA1UEChMNU3Rh cnRDb20gTHRkLjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmluZzE4 MDYGA1UEAxMvU3RhcnRDb20gQ2xhc3MgMiBQcmltYXJ5IEludGVybWVkaWF0ZSBDbGllbnQgQ0Ew HhcNMTQxMTE1MTIwODQwWhcNMTYxMTE1MDIwMDExWjByMQswCQYDVQQGEwJVUzETMBEGA1UECBMK Q2FsaWZvcm5pYTESMBAGA1UEBxMJU3Vubnl2YWxlMRcwFQYDVQQDEw5SYXNtdXMgTGVyZG9yZjEh MB8GCSqGSIb3DQEJARYScmFzbXVzQGxlcmRvcmYuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A MIIBCgKCAQEAnfzDSNz3/ljL2v7NT2zqMzN6SXf8Qzb7nvutQXWrYlhgVe3IrnkhcwCswDTCLMQz UmzT3YmzaQ+LwuoWYdCwuue4ZWhqYvVSI0b93togBNXt/0Pk4HC1PM/WlxdmY2V5jKT90k/1vh4X DF8P8hEflN32Cfum9cUT21roqdhQyOdvZcVSpd+mFFVNwJ963GbEL1UiH1CD1fybS+mnVNAZ5wAV SpJs1y+ZS+Nw8GWhP/KNZfbXsvCcg5K+9aM/a6FCLMG3aOcbUUfgkshq24WGOa6hmJBmJezCEPYs PAjFGJDlm/3itm5qg90brivL0GBSfp5K0h3D4AYc8xE2E0UAwwIDAQABo4IC2DCCAtQwCQYDVR0T BAIwADALBgNVHQ8EBAMCBLAwHQYDVR0lBBYwFAYIKwYBBQUHAwIGCCsGAQUFBwMEMB0GA1UdDgQW BBRdGtlis2LEefYTwONK6fgMt+ZNZTAfBgNVHSMEGDAWgBSuVYNv7DHKufcd+q9rMfPIHeOsuzAd BgNVHREEFjAUgRJyYXNtdXNAbGVyZG9yZi5jb20wggFMBgNVHSAEggFDMIIBPzCCATsGCysGAQQB gbU3AQIDMIIBKjAuBggrBgEFBQcCARYiaHR0cDovL3d3dy5zdGFydHNzbC5jb20vcG9saWN5LnBk ZjCB9wYIKwYBBQUHAgIwgeowJxYgU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwAwIB ARqBvlRoaXMgY2VydGlmaWNhdGUgd2FzIGlzc3VlZCBhY2NvcmRpbmcgdG8gdGhlIENsYXNzIDIg VmFsaWRhdGlvbiByZXF1aXJlbWVudHMgb2YgdGhlIFN0YXJ0Q29tIENBIHBvbGljeSwgcmVsaWFu Y2Ugb25seSBmb3IgdGhlIGludGVuZGVkIHB1cnBvc2UgaW4gY29tcGxpYW5jZSBvZiB0aGUgcmVs eWluZyBwYXJ0eSBvYmxpZ2F0aW9ucy4wNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5zdGFy dHNzbC5jb20vY3J0dTItY3JsLmNybDCBjgYIKwYBBQUHAQEEgYEwfzA5BggrBgEFBQcwAYYtaHR0 cDovL29jc3Auc3RhcnRzc2wuY29tL3N1Yi9jbGFzczIvY2xpZW50L2NhMEIGCCsGAQUFBzAChjZo dHRwOi8vYWlhLnN0YXJ0c3NsLmNvbS9jZXJ0cy9zdWIuY2xhc3MyLmNsaWVudC5jYS5jcnQwIwYD VR0SBBwwGoYYaHR0cDovL3d3dy5zdGFydHNzbC5jb20vMA0GCSqGSIb3DQEBCwUAA4IBAQDGlvK1 mwlJw04/3SXtCTScuJwNxhr6U6UeFjtzpArczqx9IeXjHwg8TG0wh45nbLb/XiemCmkkM0Smggxg xIyJsXCe6PVB7CsBVLT7i0EieCyxvEQO0HcHtLWknnAcwlgrzKopQxkRH+tMhZ0GaCpBuIQXYEGJ 25dQQAY76iT/1k0ckui2BAPV0HP3bcYnAQ3/0js86d5qrzWJWBBHcc+yj7CBBkmX2YoEg6/4o52Z nJPXDYnJAvTO3hVXJwzF5GkEskf4OK7oD7T9bZOLFt8B5g25UEGmMbS9cCq73DzdTKRdU69FID4J qkPf0YCIk0pJDDWRj/MxiPkhY6PZoao+MYIDbDCCA2gCAQEwgZMwgYwxCzAJBgNVBAYTAklMMRYw FAYDVQQKEw1TdGFydENvbSBMdGQuMSswKQYDVQQLEyJTZWN1cmUgRGlnaXRhbCBDZXJ0aWZpY2F0 ZSBTaWduaW5nMTgwNgYDVQQDEy9TdGFydENvbSBDbGFzcyAyIFByaW1hcnkgSW50ZXJtZWRpYXRl IENsaWVudCBDQQICWG8wCQYFKw4DAhoFAKCCAa0wGAYJKoZIhvcNAQkDMQsGCSqGSIb3DQEHATAc BgkqhkiG9w0BCQUxDxcNMTUxMTE1MDAwMzI0WjAjBgkqhkiG9w0BCQQxFgQU0N7O9emmFbYqFmUp AfCjpqXbEpUwgaQGCSsGAQQBgjcQBDGBljCBkzCBjDELMAkGA1UEBhMCSUwxFjAUBgNVBAoTDVN0 YXJ0Q29tIEx0ZC4xKzApBgNVBAsTIlNlY3VyZSBEaWdpdGFsIENlcnRpZmljYXRlIFNpZ25pbmcx ODA2BgNVBAMTL1N0YXJ0Q29tIENsYXNzIDIgUHJpbWFyeSBJbnRlcm1lZGlhdGUgQ2xpZW50IENB AgJYbzCBpgYLKoZIhvcNAQkQAgsxgZaggZMwgYwxCzAJBgNVBAYTAklMMRYwFAYDVQQKEw1TdGFy dENvbSBMdGQuMSswKQYDVQQLEyJTZWN1cmUgRGlnaXRhbCBDZXJ0aWZpY2F0ZSBTaWduaW5nMTgw NgYDVQQDEy9TdGFydENvbSBDbGFzcyAyIFByaW1hcnkgSW50ZXJtZWRpYXRlIENsaWVudCBDQQIC WG8wDQYJKoZIhvcNAQEBBQAEggEAJFHuSBxqIpp8Nm94SkTtqE5P2MaSCp5opTaBhZlkmAYDlszO yP0lYeehrhp1EszhIMAETDmTJTZOsa2H8KVpmVFbzwXen48MaiDahwpV9Ezca/8ghPA/sMjstMPn yvz0XUsixyVhxObhX83GAHejIx8uDzrHVJPawLJiQcW861u/jmFPR/dh070Oi0pM13MDg8qxnMsQ Tbnd5pFo9uVXvZ8Vn4SoKNEIygksgfYDc20yS8qOwkaQi6uIuK12QHKO9HusJGHmnDKkoPL3BW1z CcXhYEW5QBfKhlAKHIIH1m4Y6fxzJYa8Zl3Oi3cFERmcWGz4PcQv3hf50c5qkoebGwAAAAAAAA== --Apple-Mail-49541D5D-6F26-4C4E-8862-1555B7CFFB8B--