作为Web开发中应用最广泛的语言之一PHP有着大量的粉丝那么你是一名优秀的程序员吗?在进行自我修炼的同时你是否想过面对各种各样的问题我该如何突破自身的瓶颈以便更好的发展呢?
PHP工程师面临成长瓶颈
先明确这里所指的PHP工程师是指主要以PHP进行Web系统的开发没有使用其的语言工作过工作经验大概在~年普通的Web系统(百万级访问千成级数据以内或业务逻辑不是特别复杂)开发起基本得心应手没有什么问题但他们会这样的物点
◆除了PHP不使用其它的语言可能会点shell 脚本
◆对PHP的掌握不精(很多PHP手册都没有看完库除外)
◆知识面比较窄(面对需求除开使用PHP和mysql 不知道其它的解决办法)
◆PHP代码以过程为主认为面向对象的实现太绕看不懂
这些PHPer在遇到需要高性能处理高并发大量数据的项目或业务逻辑比较复杂(系统需要解决多领域业务的问题)时缺少思路不能分析问题的本质技术判断力比较差对于问题较快能找出临时的解决办法但常常在不断临时性的解决办法中系统和自己一步步走向崩溃那怎么提高自己呢?怎么可以挑战难度更高的系统?
更高的挑战在那里?
结合我自己的经验我列出一些具体挑战让大家先有个感性的认识
高性能系统的挑战在那里?
◆如何选择Web服务器?要不要使用fastcgi 模式;
◆要不要使用反向代理服务?选择全内存缓存还是硬盘缓存?
◆是否需要负载均衡?是基于应用层还是网络层? 如何保证高可靠性?
◆你的PHP代码性能如何使用优化工具后怎么样? 性能瓶颈在那里? 是否需要写成C的扩展?
◆用户访问有什么特点是读多还是写多?是否需要读写分离?
◆数据如何存储?写入速度和读出速度如何? 数据增涨访问速读如何变化?
◆如何使用缓存? 怎么样考虑失效?数据的一致性怎么保证?
高复杂性系统的挑战在那里?
◆能否识别业务所对应的领域?是一个还是多个?
◆能否合理对业务进行抽象在业务规则变化能以很小的代价实现?
◆数据的一致性安全性可否保证?
◆是否撑握了面向对象的分析和设计的方法
这里所列出的问题你都能肯定的回答说明在技术上你基本已经可能成为架构师了如何你还不能回答你需要在以下几个方向加强
怎么样提高突破瓶颈
如何你还不能回答你需要在以下几个方向加强
◆分析你所使用的技术其原理和背后运行的机制这样可以提高你的技术判断力提高你技术方案选择的正确性;
◆学习大学期间重要的知识 操作系统原理数据结构和算法知道你以前学习都是为了考试但现在你需要为自己学习让自己知其所以然;
◆重新开始学习C语言虽然你在大学已经学过这不仅是因为你可能需要写PHP扩展而且还因为在做C的应用中有一个时刻关心性能内存控制变量生命周期数据结构和算法的环境;
◆学习面向对象的分析与设计它是解决复杂问题的有效的方法学习抽象它是解决复杂问题的唯一之道
如何有效的学习是一个大问题“以架构为中心用例驱动迭代开发”借用这个思想关于有效的学习的方法可以这样来表述以原理模型或机制为中心任务驱动迭代学习有点抽象 举个例子来说明如何学习
目的 学习如何提高处理性能
可迭代驱动的任务 通过IP找到所在地域这是Web应用常见的任务IP数据库是左右万行的记录
第一次迭代 不考虑性能的情况下实现功能(通过PHP来实现)
因为无法直接通过KEY(IP)进行查找地域所以直接放到数据或通过关联数组这种简单的方法都是不行的思路还是先把数据进行排序然后再进行查找
◆如何通过IP查找?已序的数据二分查找是最快的
◆如何排序?用库函数sort当然是可以但是即然是学习那还是自己实现快速排序吧
学习目标 排序算法查找算法
PHPer数据结构和算法基础比较差平时也没有这方面的任务自己也不学习因此这方面的知识很缺乏但是编程解决的问题最终都会归结到数据结构和对这种数据结构操作的算法如果数据结构算法常在心中那遇到问题就能清晰认识到它内在的结构解决方法就会自然产生
第二次迭代优化数据的加载与排序
如果做到第一步那基本上还是不可用因为数据每次都需要的加载和排序这样太耗时间 解决的思路是数据一次加载排序后放到每个PHP进程能访问到的地方放到Memcache这是大家容易想到问题其实放到共享内存(EA等加速器都支持)中是更快的方式因为memcache还多了网络操作 数据是整体放入到共享内存还是分块放入如何测试性能? 如何分析瓶颈所在(xdebug)? 在这些问题的驱动下你会学习到
学习目标 检测定位优化PHP性能的方法; PHP实现结构对性能的影响
第三次迭代 编写PHP的扩展
性能还是上不去不得不进入C/C++的世界了不过从此你将不只是PHPer 而服务端的全能型工程师当然这对没有做过C/C++的同学挑战是巨大的
学习目标C/C++的学习PHP扩展的编写
怎么确定需要学习的机制和原理呢? 怎么找到驱动学习任务呢?我对需要学习的东西都没有什么概念怎么回答以上的两个问题? 从这个技术的定位来找出需要学习的重点即它怎么做到(机制)的和它为什么能这样做到列出这个技术最常见的应用做为学习的任务从简到难进行实践
假如我需要学习JavaScript我对于HTMLCSS有点感性认识首要要了解的是JavaScript是Web领域的动态语言主要解决网页的动态交互的那要学习的要点如下
◆JavaScript如何与HTML进行交互 (机制)
◆JavaScript的动态特性在那里与其它动态语言有何区别?(语言模型)
如果完全自学找到需要学习的要点(机制模型原理) 设定学习任务的确不是那么容易把握如果找到一个有经验的人来指导你或加一个学习型的团队那学习的速度的确会大大提高
最后想对大家说PHP因为简单而使用但不能因为它的简单而限制我们成长!