关于PHP程序员解决问题的能力

这个话题老生长谈了,在面试中必然考核的能力中,我我的认为解决问题能力是排第一位的,比学习能力优先级更高。解决问题的能力既能看出程序员的思惟能力,应变能力,探索能力等,又能够看出他的经验。若是解决问题能力不佳是没法经过面试的。php

这里举个例子,假如我执行了一个PHP的脚本,如php test.php,预期是能够返回一个字符串。但执行后没有任何信息输出,这时候经过什么方法能知道程序错在哪里?这里能够将解决问题能力分为8个等级,越到后面的表示能力越强。mysql

Lv0 查看PHP错误信息程序员

程序没有达到预期效果,证实代码出错了,看PHP的错误信息是第一步。若是直接忽略错误信息,代表这我的不适合担任专业的程序员岗位。有些状况下php.ini配置中关闭了错误显示,须要修改php.ini打开错误信息,或者错误信息被导出到了日志文件,这种状况能够直接tailf php_error.log来看错误信息。web

拿到错误信息后直接定位到程序代码问题,或者到Google/百度搜索,便可解决问题。面试

注:打开错误显示的方法是sql

  • php.ini中display_errors / display_startup_errors 设置为On
  • php.ini中error_reporting 设置为E_ALL
  • PHP代码中设置error_reporting(E_ALL)

Lv1 存在多个版本的php或php-cli与php-fpm加载不一样的配置浏览器

存在多个版本的php,懂得经过which php来看是哪一个PHP,或者加绝对路径制定php版本。表示此PHPer经过了此层级的50%考验。性能优化

另一个状况就是php-cli与php-fpm获得的执行状况不同,如在web浏览器中执行是对的,cli下执行是错的。这时候多是2个环境加载的php.ini不一样所致。cli下经过php -i |grep php.ini获得加载了哪一个php.ini。而fpm下经过phpinfo()函数能够获得php.ini的绝对路径。swoole

Lv2 var_dump/die打印变量值信息单步调试网络

这是惯用的程序调试手段,也是最简单粗暴有效的解决问题方法。高级一点的手段是使用PHP的Trace类/日志类,花哨一点的能够借助phpstorm+xdebug在IDE工具里进行Debug。

Trace工具还能够分析脚本的耗时,进行PHP程序的性能优化。

这3个考验所有经过,代表此程序员已经具有了专业PHP程序员应该有的解决问题能力了。PHP程序员只要过了这个等级,就足以应多大部分状况,在中小型网站中毫无压力。

Lv3 使用strace工具跟踪程序执行

strace能够用来查看系统调用的执行,使用strace php test.php,或者strace -p 进程ID。strace就能够帮助你透过现象看本质,掌握程序执行的过程。这个手段是在大型网站,大公司里最经常使用的。若是没掌握strace,这里只能说抱歉了,咱们不接受不会strace的PHPer。

strace其实也是对程序员基础的考验,若是不懂操做操做系统,彻底不懂底层,确定也达不到会用strace的程度。固然strace对于PHP代码里的死循环是解决不了的。好比你发现一个php-fpm进程CPU100%了,strace恐怕是解决不了的。由于strace是看系统调用,通常都是IO类操做,既然是IO密集,那CPU必定不多是100%。

Lv4 使用tcpdump工具分析网络通讯过程

tcpdump能够抓到网卡的数据通讯过程,甚至数据内容也能够抓到。使用tcpdump能够看到网络通讯过程是什么样的,如什么时候发起了TCP SYN3次握手,什么时候发送FIN包,什么时候发送RST包。这是一个基本功,若是不懂tcpdump,证实不具有网络问题解决能力。

Lv5 统计函数调用的耗时和成功率

使用xhporf/xdebug导出PHP请求的调用过程,而后分析每一个函数调用的过程和耗时。可以分析PHP程序的性能瓶颈,找出能够优化的点。

另一个对于网络服务的调用,如mysql查询,curl,其余API调用等,经过记录起始和结束时microtime,返回的是否是false,能够获得调用是否成功,耗时多少。若是能够汇总数据,整理出调用的成功率,失败率,平均延时,证实此程序员对接口质量敏感,有大型网站项目经验。

Lv6 gdb使用

gdb是C/C++调试程序的利器,须要具有必定C/C++功底的程序员才会能熟练使用gdb。上面说的strace没法跟踪php程序CPU100%,而gdb是能够跟踪的。另外gdb也能够解决php程序core dump的问题。

经过gdb -p 进程ID,再配合php-src的.gdbinit zbacktrace等工具,能够很方便地跟踪PHP程序的执行。像上面的CPU100%每每是PHP程序中发生死循环了,gdb进行屡次查看,就大体能够获得死循环的位置。具有gdb解决问题能力的PHP程序员少之又少。若是能使用gdb解决PHP问题,这个PHPer百分之百能够经过面试,而且能够拿到较高的技术评级。

Lv7 查看PHP内核和扩展源码

若是能熟悉PHP内核和扩展的源码,遇到PHP程序中最复杂的内存错误,也能够有解决的能力。这类PHP程序员就是百里挑一了。配合gdb工具和对PHP源码的熟悉,能够查看opcode的信息,execute_data的内存,全局变量的状态等。

转载自:http://rango.swoole.com/archi...

相关文章
相关标签/搜索