This article will take you to explore PHP sockets for the first time, and learn about sockets by making a simple socket server. I hope it will be helpful to you!
#The Chinese name of socket is called socket. This kind of thing is the "encapsulation" of TCP/IP. In reality, the network actually has only four layers. From top to bottom, they are the application layer, the transport layer, the network layer, and the data link layer. The most commonly used http protocol is a protocol belonging to the application layer, and socket can be simply and roughly understood as a thing of the transport layer. If it is still difficult to understand, then add tcp://218.221.11.23:9999 more roughly, do you see it? This is a tcp socket.
Socket gives us the ability to control the transport layer and network layer, thereby obtaining stronger performance and higher efficiency. Socket programming is the most commonly used and mature solution to solve high-concurrency network servers. Any server programmer should master socket programming related skills.
In PHP, there are two sets of functions that can control sockets. One is the socket_series of functions, and the other is the stream_series of functions. Socket_is implemented by PHP directly copying the socket in C language, while stream_is implemented by PHP using the concept of stream to encapsulate it. Let's use the socket_* series functions to simply start this series of articles.
First make the simplest socket server:
Copy after login
Save the file as server.php, and then execute php server.php to run it. We can use telnet on the client. Open another terminal and execute telnet 127.0.0.1 9999 and press Enter. The running results are as follows:
Briefly analyze the above code to explain the process of the tcp socket server:
In the above case, there are two big flaws:
After analyzing the above problems, I thought of the multi-process mentioned earlier. Then we can fork a child process to handle the client's request after accpet receives a request, so that when the accept After two clients, fork a child process to handle the request of the second client. Wouldn't the problem be solved? OK! Let’s demonstrate the code:
Copy after login
Save the code as server.php, and then execute php server.php. The client still uses telnet 127.0.0.1 9999, but this time we open two terminals to execute telnet. It is important to observe that after the first client connects, the second client can also connect. The running results are as follows:
# By receiving the timestamp of the client request, you can see that the server can now serve N clients at the same time. But, then think about it, what if 10,000 clients come to request? At this time, the server will fork out 10,000 child processes to handle each client connection, which will kill people. Fork itself is a system call that wastes system resources. 10,000 forks are enough to cause the system to crash. Even if the system can withstand 1,000 forks, the 1,000 child processes that come out of the fork are enough to drink a pot of system memory. In the end, is it okay? The child process that is easy to fork out will be closed after processing the current client, and it will have to be forked again for the next request. This in itself is a waste and does not conform to the mainstream socialist values. If there is a malicious attack, the number of system forks will increase linearly until the system crashes.
So, we once again propose an enhanced solution. We can estimate the business volume, and then fork a fixed number of child processes when the service starts. Each child process is in an infinite loop and blocked on accept. When a client connection squeezes in, the customer request is processed. After the processing is completed, the connection is only closed but not destroyed, but continues to wait for the next client request. In this way, it not only avoids the huge waste of resources caused by repeated forks of the process, but also protects the system from crashing due to infinite forks through a fixed number of child processes.
Copy after login
After saving the file as server.php, execute php server.php, and then use ps -ef | grep phpserver | grep -v grep to see the server process status:
You can see that the master process exists. In addition, there are 10 sub-processes waiting for service. They can provide services to 10 clients at the same time. Let’s try it through telnet 127.0.0.1 9999. The running result is as follows:
Okay, PHP’s new journey series will start with a simple introduction. La! The next article will describe some more profound theoretical basics.
Recommended learning: "PHP Video Tutorial"
The above is the detailed content of PHP socket learning: take you to make a simple socket server. For more information, please follow other related articles on the PHP Chinese website!