36

This is an issue I've been having for a long time. I want to run PHP applications on my windows computer and it has a terribly high load time, around 10-25 seconds. I have tried many things:

  • First I tried a simple XAMPP installation
  • I read WAMP might be faster, so I tried WAMP, too. It gave me the same results
  • Then I installed an nginx server with PHP, but it did not help either
  • Finally, I installed an Ubuntu 11.10 in VirtualBox and I shared my windows files containing my project, but the result was even worse: over 22 second load time each time.

UPDATE: I have even tried APC - it improved a bit but still 6-8 sec/page

I uploaded my files to a linux server(shared hosting), on which it runs in around 300-500 ms. On the XAMPP installation I tried to run other (i.e. not Symfony2) applications as well(e.g. phpmyadmin), which too were slower than on the shared hosting, but not extremely slow, with 2-3 sec load time. Until I change to Linux as the main OS, how could I improve performance? I have a laptop with i7 CPU, 4 GB RAM, 5400RPM HDD, Win7 x64.

Thank you for your help!

UPDATE2: For some mysterious reason my Symfony routing didn't work with fcgid (it gave me a 404 error for everything) so I went back for using PHP as a module. Now, it has become the worst ever (worse than it used to be as a module): app mode 20-25 sec, and in dev mode, over 30s every time, so I get a timeout error, and it's the same with or without APC enabled.

Here you can see this error. This is reproduceable: each time it reaches a different point of execution within 30s:

enter image description here

halfer
  • 19,824
  • 17
  • 99
  • 186
David Frank
  • 5,918
  • 8
  • 28
  • 43
  • If APC gave you no improvement, I'd suspect it was misconfigured. I can't think that having a PHP accelerator would make no difference at all with any application, even if PHP processes stayed in memory via FastCGI. Does APC offer a web application to peek into the opcode cache? We had this for eAccelerator, which I guess would have been useful if pages weren't caching. – halfer Mar 24 '12 at 19:44
  • Now I'm going to retry with APC, and tell you the results. – David Frank Mar 24 '12 at 19:48
  • Results: it is better now, but still 6-8 sec/page. Any idea? – David Frank Mar 24 '12 at 20:12
  • 1
    What did you change? If APC offered an improvement, then you may wish to edit your post to reflect that, and save on confusion `:)` – halfer Mar 24 '12 at 20:25
  • I have provided two other ideas on my answer below. – halfer Mar 24 '12 at 20:26
  • I enabled the apc extension, and changed symfony2 autoload according to this: http://symfony.com/doc/current/book/performance.html – David Frank Mar 24 '12 at 20:27
  • 1
    Do you measure Symfony2 performance in dev mode or in prod mode? What does profiler say? – Vladislav Rastrusny Mar 24 '12 at 20:36
  • I see the load time in dev mode, but it isn't faster in prod mode either. – David Frank Mar 24 '12 at 21:03
  • Hmm... screenshot the profiler (especially any timings data) and paste it into your question. – halfer Mar 25 '12 at 08:32
  • I updated the question, please have a look. Now it's even worse. – David Frank Mar 25 '12 at 13:19
  • 1
    Hmm. Is this action empty? - to check raw performance you should just be serving a _hello world_ string. Personally I'd persist with fcgid. It worked for me pretty easily, but it's been a few years since I set that up on Windows. – halfer Mar 25 '12 at 13:27
  • (Aside: if you get stuck, then grab yourself a copy of VirtualBox, install it on your Windows machine, and install a LAMP server inside it. That will get you up and running pretty quickly) – halfer Mar 25 '12 at 13:28
  • As I wrote above ubuntu in virtualbox wasn't better. I made a benchmark test(source: http://frankdavid.hu/files/benchmark.php.txt), it runs in 600-800ms while on the linux server it runs in less than 1ms! – David Frank Mar 25 '12 at 13:41
  • 2
    @DavidFrank - I've run out of things to suggest, but ~600ms isn't too bad for what I presume is a dev machine. It is quite possible to dev on Windows and deploy on Linux (surely "ubuntu in virtualbox wasn't better" can't be the case, if you're getting 600ms instead of 30s!). – halfer Mar 25 '12 at 18:20
  • No, you must have misunderstood me. 600 ms is the runtime of the test script on windows while on the linux hosting(remote machine) its under 1ms. I did not run the benchmark on my virtualbox ubuntu. Ubuntu runs my symfony2 project in 20-25 sec. – David Frank Mar 26 '12 at 01:57
  • Have you installed and not running Adobe ColdFusion service on the same machine? – Seybsen Apr 02 '12 at 15:24
  • @DavidFrank - well, I was just repeating what you said: "As I wrote above ubuntu in virtualbox wasn't better. I made a benchmark test... it runs in 600-800ms while on the linux server it runs in less than 1ms". However, I am now properly confused: "Ubuntu runs my symfony2 project in 20-25 sec". I thought it was Windows that was the very slow one? – halfer Apr 02 '12 at 16:01
  • Allow me to repeat my previous suggestion: "screenshot the profiler (especially any timings data) and paste it into your question" (from the machine with 20-25sec timings). – halfer Apr 02 '12 at 16:03
  • Now it loads in 10-15s again, but I dont see any timings data in my profiler, although I checked all the pages multiple times. I only see these lines in the log: `Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\ProfilerListener::onKernelRequest".` `Notified event "kernel.request" to listener "Symfony\Bundle\FrameworkBundle\EventListener\RouterListener::onEarlyKernelRequest".` – David Frank Apr 03 '12 at 09:52
  • 1
    Did you find solution? I have some problem. PHP work fine in my Ubuntu, but pretty slow on Windows. – nucleartux Jul 21 '12 at 17:50
  • No, I did not. Even php5.4 is so slow on my laptop. – David Frank Jul 21 '12 at 18:17
  • @nucleartux - paste your screenshot of your timing profile into a link in the comments - otherwise there's nothing much fresh to go on. If you are a confident debugger, try isolating the part of Symfony2 that is causing the slow-down. Just guessing - could be a file system call that isn't cached on Windows? – halfer Jul 23 '12 at 14:11
  • I got fed up with the whole thing and removed the webserver from my computer. Maybe later I'll reinstall it, then I'll send screenshots. All I can tell you is everything is slow. I tried with different projects, different sf versions(2.0, 2.1), different php versions(5.3.* TS, NTS, 5.4), it was slow in the console(running sf commands) and in the browser, too. So it seems to me to be a common issue. Edit: I've just noticed your message wasn't addressed to me, whatever... – David Frank Jul 23 '12 at 17:28
  • I have the same problem: symfony2 project load time is 8 to 15 seconds on wamp windows and less than 500ms on my remote server running ubuntu (a very basic 2€/month solution). I've tried many php config changes for no result... – Sébastien Jan 27 '15 at 13:29

10 Answers10

27

Update:

Since PHP 5.5 has now integrated the PHP OPCache, this speeds up the execution time. In my setup a full request with database access takes 180ms now.

Steps:

  1. Update to the latest php version
  2. Enable OPCache
  3. Disable xdebug
  4. Set realpath_cache_size = 2M as DemonTPx mentioned

php.ini settings:

realpath_cache_size = 2M
[XDebug]
xdebug.profiler_enable = 0
xdebug.remote_enable = 0
[opcache]
zend_extension = "C:\xampp18\php\ext\php_opcache.dll"
opcache.enable = 1
opcache.enable_cli = 0
opcache.memory_consumption = 128
opcache.interned_strings_buffer = 8
opcache.max_accelerated_files = 4000

Why is Windows slower than Unix?

As discussed here, PHP is very slow in file_exists, and filemtime() on Windows. since Symfony2 is using these functions in dev mode a lot. we won't get under 700ms (in <= 5.4) on Windows. PHP 5.5 allows now 180ms.

A solution could be WinCache which was developed by microsoft to solve this problem on IIS. But as it only works on several Windows versions and also only with IIS it's no solution for me.

Alternative

Also a nice solution I can recommend is to have a Linux Virtual Machine on Virtualbox. This is easy to setup and is also more like the production environment.

Community
  • 1
  • 1
Simon Fakir
  • 1,712
  • 19
  • 20
  • I dropped from 10s to 2.5s with those settings. Disabling xDebug made a noticeable improvement, as well as setting realpath_cache_size to 2M. – Jean Apr 12 '14 at 16:29
  • Hi Jean, still - 2.5 seconds is to slow for development. You may try OPCache in PHP5.5 which should do it faster. – Simon Fakir Apr 22 '14 at 11:45
  • That helped me a lot! Lowered loading time from ~500ms to ~50ms. Thanks! – Jazi Jan 25 '16 at 19:45
20

I have the exact same problem. Setting the following in php.ini increased the performance for me from ~800ms to ~300ms:

php.ini:

realpath_cache_size = 2M

Still not the ~100ms I get from a unix machine, but it makes a difference at least

Bert Hekman
  • 8,987
  • 3
  • 21
  • 14
9

I had a similar problem with symfony 1 for a time on XP and Server 2003. The solution was to install a PHP accelerator (eAccelerator for us, APC might be a better bet these days) plus FastCGI/fcgid.

Addendum: it's been ages since I've used Apache on Windows. I have generally been of the view that its performance has been getting steadily better, rather than worse; however as with most unusual set-ups, good results are not guaranteed. As per my earlier comment, I recommend asking your question at Apache Lounge, where I previously have received some great expert advice.

If memory serves correctly, they can offer you a free Apache binary compiled with better tools than the standard one offered on the Apache website.

halfer
  • 19,824
  • 17
  • 99
  • 186
  • I have tried APC but didnt help, and with fastCGI it became even slower. – David Frank Mar 24 '12 at 19:41
  • I upgraded to fcgid, but didnt help :( I even got an NTS version of PHP – David Frank Mar 24 '12 at 21:33
  • Did you verify that it was _actually_ installed? You should have a Symfony toolbar that lets you know whether it is working (at least, symfony 1 had one). I believe also that either php or apache (I forget which) should show that fcgid is correctly installed if you list modules at the command line. – halfer Mar 24 '12 at 21:41
  • Symfony2 has a toolbar, too, and yes, after I had activated the APC, symfony2 indicated it. About the fcgid: in the task manager, I see php-cgi.exe, althought, I didnt see it earlier. – David Frank Mar 24 '12 at 21:44
3

Wow, After trying many different things, I've finally succeeded to move from a 15s execution time to a 3s exec time on windows7 with wamp.

How to install wincache extension : http://us2.php.net/manual/en/wincache.installation.php

Where to download the wincache dll: http://sourceforge.net/projects/wincache/

My php.ini config change:

[PHP]
realpath_cache_size = 2M
extension=php_wincache.dll
; XDEBUG Extension
;zend_extension = "C:/Net Generation/wamp/bin/php/php5.5.12/zend_ext/php_xdebug-2.2.5-5.5-vc11.dll"
;
[xdebug]
xdebug.remote_enable = off
xdebug.profiler_enable = Off
xdebug.profiler_enable_trigger = off
xdebug.profiler_output_name = cachegrind.out.%t.%p
xdebug.profiler_output_dir = "C:/Net Generation/wamp/tmp"
xdebug.show_local_vars=0
xdebug.max_nesting_level=200

[opcache]
zend_extension = "C:/Net Generation/wamp/bin/php/php5.5.12/ext/php_opcache.dll"
opcache.enable = 1
opcache.enable_cli = 0
opcache.memory_consumption = 128
opcache.interned_strings_buffer = 8
opcache.max_accelerated_files = 4000
Sébastien
  • 5,263
  • 11
  • 55
  • 116
1

Some years ago i had the same problem. Which antivirus software do you run in the background? Try to deactivate it for dev purposes or change it. It also could be some indexing services running in the background. Symfony 2 consists of >15000 files with vendors :) Also try to do it the classic way by reinstalling Windows from the scratch. My sites takes usually from 100-500ms and my laptop is slower than yours. (Intel C2D P8600)

Vincent
  • 11
  • 1
1

Just a guess (and probably not the right one), but it could be MySQL related. Seeing how you mentioned PhpMyAdmin and Symfony 2 as PHP applications you tested, both rely on MySQL (assuming you have MySQL set up in Symfony 2). You did not mention this in your post, but in your VirtualBox setup, did you by any chance let the script running on Ubuntu connect to the MySQL server on your Windows host machine?

You could check out PHP Benchmark for some performance testing scripts, and see if these scripts perform better timewise.

Another thing you could try is use Xdebug and see if you find (a) certain (group of) function(s) that are taking up too much time.

I'm definately gonna keep this question as a favorite, because I am too curious to see what it was now :) good luck !

Wouter
  • 833
  • 6
  • 13
  • omg Wouter, thank you so much. I was banging my head against the wall with a similar problem and you are absolutely right - my remote MySQL connection was the bottleneck. – Leng Jul 06 '14 at 16:20
1

i think you have a problem with caching mechanism. check app\cache directory. there has to be a folder named dev. if it does not exist or if it is empty check folder permissions. when i delete dev and prod directories under app\cache directory it takes 18 seconds to load the page but after that it takes only 500 ms.

Ekrem
  • 483
  • 2
  • 16
0

Check your computer random access memory, RAM using http://oca.microsoft.com/en/windiag.asp or run the memory test application shipped with your Ubuntu CD booting option.

In both cases choose what know as extra or deep test - I don't remember exactly- How ever, choose the test with more longtime these kind of tests has no end, you just wait till the test finish two phases and any problems with your RAM, commonly, shown.

Also, Check your hard drive with any mean of checking. after that try to perform disk defragmentation

I bit, your problem is hardware related problem.

0

My pages were taking 20 seconds to execute. I installed fast cgi, increased memory limits, everything, not working. Then started looking at timeline and noticed symfony firewall module was taking up most of it time. Turns out having "localhost" in my config for doctrine is what was causing issues. Changing it to 127.0.0.1 fixed the problem. Not sure why, but it's described here:

http://12wiki.blogspot.ca/2012/11/why-does-symfony-2-firewall-take-so.html

Alex
  • 51
  • 1
  • 5
-1

Page loading time is depends on the CSS + JS + Image loading time also. I had the same problem in CakePHP and solved the problem by using mod_expires in htaccess.

Have you tried "ExpiresByType" in your server htaccess file for CSS, JS and images? Check this page.

halfer
  • 19,824
  • 17
  • 99
  • 186
Kumar
  • 237
  • 3
  • 9