PHP架构师之路-提高阶段(2-3年)
重点
- 玩转LNMP搭建和配置,精通各种大流量高并发场景的中型PHP系统的开发
目标
- 能够独立完成LNMP环境的搭建,根据项目需要熟练进行各种常规配置;有能力定位和解决大部分开发和线上问题;有能力独立完成一个中型系统的架构设计,具备一定的团队领导力,能够带领10人以内的小团队完成一个中型系统的开发,能够独立完成一个大型系统的模块架构和开发工作
知识点
Linux:
- 能够流畅的使用Shell脚本来完成很多自动化的工作;
- awk/sed/perl也操作的不错,能够完成很多文本处理和数计等工作;
- 了解基本的Linux服务,知道如何查看Linux的性能指标数据,知道基本的Linux下面的问题跟踪等。
Nginx:
- 了解复杂一些的Nginx配置;包括多核配置、events、proxy_pass,sendfile/tcp_*配置,知道超时等相关配置对性能的影响;
- 知道nginx除了web server,还能够承担代理服务器、反向静态服务器等配置;知道如何配置权限、编译一个nginx扩展到nginx;
- 知道基本的nginx配置调优;
- 知道基本的nginx运行原理(master/worker机制,epoll),知道为什么nginx性能比apache性能好等知识;
MySQL/MongoDB:
- 掌握一些常规SQL优化技巧(group by/order by/rand优化等);
- 能够冷热备份MySQL数据,知道影响innodb/myisam性能的配置选项,知道这些选项配置成为多少值合适;另外也了解一些特殊的配置选项,比如知道如何搭建mysql主从同步的环境,知道各个binlog_format的区别;
- 知道MySQL的性能追查,包括slow_log/explain等,还知道基本的索引建立处理等知识;
- 原理方面了解基本的MySQL的架构(Server+存储引擎),知道基本的【nnoDB/MyISAM索引存储结构和不同(聚簇索引,B树);
- 知道基本的InnoDB事务处理机制;
- 了解大部分MySQL异常情况的处理方案。条件允许的情况,建议了解一下NoSQL的代表MongoDB数据库,顺便对比与MySQL的差别,同时能够在合适的应用场景安全谨慎的使用MongoDB,知道基本的PHP+MongoDB的结合开发。
Redis/Memcached:
- 在大部分中型系统里面一定会涉及到缓存处理,所以一定要了解基本的缓存;
- 知道Memcached和Redis的异同和应用场景,能够独立安装Redis/Memcached,了解Memcahed的一些基本特性和限制,比如最大的value值,知道PHP跟他们的使用结合;
- 了解Redis基本工作原理和使用,了解常规的数据类型,知道什么场景应用什么类型,了解Redis的事务等。
- 原理部分,能够大概了解Memcached的内存结构(slab机制),了解Redis常用数据类型底层实现存储结构(SDS/链表/SkipList/HashTable)等,顺便了解一下Redis的事务、RDB、AOF等机制更好
PHP
- 能够随意安装PHP和各种第三方扩展的编译安装配置;
- 了解php-fpm的大部分配置选项和含义(如max_requests/max_children/request_terminate_timeout之类的影响性能的配置),知道mod_php/fastcgi的区别;
- 对PHP面向对象有深入的理解,了解SPL/语法层面的特殊特性比如反射之类的;
- 在框架方面已经阅读过一个以上常见PHP MVC框架的代码,知道基本PHP框架内部实现机制和设计思想;
- 在PHP开发中已经能够熟练使用常规的设计模式来进行开发(抽象工厂/单例/观察者/命令链/策略/适配器等模式);
- 建议开发自己的PHPMVC框架来充分让开发自由化,让自己深入理解MVC模式,也让自己能够在业务项目开发里快速升级;
- 熟悉PHP的各种代码优化方法,熟悉大部分PHP安全方面问题的解决处理;
- 熟悉基本的PHP执行的机制原理(Zend引擎/扩展基本工作机制)
C/C++:
- 开始涉猎一定的C/C++语言,能够写基本的C/C++代码,对基本的C/C++语法熟悉(指针、数组操作、字符串、常规标准API)和数据结构(链表、树、哈希、队列)有一定的熟悉下;
- 对Linux下面的C语言开发有基本的了解概念,会简单的makefile文件编写,能够使用简单的GCC/GDB的程序编译简单调试工作;
- 对基本的网络编程有大概了解
前端:
- 熟悉基本的HTTP协议(协议代码200/300/400/500,基本的HTTP交互头);
- 条件允许,可以在深入写出稍微优雅的HTML+CSS+JavaScript,或者能够大致简单使用某些前端框架(jQuery/YUI/ExtJS/RequireJS/Bootstrap之类);
- 如果条件允许,可以深入学习JavaScript编程,比如闭包机制、DOM处理;
- 再深入些可以读读jQuery源码做深入学习。(本项不做重点学习,除非对前端有兴趣)
系统架构设计:
- 能够设计大部分中型系统的网站架构、数据库、基本PHP框架选型;
- 性能测试排查处理等;
- 能够完成类似:浏览器->CDN(Squid)->Nginx+PHP->缓存->数据库结构网站的基本设计开发维护;
- 能够支撑每天数百万到千万流量基本网站的开发维护工作;