search
HomePHP FrameworkSwooleHow to create a worker in swoole

How to create a worker in swoole

Jan 13, 2020 pm 01:30 PM
swoole

How to create a worker in swoole

swoole is a multi-process model framework. When a process swoole application is started, a total of 2 n m processes will be created, n is the number of worker processes, m is the number of TaskWorker processes, 1 The relationship between a master process and a manager process is as shown in the figure below

How to create a worker in swoole

The Master process is the main process. This process will create work processes/threads such as Manager processes and Reactor threads.

The Worker process serves as the working process of Swoole, and all business logic codes run on this process. When the Reactor thread receives the data from the client, it packages the data and sends it to a Worker process through a pipe.

The worker/task processes in swoole are all forked and managed by the Manager process.

When the child process ends, the manager process is responsible for recycling the child process to avoid becoming a zombie process. And create a new sub-process

When the server is shut down, the manager process will send signals to all sub-processes to notify the sub-processes to shut down the service

When the server is reloaded, the manager process will shut down/restart the sub-processes one by one

fork():

A process, including code, data and resources allocated to the process. The fork() function creates a process that is almost identical to the original process through a system call, that is, the two processes can do exactly the same thing, but if the initial parameters or passed-in variables are different, the two processes can also do different things. .
After a process calls the fork() function, the system first allocates resources to the new process, such as space for storing data and code. Then copy all the values ​​of the original process to the new process, except for a few values ​​that are different from the values ​​of the original process. It is equivalent to cloning oneself.

Recommended learning: swoole tutorial

The above is the detailed content of How to create a worker in swoole. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),