According to many PHP/LNMP programmer's development trajectory, combined with personal experience, abstract a lot of programmers to the future of confusion, especially the blind and flustered technical learning, a simple comb this each stage of the PHP Programmer's technical requirements, to help a lot of PHP programs to set learning growth goals.
This article according to the current mainstream technology to do a basic comb, the whole is to assume that the PHP programmer is not a very solid foundation of the setting, and all the settings are very specific and clear, may make people feel uncomfortable, please understand only represents opinion. (Future technical changes are not covered)
Focus: lnmp Skilled (core is the basic operation of the installation configuration)
Objective: to complete basic LNMP system installation, simple configuration and maintenance, to be able to do basic PHP development of simple system, to support the development of a PHP function module in PHP medium-sized system.
time: The time to complete this stage varies from person to person, and some grow up almost half a year on the past, growing slowly two or three years also have.
Basic command, operation, startup, basic service configuration (including RPM installation files, various service configurations, etc.); write simple shell scripts and awk/sed script commands.
To be able to install configuration nginx+php, know the basic nginx core configuration options, know Server/fastcgi_pass/access_log and other basic configuration, the goal is to enable NGINX+PHP_FPM to work smoothly.
Will build MySQL, know the basic MySQL configuration options, know the difference between InnoDB and MyISAM, know the different configuration options for InnoDB and MyISAM two engines; know the difference between the basic two engines and choose the difference above To build a MySQL database and configure the code to run normally and stably; The core idea is to be able to build a running MySQL database.
Basic syntax array, string, database, XML, Socket, gd/imagemgk image processing, and so on; be familiar with the various APIs (MYSQL/MYSQLI/PDO) linked to MySQL, and know the solution to various coding problems Know the regular skilled PHP framework (thinkphp, Zendframework, Yii, YAF, etc.); understand the basic MVC mechanism and why you do it, a little bit about the differences between different PHP frameworks, and the ability to quickly learn an MVC framework. Be able to know the file directory organization in the development project, have the basic good code structure and the style, can complete the small system development and the medium system one module development work.
5. Front End:
6. System Design:
Can complete the basic design of the small system, including the simple database design, can complete the basic: Browser---nginx+php database architecture design and development work, can support hundreds of thousands of to millions of daily traffic website development and maintenance work;
Focus: improve the skills for LNMP, can be more comprehensive to the LNMP have skilled application.
Objective: to set up the LNMP environment anytime, anywhere, to quickly complete the general configuration, to trace the most encountered development and online environment problems, to be able to independently assume the framework and development of the medium-sized system, to assume the development of a medium-sized module in a large-scale system;
On the basis of the first stage, we can use the shell script to do a lot of automated work smoothly, Awk/sed/perl is also very good, can complete a lot of text processing and data statistics, etc., basically can install most non-special Linux programs (including various libraries, packages, Third-party dependencies and so on, such as MONGODB/REDIS/SPHINX/LUNCENE/SVN); Learn about basic Linux services, know how to view Linux performance metrics data, know basic Linux problem tracking, and more.
In the first stage of the foundation, understand the complex nginx configuration, including multi-core configuration, events, proxy_pass,sendfile/tcp_* configuration, know the time-out and other related configuration and performance impact; I know nginx in addition to Web server, Also can assume proxy server, reverse static server and other configuration; know the basic Nginx configuration tuning; Know how to configure permissions, compile an nginx extension to nginx; know the basic nginx operating principle (Master/worker mechanism, epoll), Know why Nginx performance is better than Apache performance and other knowledge;
On the basis of the first stage, there are a number of tips on MySQL development, including regular SQL optimizations (group By/order By/rand Optimizations), and the ability to back up MySQL data in cold and hot, in addition to being able to build MySQL, and to know the impact innodb/ MyISAM configuration options for performance (such as key_buffer/query_cache/sort_buffer/innodb_buffer_pool_size/innodb_flush_log_at_trx_commit, etc.), Also know how many of these options are configured to be appropriate; also know some special configuration options, such as know how to build MySQL master-slave synchronization environment, know the difference between the Binlog_format; know MySQL performance tracing, including Slow_log/explain, Knowledge of basic indexing and processing is also possible, and the principle of understanding basic MySQL architecture (server+ storage engine), knowing the basic Innodb/myisam index storage structure and different (clustered index, B-tree); know the basic INNODB transaction processing mechanism To understand most of the MySQL exception scenarios (or know where to find the processing solution). Conditions allow, it is recommended to understand the NoSQL representative MongoDB database, by contrast with the MySQL differences, colleagues can safely use MongoDB in the appropriate application scenarios, know the basic PHP with MongoDB development.
In most of the medium-sized system will be involved in the cache processing, so be sure to understand the basic cache; know the similarities and differences between Memcached and Redis and the application scenario, can install redis/memcached independently, understand some basic features and limitations of memcahed, such as the largest value values, know PHP with their use, Redis understand the basic work and use, understand the general data types, know what kind of scenarios to apply what type, understand Redis transactions and so on. Principle part, can understand the memory structure of memcached (slab mechanism), Redis understand the common data type underlying implementation of the storage structure (sds/linked list/skiplist/hashtable), and so on, by the way, know the Redis transaction, RDB, AoF and other mechanisms better
In addition to the first-stage capabilities, installation configuration is free to install PHP and various third-party extensions of the compiled installation configuration; Understand most of the configuration options and implications of PHP-FPM (such as Max_requests/max_children/request_terminate_ Timeout and the like to affect the performance of the configuration), know the difference between the mod_php/fastcgi, in PHP has been able to master a variety of basic technology, but also a variety of in-depth PHP, including a deep understanding of PHP object-oriented/spl/syntax aspects of special features such as reflection , in the framework has read at least one of the regular PHP MVC framework Code, know the basic PHP framework internal implementation mechanism and design ideas; in PHP development has been able to skillfully use the conventional design pattern to apply development (abstract Factory/SINGLETON/Observer/Command chain/policy/adapter and other modes) , it is recommended that you develop your own PHP MVC framework to fully liberalize your development, allow yourself to understand the MVC pattern, and enable you to quickly upgrade your Business Project development, familiarize yourself with PHP's various code optimization methods, and familiarize yourself with most of the PHP security issues. Familiar with basic mechanism of PHP execution (Zend Engine/extended basic working mechanism);
6. C + +:
began to dabble in a certain C + + language, be able to write basic C + + code, familiar with the basic C + + syntax (pointers, array operations, strings, general standard API) and data structures (linked list, tree, hash, queue) have a certain familiarity with the C language development below Linux has a basic understanding of the concept , will be simple makefile file writing, can use simple GCC/GDB program to compile simple debugging work, basic network programming have a general understanding. (This is to lay the groundwork for a higher level)
7. Front End:
8. System Design:
Able to design most of the medium-sized system Web site architecture, database, basic PHP framework selection, performance testing and processing, etc. can be completed similar to: browser----CDN (SQUID)------cache-------database structure of the Web site design and development maintenance , can support millions of to tens of thousands of daily traffic basic website development and maintenance work;
emphasis: In addition to the basic LNMP program, you can also have in-depth learning in a certain direction or field. (Depth dimension development)
Objective: In addition to the ability to complete basic PHP business development, but also to solve most of the deep and complex technical problems, and can be independently designed to complete the large-scale system design and development work, oneself can hold into a technical direction independently, in this piece of comparative professional. (such as MySQL, Nginx, PHP, Redis, and so on in any direction in-depth research)
In addition to the second phase of the ability, under Linux in addition to the general operation and performance monitoring tracking, but also can use a lot of advanced complex commands to complete the work (watch/tcpdump/starce/ldd/ar, etc.); in Shell scripting, has been able to write more complex shell scripts (more than 500 lines) to assist in the completion of a lot of tasks including backup, automated processing, monitoring and other work of the shell, Awk/sed/perl and other applications such as fire pure green, able to manipulate the arbitrary control processing text statistical analysis of various complex formats of data , there is some understanding of the internal mechanism of Linux, the kernel module loading, startup error handling and so on have a basic processing, but also some other related things, such as NFS, Disk Management and so on;
In the second stage of the foundation, has been able to operate the nginx very skilled, can be more in-depth operation of nginx, such as monitoring, performance optimization, complex problem processing and so on; looking at personal interests, more aspects can be considered to focus on the Nginx working principle part of the deep learning, Mainly in the reading source, such as the specific master/worker work mechanism, nginx internal event processing, memory management and so on, but also can learn the development of Nginx extension, you can customize some of your own private extensions, but also to nginx+lua a certain degree of understanding, To see if a better model can be combined, the requirement of this stage is an in-depth understanding of the nginx principle, which can be considered as an in-depth professional in the nginx direction.
In the second stage of the foundation, in the MySQL application, in addition to the previous basic SQL optimization, but also in the completion of a number of complex operations, such as the import and export of large quantities of data, a large number of online data change table structure or delete index fields and other high-risk operations; In addition to the installation configuration, have been able to deal with more complex MySQL problems, such as the tracing of various problems, master-Slave synchronization delay problem resolution, cross-room synchronization data scheme, MySQL high-availability architecture, etc. are involved in understanding; for MySQL application level, the core key technologies of MySQL are familiar, such as the transaction mechanism (Isolation level , locks, etc.), to trigger, partition and other technologies have a certain understanding and application; For MySQL performance, there are disk optimizations (SAS migration to SSD), Server optimizations (memory, server itself configuration), and other core performance tuning options in addition to the two phase (Innodb_log_buffer_ Size/back_log/table_open_cache/thread_cache_size/innodb_lock_wait_timeout, etc.), connection pooling software selection application, to show * (Show Status/show Profile) class operation statements have in-depth understanding, to complete most of the performance problem tracking; MySQL backup technology in-depth familiarity, including disaster recovery, deep understanding of Binlog, hot and cold backup, multi-IDC backup, etc. in the MySQL principle, there is more understanding, For example, the working mechanism of MySQL began to read some of the source code, such as the master-slave Synchronization (replication) technology source learning, or to a storage engine (MYISAM/INNODB/TOKUDB) and so on the source learning understanding, if the conditions allow, You can refer to the CSV engine to develop your own simple storage engine to save some data and enhance your understanding of MySQL, and in this process, if you are interested, you can also consider moving to DBA. MongoDB level, you can consider, for example, in the case of writing less read more and start to apply MongoDB online, or do some online data analysis processing operations, specific scenarios can follow the work, but the core is to better understand the Rmdbs and NoSQL different scenarios below the application, If the conditions or interests allow, you can begin to learn more about MongoDB's working mechanism.
In the second stage of the foundation, can be more in-depth application and learning. Because memcached is not particularly complex, it is suggested that the source code can be read, especially the memory management part, to facilitate in-depth understanding; Redis section, you can do more complex data structure of the application (Zset to do the leaderboard sort operations/ Transaction processing is used to ensure atomicity in the use of the second-class scene application and other applications, and more involved in the AOF and other synchronization mechanisms of learning applications, design a highly available Redis application architecture and clusters; It is suggested that we can learn the source of Redis in depth and apply the knowledge accumulated in the second stage. Especially you can read about it, including core event management, memory management, internal core data structure, and so on. If interest permits, you can become a very professional user of Redis.
As a basic core skill, we need more in-depth learning and application on the basis of the second stage. From the basic code application above, can solve the PHP development encountered 95% of the problem, understand most of the PHP skills, for most of the PHP framework can be quickly used in a day, and understand the pros and cons of various mainstream PHP framework, can quickly facilitate project development to do technology selection; In addition to the general second stage of knowledge, you will learn some of the more biased gate configuration options (PHP auto_prepend_file/auto_append_file), Includes some complex advanced configurations and principles in the extension (such as the memcache.hash_strategy in the memcached extension configuration, apc.mmap_file_mask/apc.slam_defense/in the APC extended configuration Apc.file_update_protection and so on), the working mechanism of PHP, including the PHP-FPM work mechanism (such as PHP-FPM under different configuration machine to open process number calculation and principle), Zend Engine has a basic familiarity (vm/gc/ Stream processing), read the basic PHP kernel source code (or read the related article), the most core data structure of PHP internal mechanism (basic type/array/object) implementation has the understanding, for the core infrastructure (zval/hashtable/ GC) with in-depth learning, ability to perform basic PHP extension development, understanding of some advanced knowledge of extended development (minit/rinit, etc.), familiarity with PHP and apache/nginx different communication interaction details (MOD_PHP/FASTCGI) In addition to developing PHP extensions, consider learning to develop Zend extensions to understand PHP from a lower level.
6. C + +:
On the basis of the second stage, we can have a more in-depth understanding of the C + + language, and can complete the development of small and medium-sized/C + + systems. In addition to the basic second-stage base C/d syntax and data structure, you can learn some special data structures (b-tree/rb-tree/ Skiplist/lsm-tree/trie-tree, etc.) convenient in the special work of the requirements, in the system programming, familiar with multi-process, multi-threaded programming, multi-process situation below to understand the majority of multi-process communication, flexible choice of communication mode (shared memory/semaphore/pipeline, etc.) Multi-threaded programming can solve the problem of lock conflict, and be able to develop and debug multi-thread program, and be familiar with network programming, understand the difference and selection of multi-process model/multithreaded model/asynchronous Network IO Model, and be familiar with the principle and difference of different asynchronous network IO models (select/poll/ EPOLL/IOCP, etc.), and familiar with the common asynchronous framework (ace/ice/libev/libevent/libuv/ Boost.asio, etc.) and use, if leisure can also look at some of the domestic development of the library (such as Muduo), but also can design a high concurrent program architecture (Leader-follow/master-worker, etc.); Problems in Backend server development (memory management, log printing, high concurrency, front-end communication Protocol, service monitoring), knowledge of each backend service RPC communication problem (STRUCT/HTTP/THIRFT/PROTOBUF, etc.) , can be more familiar with the use of GCC and GDB to develop the compilation of debugging procedures, the online program core can be quickly traced after the tracking problem; Common module development, can accumulate or develop some common tools or libraries (such as asynchronous network framework, log library, memory pool, thread pool, etc.), However, the development of whether to use caution, the province of the buried pit to chase the bug;
7. Front End:
8. Other areas of language learning:
In the basic php/c/c++ language aspect has the fundamental accumulation, the suggestion in the current stage may try to learn the different programming language, sees the personal interest hobby, the script language can learn python/ruby and so on, the functional programming language may try Lisp/haskell/scala/ Erlang and the like, static language can try Java/golang, data statistical analysis can understand the R language, if you want to change perspective to do back-end business, you can try node. js and the previous mentioned with the Nginx combination of Nginx_lua and so on. Learning different languages is mainly about raising your horizons and solving the differences between the methods, such as understanding the process/thread, as well as the lightweight association, for example, under the cross-machine communication scenario, Erlang's solution is surprisingly simple, for example, if you do not want to choose C + +, there are similar efficient erlang/ Golang can be used, etc., mainly to enhance the field of vision.
9. Other Professional Direction study:
In this stage, in addition to the basic LNMP skills, will consider a number of other areas of knowledge learning, these are available, look at personal interests and long-term goal direction. At present, the situation can choose more areas, such as cloud computing (distributed storage, distributed computing, virtual machines, etc.), machine learning (data mining, pattern recognition, application to statistics, personalized recommendations), Natural language processing (Chinese word segmentation, etc.), search engine technology, graphic images, speech recognition and so on. In addition to these tall, there are many partial engineering aspects can be learned, such as high-performance systems, mobile development (Android/ios), computer security, embedded systems, hardware and other directions.
10. System Design:
System design on the basis of the second stage, can apply the mastered experience and skills, design a more complex medium and large system, can solve most of the problems of complex systems on the line, complete similar browser----CDN---load balancer, access layer, and so on nginx+php- > Business Cache--database--Complex backend RPC interaction (storage backend, logical back end, anti-cheat backend, external services)--more complex services for back-end Jiangzi, capable of supporting the normal development and maintenance of tens of millions of to hundreds of millions of traffic sites per day.
PS: For the time being no discussion, wait for the next special article to describe the supplement to this part
PS: On the tall, this piece does not unfold the discussion ^_^