Showing posts with label debugging. Show all posts
Showing posts with label debugging. Show all posts
2014-08-16
Fatal error: Maximum execution time of 30 seconds exceeded & timeout problems (PHP debugging)
The error message above in the title line indicates that you have some code that takes too long to run in your php file. There is a sanity check that keeps track of the time you spend on a page, and the timer times-out you will get the Maximum execution time exceeded message. The duration for this time-out value is set in the php.ini
maximum_execution_time = 30
You can reset this in your file to debug what is happening. Using
ini_set('max_execution_time', 300);
sets the maximum execution time to 300 seconds or 5 minutes.
You need to surround snippets of your code with some timestamp routines to figure out
which portion is taking up a long time.
$ts = microtime(true);
// code snippet to check timing of
var_dump(microtime(true) - $ts);
If you are doing MySQL database queries, you can turn to the slow queries log to see if there are any SQL queries that are too complex and take a while to return (for e.g., a join with several large tables would slow down you query because of the large result set.
To enable the slow query log, start mysqld with the --log-slow-queries[=file_name]
The slow query log can be used to find queries that take a long time to execute and are therefore candidates for optimization. However, examining a long slow query log can become a difficult task. To make this easier, you can process a slow query log file using the mysqldumpslow command to summarize the queries that appear in the log.
Diagnosing slow PHP execution with Xdebug and KCachegrind
Profiling a PHP application can explain how much time the server spent in each function, each file, and each code path. It can also show you how many times a function or method was called, which is useful for diagnosing programming errors involving pointless looping. Xdebug generates cachegrind-compatible files which can also be used to create easy-to-understand graphs using KCachegrind.
The log file created by Xdebug can be small or large depending on what the application is doing. Also, it’s not really reader friendly. You’ll want to use programs like KCachegrind or Webgrind to view them. KCachegrind is a profile data visualization tool for KDE, which needs a Unix environment to run, whereas Webgrind is a web-based tool.
http://kcachegrind.sourceforge.net/html/Home.html
https://github.com/jokkedk/webgrind
https://github.com/ceefour/wincachegrind
http://ceefour.github.io/wincachegrind/
WinCacheGrind is a viewer for cachegrind.out files generated by xdebug 2. WinCacheGrind is functionally similar to KCacheGrind, only it is much simpler and runs on Windows.
As we have done in a previous PHP debugging tip, we need to enable certain Xdebug options in the php.ini file. Specifically those related to profiling.
xdebug.profiler_enable = 1
xdebug.profiler_output_name = xdebug.out.%t
xdebug.profiler_output_dir = /tmp
xdebug.profiler_enable_trigger = 1
xdebug.profiler_enable is used to enable profiling in Xdebug (off by default). xdebug.profiler_output_name is the filename of the profiler log (the %t specifier appends a timestamp to the filename.
xdebug.profiler_output_dir stores the profiling output in the directory specified
Profiling degrades performance since the PHP engine.
xdebug.profiler_enable_trigger instructs Xdebug to perform profiling only when XDEBUG_PROFILE is passed as a GET or POST parameter.
2014-08-13
How to fix #PHP #BSOD - Blank Screen of Death / #WSOD - the White Screen of Death (PHP Debugging)
You created a PHP file which was running fine. Then you made some changes to improve it and uploaded it to your server. Suddenly, all you get is a blank screen on your browser. Not even an error message!!
What happened ?!?
You have just witnessed the well known PHP BSOD or WSOD.
This happens when error messages are turned off. This would be the default settings on many production PHP servers. You won't want your customers to see all your error messages appearing on their screens.
How to fix this? Basically, we can
1) turn on the error messages display, or
2) create custom error handlers
#1 - Turning on error messages
You can change the settings of the php.ini or .htaccess or include the following
at the top of the php file
<?php
On Apache web server, we can use the .htaccess file to configure
PHP error messages
Or, if you do have access to the php.ini, you can set the error reporting in the php.ini
You can define your own handling function. When an error occurs, this custom
function gets called
What happened ?!?
You have just witnessed the well known PHP BSOD or WSOD.
This happens when error messages are turned off. This would be the default settings on many production PHP servers. You won't want your customers to see all your error messages appearing on their screens.
How to fix this? Basically, we can
1) turn on the error messages display, or
2) create custom error handlers
#1 - Turning on error messages
You can change the settings of the php.ini or .htaccess or include the following
at the top of the php file
<?php
ini_set('error_reporting', E_ALL); // or -1
ini_set('display_errors', 'On'); //On or Off
On Apache web server, we can use the .htaccess file to configure
PHP error messages
php_value display_errors 1
php_value display_startup_errors 1
php_value error_reporting -1 # E_ALL
Or, if you do have access to the php.ini, you can set the error reporting in the php.ini
display_errors = On
display_startup_errors = On
error_reporting = E_ALL
#2 - Custom error handling functionYou can define your own handling function. When an error occurs, this custom
function gets called
<?php
// error handler function
function myErrorHandler($errno, $errstr, $errfile, $errline)
{
if (!(error_reporting() & $errno)) {
// This error code is not included in error_reporting
return;
}
switch ($errno) {
case E_USER_ERROR:
echo "<b>My ERROR</b> [$errno] $errstr<br />\n";
echo " Fatal error on line $errline in file $errfile";
echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />\n";
echo "Aborting...<br />\n";
exit(1);
break;
case E_USER_WARNING:
echo "<b>My WARNING</b> [$errno] $errstr<br />\n";
break;
case E_USER_NOTICE:
echo "<b>My NOTICE</b> [$errno] $errstr<br />\n";
break;
default:
echo "Unknown error type: [$errno] $errstr<br />\n";
break;
}
/* Don't execute PHP internal error handler */
return true;
}
// you need to register the custom error handler to use it
// set to the user defined error handler
$old_error_handler = set_error_handler("myErrorHandler");
// the #old_error_handler can be used to reset the handler
2014-08-04
How to debug PHP tips & techniques (Part 3)
Using print statements inside the script to display the trace of execution is a tried and tested method of debugging. For PHP is has several commands that can be used for displaying a trace of the executing PHP file.
Echo command can be used for quick debug message. You can comment them off when not in use.
echo "message line";
// echo "message line"; commented off
USING VAR_DUMP() TO AID YOUR DEBUGGING
var_dump() is a native PHP function which displays structured, humanly readable, information about one (or more) expressions. This is particularly useful when dealing with arrays and objects as var_dump() displays their structure recursively.
echo '<pre>'; var_dump($aMyData); echo '</pre>';
Tip: Wrap var_dump() in <pre> tags to aid readability.
Sometimes you may want to collect the log messages
in separate file instead of showing it in the browse.
You can log data to the standard error log file with error_log.
http://php.net/manual/en/function.error-log.php
PHP does not come with different debug levels (info, warning, error), you may also
standalone log modules/classes like Monolog or KLogger.
Monolog: https://github.com/Seldaek/monolog
KLogger: http://codefury.net/projects/klogger/
Besides var_dump(), you could also use var_export and print_r() functions in PHP
to examine variable values.
Echo command can be used for quick debug message. You can comment them off when not in use.
echo "message line";
// echo "message line"; commented off
USING VAR_DUMP() TO AID YOUR DEBUGGING
var_dump() is a native PHP function which displays structured, humanly readable, information about one (or more) expressions. This is particularly useful when dealing with arrays and objects as var_dump() displays their structure recursively.
echo '<pre>'; var_dump($aMyData); echo '</pre>';
Tip: Wrap var_dump() in <pre> tags to aid readability.
Sometimes you may want to collect the log messages
in separate file instead of showing it in the browse.
You can log data to the standard error log file with error_log.
http://php.net/manual/en/function.error-log.php
PHP does not come with different debug levels (info, warning, error), you may also
standalone log modules/classes like Monolog or KLogger.
Monolog: https://github.com/Seldaek/monolog
KLogger: http://codefury.net/projects/klogger/
Besides var_dump(), you could also use var_export and print_r() functions in PHP
to examine variable values.
print_r() displays information about a variable in a way that's readable by humans.
print_r(), var_dump() and var_export() will also show protected and private properties of objects with PHP 5. Static class members will not be shown.
2014-08-03
Debugging PHP tips and techniques (part 2)
An alternative to setting up the PHP server on your PC, Mac or Linux machine is to create a virtual server within a virtual machine (VM) running on your machine. This would closely emulate the final deployment environment. As the VM is usually running Linux, it would support things like case-sensitivity in the web server (something which causes grief on windows based web servers).
There are a number of free solutions for creating VM servers on your operating system.
VirtualBox is available on most platforms as long as you are running on Intel.
VirtualBox: https://www.virtualbox.org
Vagrant: http://www.vagrantup.com
Vagrant is a tool that allows quick setup of development environments using virtual machines. It works well with VirtualBox.
To make the configuration of PHP itself easier, we can turn to PuPHPet
PuPHPet: https://puphpet.com/
Configuration of your Vagrant+VirtualBox is as easy as choosing from a menu of options.
But, you may want to try Docker instead of VirtualBox as a Vagrant provider
http://www.tylercipriani.com/2014/05/25/lightweight-portable-vagrant-docker.html
There are a number of free solutions for creating VM servers on your operating system.
VirtualBox is available on most platforms as long as you are running on Intel.
VirtualBox: https://www.virtualbox.org
VirtualBox is a powerful x86 and AMD64/Intel64 virtualization product for enterprise as well as home use. Not only is VirtualBox an extremely feature rich, high performance product for enterprise customers, it is also the only professional solution that is freely available as Open Source Software under the terms of the GNU General Public License (GPL) version 2.
Presently, VirtualBox runs on Windows, Linux, Macintosh, and Solaris hosts.
Presently, VirtualBox runs on Windows, Linux, Macintosh, and Solaris hosts.
Vagrant: http://www.vagrantup.com
Vagrant is a tool that allows quick setup of development environments using virtual machines. It works well with VirtualBox.
WHY VAGRANT?
Vagrant provides easy to configure, reproducible, and portable work environments built on top of industry-standard technology and controlled by a single consistent workflow to help maximize the productivity and flexibility of you and your team.
To achieve its magic, Vagrant stands on the shoulders of giants. Machines are provisioned on top of VirtualBox, VMware, AWS, or any other provider. Then, industry-standard provisioning tools such as shell scripts, Chef, or Puppet, can be used to automatically install and configure software on the machine.
Vagrant provides easy to configure, reproducible, and portable work environments built on top of industry-standard technology and controlled by a single consistent workflow to help maximize the productivity and flexibility of you and your team.
To achieve its magic, Vagrant stands on the shoulders of giants. Machines are provisioned on top of VirtualBox, VMware, AWS, or any other provider. Then, industry-standard provisioning tools such as shell scripts, Chef, or Puppet, can be used to automatically install and configure software on the machine.
To make the configuration of PHP itself easier, we can turn to PuPHPet
PuPHPet: https://puphpet.com/
Configuration of your Vagrant+VirtualBox is as easy as choosing from a menu of options.
But, you may want to try Docker instead of VirtualBox as a Vagrant provider
http://www.tylercipriani.com/2014/05/25/lightweight-portable-vagrant-docker.html
The latest versions of Vagrant (1.6.2, as of May 26th) can actually use docker as a provider, that is, as an alternative to VirtualBox. Using Docker as a provider means that you can run a fully-independent development enviroment, on your host machine without the overhead of VirtualBox.
2014-08-02
PHP Debugging tips and techniques (Part 1)
PHP is a script based language. It does not require a compilation process. Errors can only be detected when you run the PHP code.
Tip #1 - setup a development environment on your own machine.
With the available of cheap PHP hosting, some PHP developers just use a text editor to write the code. Then upload the php file directly to the PHP server using FTP, and test using the PHP server. If there are any errors in the PHP file, they would be obvious when the you try to view the page on the browser.
When it comes to debugging, this is a very slow and tedious process of finding a bug, the correcting (at least hope to) and uploading the new version of the php file and testing with a browser. It would probably take far less time, to setup the development environment on your machine. At the very least, it would save you the hassle of repeatedly uploading the file to the server.
A number of pre-packaged installers exists for windows and macosx and linux
https://www.apachefriends.org/index.html
Mac, Win, Linux
http://www.easyphp.org/
Win
http://www.mamp.info/en/
Mac
Tip #1 - setup a development environment on your own machine.
With the available of cheap PHP hosting, some PHP developers just use a text editor to write the code. Then upload the php file directly to the PHP server using FTP, and test using the PHP server. If there are any errors in the PHP file, they would be obvious when the you try to view the page on the browser.
When it comes to debugging, this is a very slow and tedious process of finding a bug, the correcting (at least hope to) and uploading the new version of the php file and testing with a browser. It would probably take far less time, to setup the development environment on your machine. At the very least, it would save you the hassle of repeatedly uploading the file to the server.
A number of pre-packaged installers exists for windows and macosx and linux
https://www.apachefriends.org/index.html
Mac, Win, Linux
http://www.easyphp.org/
Win
http://www.mamp.info/en/
Mac
2014-07-30
Strings to DateTime using C# (problems with different date formats from around the world)
// Date strings are interpreted according to the current culture. // If the culture is en-US, this is interpreted as "January 8, 2008", // but if the user's computer is fr-FR, this is interpreted as "August 1, 2008" string date = "01/08/2008"; DateTime dt = Convert.ToDateTime(date); Console.WriteLine("Year: {0}, Month: {1}, Day: {2}", dt.Year, dt.Month, dt.Day); // Specify exactly how to interpret the string. IFormatProvider culture = new System.Globalization.CultureInfo("fr-FR", true); // Alternate choice: If the string has been input by an end user, you might // want to format it according to the current culture: // IFormatProvider culture = // System.Threading.Thread.CurrentThread.CurrentCulture; DateTime dt2 = DateTime.Parse(date, culture, System.Globalization.DateTimeStyles.AssumeLocal); Console.WriteLine("Year: {0}, Month: {1}, Day {2}", dt2.Year, dt2.Month, dt2.Day); /* Output (assuming first culture is en-US and second is fr-FR): Year: 2008, Month: 1, Day: 8 Year: 2008, Month: 8, Day 1 */
I was encountering a lot of problems converting a simple string like
"30/7/2014 11:00" to DateTime because I kept getting an exception for invalid DateTime string.
I was doing the conversion using the code like
String datestr = "30/7/2014 11:00";
DateTime mydate = Convert.ToDateTime(datestr);
Finally, I dawned upon me that the source of the problem was that the machine I was
working on was set to "en-US" mm/dd/yyy and not the UK style dates dd/mm/yyyy which I normally worked with.
Without changing the machine setting, I had to use the CulturalInfo and DateTime.Parse instead. So the code ended up like the one below
String datestr = "30/7/2014 11:00";
IFormatProvider culture = new System.Globalization.CultureInfo("en-GB", true);DateTime mydate = DateTime.Parse(datestr, culture);
The list of strings that can be used to set the CulturalInfo is below:
http://msdn.microsoft.com/en-us/goglobal/bb896001.aspx
Note that for English we can have "en-US", "en-UK", "en-SG", "en-AU", "en-IN"
Which leads me to wonder how many versions of English there are in the world.
The reverse path of formatting a DateTime to string is easier. For example, to get at date string in ISO format I can use
mydate.ToString("yyyy-MM-ddTHH:mm:sszz");
http://en.wikipedia.org/wiki/ISO_8601
provides a detailed description of the international standard for datetime string. This should work in all countries.
There is a way to parse the datetime string in a custom format that is culture independent. We should use DateTime.ParseExact method instead of DateTime.Parse
string dateString, format; DateTime result; CultureInfo provider = CultureInfo.InvariantCulture; // Parse date and time with custom specifier. dateString = "Sun 15 Jun 2008 8:30 AM -06:00"; format = "ddd dd MMM yyyy h:mm tt zzz"; try
{
result = DateTime.ParseExact(dateString, format, provider);
Console.WriteLine("{0} converts to {1}.", dateString, result.ToString());
} catch (FormatException) { Console.WriteLine("{0} is not in the correct format.", dateString); }
Subscribe to:
Posts (Atom)
Github CoPilot Alternatives (VSCode extensions)
https://www.tabnine.com/blog/github-copilot-alternatives/
-
The error message above in the title line indicates that you have some code that takes too long to run in your php file. There is a sanity ...
-
Scilab 5.0.2 installs in windows fine. But when I try to run program, get start-up screen, then an error dialog box . Error message is: Scil...
-
To Build Websites and Apps, People Flock to Coding Classes http://online.wsj.com/news/articles/SB10001424052702304709904579411354120634252...