如何突破PHP程序员的技术瓶颈分析


Posted in PHP onJuly 17, 2011

先明确我所指的PHP工程题,是指毕业工作后,主要以PHP进行WEB系统的开发,没有使用其的语言工作过。工作经验大概在3~4年,普通的WEB系统(百万级访问,千成级数据以内或业务逻辑不是特别复杂)开发起基本得心应手,没有什么问题。但他们会这样的物点:

除了PHP不使用其它的语言,可能会点shell 脚本。
对PHP的掌握不精(很多PHP手册都没有看完,库除外)
知识面比较窄(面对需求,除开使用PHP和mysql ,不知道其它的解决办法)
PHP代码以过程为主,认为面向对象的实现太绕,看不懂
这些PHPer 在遇到需要高性能,处理高并发,大量数据的项目或业务逻辑比较复杂(系统需要解决多领域业务的问题)时,缺少思路。不能分析问题的本质,技术判断力比较差,对于问题较快能找出临时的解决办法,但常常在不断临时性的解决办法中,系统和自己一步步走向崩溃。那怎么提高自己呢?怎么可以挑战难度更高的系统?

更高的挑战在那里?结合我自己的经验,我列出一些具体挑战,让大家先有个感性的认识。

高性能系统的挑战在那里?

如何选择WEB服务器?要不要使用fast-cgi 模式
要不要使用反向代理服务?选择全内存缓存还是硬盘缓存?
是否需要负载均衡?是基于应用层,还是网络层? 如何保证高可靠性?
你的PHP代码性能如何,使用优化工具后怎么样? 性能瓶颈在那里? 是否需要写成C的扩展?
用户访问有什么特点,是读多还是写多?是否需要读写分离?
数据如何存储?写入速度和读出速度如何? 数据增涨访问速读如何变化?
如何使用缓存? 怎么样考虑失效?数据的一致性怎么保证?
高复杂性系统的挑战在那里?

能否识别业务所对应的领域?是一个还是多个?
能否合理对业务进行抽象,在业务规则变化能以很小的代价实现?
数据的一致性、安全性可否保证?
是否撑握了面向对象的分析和设计的方法
当我所列出的问题,你都能肯定的回答,我想在技术上你基本已经可能成为架构师了。如何你还不能回答,你需要在以下几个方向加强。

如何你还不能回答,你需要在以下几个方向加强:

分析你所使用的技术其原理和背后运行的机制,这样可以提高你的技术判断力,提高你技术方案选择的正确性;
学习大学期间重要的知识, 操作系统原理,数据结构和算法。知道你以前学习都是为了考试,但现在你需要为自己学习,让自己知其所以然。
重新开始学习C语言,虽然你在大学已经学过。这不仅是因为你可能需要写PHP扩展,而且还因为,在做C的应用中,有一个时刻关心性能、内存控制、变量生命周期、数据结构和算法的环境。
学习面向对象的分析与设计,它是解决复杂问题的有效的方法。学习抽象,它是解决复杂问题的唯一之道。
"这么多的东西怎么学,这得学多久呀" ?如果你努力的话,有较好的规划,估计需要1~2年的时间。

如何有效的学习是一个大问题。 自己有些实践但很零散,不好总结。昨天晚上睡觉前,突然想到了RUP的核心,"以架构为中心,用例驱动,迭代开发",借用这个思想,关于有效的学习的方法,可以这样来表述:以原理、模型或机制为中心,任务驱动,迭代学习。

有点抽象, 举个例子来说明如何学习。目的: 学习如何提高处理性能。

可迭代驱动的任务: 通过IP找到所在地域。

这是WEB应用常见的任务,IP数据库是10左右万行的记录。

第一次迭代: 不考虑性能的情况下实现功能(通过PHP来实现)。因为无法直接通过KEY(IP)进行查找地域,所以直接放到数据或通过关联数组这种简单的方法都是不行的。思路还是先把数据进行排序,然后再进行查找。

如何通过IP查找? 已序的数据,二分查找是最快的。
如何排序?用库函数sort当然 是可以,但是即然是学习,那还是自己实现快速排序吧。
学习目标: 排序算法,查找算法。

PHPer 一般数据结构和算法基础比较差,平时也没有这方面的任务,自己也不学习,因此这方面的知识很缺乏。但是,编程解决的问题,最终都会归结到数据结构和对这种数据结构操作的算法。如果数据结构算法常在心中,那遇到问题就能清晰认识到它内在的结构,解决方法就会自然产生。

第二次迭代:优化数据的加载与排序。如果做到第一步,那基本上还是不可用,因为数据每次都需要的加载和排序,这样太耗时间。 解决的思路是,数据一次加载排序后,放到每个PHP进程能访问到的地方。

放到memcache 这是大家容易想到问题。其实放到共享内存(EA等加速器都支持)中是更快的方式,因为memcache还多了网络操作。 数据是整体放入到共享内存,还是分块放入,如何测试性能? 如何分析瓶颈所在(xdebug)? 在这些问题的驱动下你会学习到。

学习目标: 检测、定位、优化PHP性能的方法; PHP实现结构对性能的影响。

第三次迭代: 编写PHP的扩展。性能还是上不去,不得不进入C/C++的世界了,不过从此你将不只是PHPer 而服务端的全能型工程师,当然这对没有做过C/C++的同学挑战是巨大的。 我这里无法再简单来说如何学习C/C++ ,可以参看 《PHP程序员学习C++》

学习目标:C/C++的学习,PHP扩展的编写

怎么确定需要学习的机制和原理呢? 怎么找到驱动学习任务呢?我对需要学习的东西,都没有什么概念,怎么回答以上的两个问题?

从这个技术的定位来找出需要学习的重点,即它怎么做到(机制)的和它为什么能这样做到 (模型或原理)
列出这个技术最常见的应用,做为学习的任务,从简到难进行实践。
假如我需要学习Javascript ,我对于HTML,CSS有点感性认识。首要我了解到,JS 是WEB领域的动态语言,主要解决网页的动态交互的。那我要学习的要点如下:

JS如何与HTML 进行交互 (机制)
JS的动态特性在那里,与其它动态语言有何区别?(语言模型)
如果完全自学,找到需要学习的要点(机制、模型、原理) 设定学习任务的确不是那么容易把握。如果找到一个有经验的人来指导你或加一个学习型的团队,那学习的速度的确会大大提高。

PHP 相关文章推荐
PHP 中执行系统外部命令
Oct 09 PHP
PHP编程中字符串处理的5个技巧小结
Nov 13 PHP
php中将数组存到文件里的实现代码
Jan 19 PHP
使用PHP遍历文件目录与清除目录中文件的实现详解
Jun 24 PHP
如何使用php输出时间格式
Aug 31 PHP
php中的curl使用入门教程和常见用法实例
Apr 10 PHP
9个经典的PHP代码片段分享
Dec 18 PHP
windows7下php开发环境搭建图文教程
Jan 06 PHP
php构造函数的继承方法
Feb 09 PHP
php基于Fleaphp框架实现cvs数据导入MySQL的方法
Feb 23 PHP
PHP实现基于PDO扩展连接PostgreSQL对象关系数据库示例
Mar 31 PHP
PHP7新特性之抽象语法树(AST)带来的变化详解
Jul 17 PHP
过滤掉PHP数组中的重复值的实现代码
Jul 17 #PHP
PHP二维数组的去重问题解析
Jul 17 #PHP
简单的PHP多图上传小程序代码
Jul 17 #PHP
一个PHP验证码类代码分享(已封装成类)
Jul 17 #PHP
PHP 验证码的实现代码
Jul 17 #PHP
PHP中用hash实现的数组
Jul 17 #PHP
PHP中文分词的简单实现代码分享
Jul 17 #PHP
You might like
php读取mysql中文数据出现乱码的解决方法
2013/08/16 PHP
php批量删除数据库下指定前缀的表以prefix_为例
2014/08/24 PHP
php使用file函数、fseek函数读取大文件效率对比分析
2016/11/04 PHP
Laravel框架中Blade模板的用法示例
2017/08/30 PHP
PHP在同一域名下两个不同的项目做独立登录机制详解
2017/09/22 PHP
WordPress伪静态规则设置代码实例
2020/12/10 PHP
js获取url参数值的两种方式
2013/09/10 Javascript
Jquery实现控件的隐藏和显示实例
2014/02/08 Javascript
浅谈jQuery的offset()方法及示例分享
2015/07/17 Javascript
jQuery实现可编辑的表格实例讲解(2)
2015/09/17 Javascript
微信公众平台开发教程(四) 实例入门:机器人回复(附源码)
2016/12/02 Javascript
JavaScript截屏功能的实现代码
2017/07/28 Javascript
vue中实现methods一个方法调用另外一个方法
2018/02/08 Javascript
vue用BMap百度地图实现即时搜索功能
2019/09/26 Javascript
详解如何修改 node_modules 里的文件
2020/05/22 Javascript
Vue.js中使用Vuex实现组件数据共享案例
2020/07/31 Javascript
python分割和拼接字符串
2013/11/01 Python
Python功能键的读取方法
2015/05/28 Python
python实现的希尔排序算法实例
2015/07/01 Python
Python实现快速傅里叶变换的方法(FFT)
2018/07/21 Python
Scrapy框架使用的基本知识
2018/10/21 Python
Linux CentOS Python开发环境搭建教程
2018/11/28 Python
Python实现获取系统临时目录及临时文件的方法示例
2019/06/26 Python
numpy 返回函数的上三角矩阵实例
2019/11/25 Python
Python使用sys.exc_info()方法获取异常信息
2020/07/23 Python
Ruby如何创建一个线程
2013/03/10 面试题
创业计划书撰写原则
2014/01/25 职场文书
投资协议书范本
2014/04/21 职场文书
三好学生个人先进事迹材料
2014/05/17 职场文书
机电专业毕业生自我鉴定2014
2014/10/04 职场文书
2015年社区消防安全工作总结
2015/10/14 职场文书
2016新教师岗前培训心得体会
2016/01/08 职场文书
canvas多重阴影发光效果实现
2021/04/20 Javascript
html5移动端禁止长按图片保存的实现
2021/04/20 HTML / CSS
java设计模式--三种工厂模式详解
2021/07/21 Java/Android
纯CSS打字动画的实现示例
2022/08/05 HTML / CSS