Rumah > pembangunan bahagian belakang > tutorial php > Pengaturcaraan pelbagai proses dan teknologi pengurusan proses dalam PHP

Pengaturcaraan pelbagai proses dan teknologi pengurusan proses dalam PHP

王林
Lepaskan: 2023-05-11 18:52:01
asal
860 orang telah melayarinya
  1. Kata Pengantar

Sebagai bahasa pengaturcaraan yang popular, PHP telah digunakan secara meluas dalam pelbagai bidang. Dalam kes konkurensi yang tinggi, volum data yang besar dan beban yang tinggi, ciri satu benang PHP akan menyebabkan kesesakan prestasi. Untuk menggunakan sepenuhnya semua sumber CPU, memori dan IO mesin dan meningkatkan prestasi dan kebolehskalaan program, teknologi berbilang proses perlu digunakan.

  1. Apakah pengaturcaraan berbilang proses?

Dalam sistem pengendalian, proses merujuk kepada program yang sedang dilaksanakan. Pengaturcaraan berbilang proses merujuk kepada membahagikan program kepada beberapa proses untuk pelaksanaan Setiap proses adalah bebas antara satu sama lain dan boleh dilaksanakan secara serentak, dengan itu meningkatkan keupayaan pemprosesan dan pemprosesan program.

Dalam PHP, perpustakaan sambungan pcntl biasanya digunakan untuk melaksanakan pengaturcaraan berbilang proses.

  1. Bagaimana untuk menggunakan perpustakaan sambungan PCNTL?

Pertama, anda perlu mendayakan perpustakaan sambungan pcntl dalam fail php.ini.

extension=pcntl.so

Gunakan fungsi pcntl_fork() untuk mencipta proses anak baharu. Proses anak dan proses induk berkongsi segmen kod, segmen data dan segmen tindanan, tetapi masing-masing mempunyai ruang berjalan bebas dan identiti proses.

$pid = pcntl_fork();
if ($pid == -1) {

// fork失败
Salin selepas log masuk

} else if ($pid) {

// 父进程
Salin selepas log masuk

} else {

// 子进程
Salin selepas log masuk

}

Gunakan fungsi pcntl_waitpid() untuk menunggu proses anak tamat dan mendapatkan kod status yang dikembalikan oleh proses anak.

$status = null;
$pid = pcntl_waitpid($child_pid, $status, WNOHANG);
jika ($pid == -1) {

// waitpid错误
Salin selepas log masuk

} lain if ($pid) {

// 子进程已结束,$status中是子进程的状态码
Salin selepas log masuk

} else {

// 子进程还在运行
Salin selepas log masuk

}

Gunakan fungsi pcntl_sigprocmask() untuk menutup/memulihkan isyarat yang diterima oleh proses.

pcntl_sigprocmask(SIG_BLOCK, [SIGTERM]);
// Selepas menerima isyarat SIGTERM, proses tidak akan ditamatkan serta-merta, tetapi akan menunggu sehingga proses diproses sebelum keluar dari
pcntl_signal(SIGTERM , function() {

// 处理SIGTERM信号
Salin selepas log masuk

});
pcntl_sigprocmask(SIG_UNBLOCK, [SIGTERM]);

  1. Teknologi pengurusan proses

Secara praktikal aplikasi, ia diperlukan Mengurus proses, termasuk memulakan, menghentikan, memulakan semula, memantau dan fungsi proses lain. Teknologi pengurusan proses yang biasa digunakan adalah seperti berikut:

4.1 Penyelia

Penyelia ialah pengurus proses yang boleh memulakan, menghentikan, memulakan semula dan memantau berbilang proses. Ia mempunyai klien dan pelayan Klien menghantar arahan kawalan kepada pelayan, dan pelayan mengawal status berjalan proses. Penyelia juga menyokong kumpulan proses, pengelogan, mula semula automatik jika permulaan program gagal, skrip tersuai dan fungsi lain.

Fail konfigurasi penyelia sangat mudah, menggunakan format INI dan mudah diselenggara. Berikut ialah contoh fail konfigurasi Penyelia:

[program:myprogram]
command=/usr/bin/php /path/to/myprogram.php
process_name=%(program_name) s_% (process_num)02d
numprocs=4
directory=/path/to/myprogram
autostart=true
autorestart=true
user=myuser
stdout_logfile=/var/log /myprogram .log
stderr_logfile=/var/log/myprogram.err

4.2 Systemd

Systemd ialah sistem permulaan yang digunakan untuk menggantikan sysvinit dan upstart, dan juga boleh digunakan sebagai pengurus proses. Ia boleh memulakan, menghentikan, memulakan semula dan memantau berbilang proses, dan menyokong fungsi seperti kebergantungan proses, mula semula automatik, pertanyaan status proses dan sekatan sumber.

Fail konfigurasi Systemd agak rumit dan menggunakan format fail systemd.units. Berikut ialah contoh fail konfigurasi Systemd:

[Unit]
Description=myprogram
After=network.target

[Service]
Type=simple
ExecStart=/usr/bin/php /path/to/myprogram.php
PIDFile=/run/myprogram.pid
Restart=on-failure
User=myuser

[ Pasang]
WantedBy=multi-user.target

4.3 Docker

Docker ialah enjin kontena aplikasi sumber terbuka yang boleh membuat, menggunakan dan menjalankan bekas dengan cepat. Dalam Docker, setiap bekas adalah proses bebas dan bekas itu boleh diurus menggunakan alat baris arahan Docker atau API.

Docker menyediakan persekitaran seperti sistem pengendalian, termasuk sistem fail, ruang proses, rangkaian, dsb., di mana sebarang aplikasi boleh dijalankan. Docker juga menyokong penggunaan teragih, orkestrasi kontena, gudang imej dan fungsi lain.

  1. Ringkasan

Pengaturcaraan berbilang proses dan teknologi pengurusan proses digunakan secara meluas dalam pengaturcaraan rangkaian dan pengaturcaraan sistem. Menggunakan pelbagai proses boleh meningkatkan keupayaan pemprosesan serentak dan pemprosesan program Menggunakan pengurus proses boleh menguruskan permulaan, berhenti, memulakan semula, pemantauan dan operasi lain proses. Dalam aplikasi praktikal, teknologi yang sesuai perlu dipilih untuk pembangunan dan penggunaan berdasarkan keadaan sebenar.

Atas ialah kandungan terperinci Pengaturcaraan pelbagai proses dan teknologi pengurusan proses dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan