I was chatting with a former colleague yesterday and complained about PHP and Swoole. He believed that PHP was full of pitfalls and that PHP had great limitations. PHP Swoole is not suitable for high-concurrency servers, and C Swoole is the best solution. C has various data structures. C can open threads and C can share objects. It seems necessary to explain it carefully.
What does PHP lack compared to C/C or Java? Multi-threading, multi-threading, multi-threading...
Yes. PHP is much less multi-threaded than C/C and Java. PHP only has a multi-process solution, so global variables and objects in PHP are not shared, data structures cannot be operated across processes, Socket file descriptors cannot be shared, etc. So PHP has limitations?
Multi-threading seems to be much more powerful than multi-processing. In fact, I can responsibly tell you that multi-threading brings more pitfalls.
Data synchronization issues will drive you crazy. Either sacrifice performance and add locks everywhere, or use hell-hard lock-free concurrent programming. As far as I know, there are very few people in China who can master this skill.
Don’t think that everything will be fine if you add a lock. You will be in trouble with the deadlock problem. When your program logic becomes complex, locks become increasingly difficult to control. Once deadlocked, your program is basically doomed.
If a thread hangs, all threads will exit
Instead, I am looking at multi-process, which is actually much simpler.
With inter-process communication, you can basically achieve any data sharing. For example, a process is used to specifically store data structures and objects, and all data operations of other processes are delivered to this process
Multiple processes do not require locks
Multiple processes can use shared memory data structures to implement some multi-threading functions. For example, Table and Atomic provided by Swoole can realize data sharing, but the cost is very low. Shared memory queues will also be added in the future
The so-called PHP restricts Swoole is completely nonsense. Proper use of Table, Atomic, SendMessage/PipeMessage, and Task provided by Swoole can completely implement asynchronous and non-blocking code logic.
Do programs written in C have better performance?
This is completely blind superstition, the computationally intensive program C does have advantages. The core of the concurrent server is IO, not large-scale intensive computing. C has no advantages from a language perspective. In addition, most of the data structures in C have corresponding implementations in PHP. If it is not possible, you can still solve it by writing a special extension yourself.
A single server with high concurrency can maintain 10W connections and can handle 3-5W messages sent and received per second. This level of performance can already be applied to BAT's core system.
What is the meaning of fast development efficiency?
This colleague also said that although PHP development server is faster than C, C is still needed to pursue the ultimate performance. I'm going to tell you what it means to be efficient. Developing a good program is not an easy task and requires programmers to invest a lot of time and energy. The significance of improved development efficiency is not simply that I can complete the work in less time, but that in the remaining time you can add unit tests, fix bugs, improve user experience, improve details, provide supporting tools, optimize performance, add key logs, and increase Monitor alarms and add disaster recovery plans.
The author of this article is the founder of Swoole, original title: "About C, PHP and Swoole")
Original text: http://rango.swoole.com/archives/473 Author: @汉天峰-Rango