PHP engineers face growth bottlenecks
First of all, make it clear that the PHP engineers referred to here refer to those who mainly use PHP to develop Web systems and have not worked in other languages. I have about 3 to 4 years of work experience. I am basically comfortable in developing ordinary Web systems (millions of accesses, less than 1,000-level data, or the business logic is not particularly complex) without any problems. But they will point like this:
◆Do not use other languages except PHP, and may click on shell scripts.
◆Not good at mastering PHP (have not read many PHP manuals, except libraries).
◆The knowledge base is relatively narrow (faced with the demand, apart from using PHP and MySQL, I don’t know other solutions).
◆PHP code is mainly process-oriented, and I think the object-oriented implementation is too convoluted and difficult to understand.
These PHPers lack ideas when they encounter projects that require high performance, high concurrency processing, and large amounts of data, or the business logic is relatively complex (the system needs to solve business problems in multiple fields). They are unable to analyze the essence of the problem and have poor technical judgment. They can quickly find temporary solutions to the problem, but often the system and themselves collapse step by step in the constant temporary solutions. So how do you improve yourself? How can I challenge a more difficult system?
Where are the higher challenges?
Based on my own experience, I will list some specific challenges so that everyone can have a perceptual understanding first.
What are the challenges of high-performance systems?
◆How to choose a Web server? Do you want to use fast-cgi mode;
◆Do you want to use reverse proxy service? Choose full memory cache or hard disk cache?
◆Is load balancing required? Is it based on the application layer or the network layer? How to ensure high reliability?
◆How is the performance of your PHP code, and how is it after using optimization tools? Where is the performance bottleneck? Does it need to be written as an extension of C?
◆What are the characteristics of user access? Is it more reading or writing? Is read-write separation required?
◆How is the data stored? What are the writing and reading speeds? How does access speed change as data increases?
◆How to use cache? How to consider failure? How to ensure data consistency?
What are the challenges of high-complexity systems?
◆Can you identify the fields corresponding to the business? Is it one or multiple?
◆Can the business be reasonably abstracted, so that changes in business rules can be realized at a small cost?
◆Can the consistency and security of data be guaranteed?
◆Whether you have mastered object-oriented analysis and design methods
If you can answer the questions listed here in the affirmative, it means that you are basically technically capable of becoming an architect. . If you can't answer it yet, you need to strengthen in the following directions.
How to improve and break through bottlenecks
If you still can’t answer, you need to strengthen in the following directions:
◆Analyze what you use The principles of the technology and the operating mechanism behind it can improve your technical judgment and improve the correctness of your choice of technical solutions;
◆Learn important knowledge during college, operating system principles, data structures and algorithms . Know that you used to study for exams, but now you need to study for yourself and let yourself know why;
◆Start learning C language again, although you have already learned it in college. This is not only because you may need to write PHP extensions, but also because, in C applications, there is an environment that always cares about performance, memory control, variable life cycle, data structures and algorithms;
◆Learning Object-oriented analysis and design is an effective method for solving complex problems. Learn abstraction, it is the only way to solve complex problems.
How to study effectively is a big problem. "Architecture-centered, use-case driven, iterative development", borrowing this idea, effective learning methods can be expressed as follows: centered on principles, models or mechanisms, task-driven, iterative learning. It's a bit abstract, let's give an example to illustrate how to learn.
Purpose: Learn how to improve processing performance.
Iterable driven task: Find the location by IP. This is a common task for web applications, and the IP database contains about 100,000 rows of records.
First iteration: Implementing the function without considering performance (implemented through PHP)
Because the region cannot be searched directly through KEY (IP), so The simple method of putting it directly into the data or through an associative array will not work. The idea is to sort the data first and then search:
◆How to search by IP? For ordered data, binary search is the fastest.
◆How to sort? Of course you can use the library function sort, but since you are learning, it is better to implement quick sort yourself.
Learning objectives: Sorting algorithms, search algorithms
PHPer's data structure and algorithm foundation is relatively poor. I don't usually have tasks in this area, and I don't study myself, so I lack knowledge in this area. However, the problems solved by programming will ultimately come down to the data structure and the algorithms that operate on this data structure. If the data structure algorithm is always in your mind, you will be able to clearly understand its inner structure when you encounter a problem, and the solution will naturally emerge.
Second iteration: Optimizing data loading and sorting
If you do the first step, it is basically still unavailable, because the data needs to be loaded and sorted every time, which is too time-consuming. The solution is to load and sort the data once and put it in a place where each PHP process can access it. Putting it in Memcache is an easy problem for everyone. In fact, putting it in shared memory (supported by EA and other accelerators) is a faster way, because memcache also has more network operations. Is the data put into shared memory as a whole or in blocks? How to test performance? How to analyze bottlenecks (xdebug)? Driven by these issues, you will learn.
Learning objectives: Methods to detect, locate, and optimize PHP performance; the impact of PHP implementation structure on performance.
The third iteration: Writing PHP extensions
The performance still cannot improve, and I have to enter the C/C world, but from now on you will not only be a PHP As for the all-round engineers on the server side, of course this is a huge challenge for students who have never done C/C.
Learning goals: C/C learning, writing PHP extensions
How to determine the mechanisms and principles that need to be learned? How to find the driving learning tasks? I don’t have any idea about what I need to learn. How can I answer the above two questions? Find out the key points that need to be learned from the positioning of this technology, that is, how it does it (mechanism) and why it can do it. List the most common applications of this technology as a learning task and practice them from simple to difficult.
If I need to learn JavaScript, I have some perceptual knowledge of HTML and CSS. The first thing to understand is that JavaScript is a dynamic language in the Web field, which mainly solves the dynamic interaction of web pages. The key points to learn are as follows:
◆How JavaScript interacts with HTML (mechanism)
◆What are the dynamic characteristics of JavaScript, and how are they different from other dynamic languages? (Language model)
If you are completely self-study, find the key points that need to be learned (mechanism, model, principle). Setting learning tasks is indeed not that easy to grasp. If you find an experienced person to guide you or add a learning team, the speed of learning will indeed be greatly improved.