PHP并发多进程处理利器Gearman使用介绍,利器gearman
PHP并发多进程处理利器Gearman使用介绍,利器gearman
工作中我们有时候会遇到比如需要同时发布数据到多个个服务器上,或者同时处理多个任务。可以使用PHP的curl_multi的方式并发处理请求,但是由于网络和数据以及各个服务器等等的一些情况导致这种并发处理的响应时间很慢,因为在并发请求的过程中还包括记录日志,处理数据等逻辑,等待处理结果并返回,所以也不能友好的满足后台操作的体验。
现在有另外一种方案,利Gearman来实现并发的需求。通过Client将请求发送到Gearman的Jobs,在每个Work中来再来进行curl_multi和数据处理和日志等一些操作,同时用supervisor 来监控Gearman以及Works的进程,这样可以实现一个并行的多进程和负载均衡的方案。
Gearman可以做什么:
异步处理:图片处理,订单处理,批量邮件/通知之类的
要求高CPU或内存的处理:大容量的数据处理,MapReduce运算,日志聚集,视频编码
分布式和并行的处理
定时处理:增量更新,数据复制
限制速率的FIFO处理
分布式的系统监控任务
Gearman工作原理:
使用Gearman的应用通常有三部分组成:一个Client、一个Worker、一个 任务服务器。 Client的作用是提出一个 Job 任务 交给 Job Server 任务服务器。Job Server 会去寻找一个 合适的 Worker 来完成这项任务。Worker 执行由 Client 发送过来的 Job,并且将结果通过 Job Server 返回给 Client。Gearman 提供了 Client 和 Worker 的 API,利用这些API 应用可以同 Gearman Job Server来进行通信。Gearman 内部 Client 和 Worker 之间的通信都是通过 TCP 连接来进行的。
Gearman可以将工作的负载分担到不同的机器中。
安装:
复制代码 代码如下:
rpm -ivh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/x86_64/epel-release-6-5.noarch.rpm
yum install -y gearmand
启动:
gearmand -d
安装PHP Gearman扩展
我都是用pcel来安装的,你也可以下载源码包来编译安装,但是记得要先安装libgearman和re2c,不然扩展编译安装会出错。
pecl install gearman #不成功并提示版本问题可以试试 pecl install gearman-1.0.3,默认好像是1.1.2
编译安装也很简单
复制代码 代码如下:
wget -c http://pecl.php.net/get/gearman-1.1.1.tgz
tar zxvf gearman-1.1.1.tgz
phpize
./configure
make && make install
echo "extension=gearman.so" >> /etc/php.ini
PHP接口函数
Gearman提供很多完善的扩展函数,包括GearmanClient,GearmanJob,GearmanTask,GearmanWorker,具体可以查看PHP官方手册.
这是官方提供的Example其中的一个,相当与一个并发的分发任务处理的例子
<?php $client = new GearmanClient(); $client->addServer(); // initialize the results of our 3 "query results" here $userInfo = $friends = $posts = null; // This sets up what gearman will callback to as tasks are returned to us. // The $context helps us know which function is being returned so we can // handle it correctly. $client->setCompleteCallback(function(GearmanTask $task, $context) use (&$userInfo, &$friends, &$posts) { switch ($context) { case 'lookup_user': $userInfo = $task->data(); break; case 'baconate': $friends = $task->data(); break; case 'get_latest_posts_by': $posts = $task->data(); break; } }); // Here we queue up multiple tasks to be execute in *as much* parallelism as gearmand can give us $client->addTask('lookup_user', 'joe@joe.com', 'lookup_user'); $client->addTask('baconate', 'joe@joe.com', 'baconate'); $client->addTask('get_latest_posts_by', 'joe@joe.com', 'get_latest_posts_by'); echo "Fetching...\n"; $start = microtime(true); $client->runTasks(); $totaltime = number_format(microtime(true) - $start, 2); echo "Got user info in: $totaltime seconds:\n"; var_dump($userInfo, $friends, $posts);
gearman_work.php
<?php $worker = new GearmanWorker(); $worker->addServer(); $worker->addFunction('lookup_user', function(GearmanJob $job) { // normally you'd so some very safe type checking and query binding to a database here. // ...and we're gonna fake that. sleep(3); return 'The user requested (' . $job->workload() . ') is 7 feet tall and awesome'; }); $worker->addFunction('baconate', function(GearmanJob $job) { sleep(3); return 'The user (' . $job->workload() . ') is 1 degree away from Kevin Bacon'; }); $worker->addFunction('get_latest_posts_by', function(GearmanJob $job) { sleep(3); return 'The user (' . $job->workload() . ') has no posts, sorry!'; }); while ($worker->work());
我在3个终端中都执行了gearman_work.php
ryan@ryan-lamp:~$ ps aux | grep gearman* | grep -v grep gearman 1504 0.0 0.1 60536 1264 ? Ssl 11:06 0:00 /usr/sbin/gearmand --pid-file=/var/run/gearman/gearmand.pid --user=gearman --daemon --log-file=/var/log/gearman-job-server/gearman.log --listen=127.0.0.1 ryan 2992 0.0 0.8 43340 9036 pts/0 S+ 14:05 0:00 php /var/www/gearmand_work.php ryan 3713 0.0 0.8 43340 9036 pts/1 S+ 14:05 0:00 php /var/www/gearmand_work.php ryan 3715 0.0 0.8 43340 9036 pts/2 S+ 14:05 0:00 php /var/www/gearmand_work.php
来查看下执行gearman_work.php的结果shell
复制代码 代码如下:
Fetching...
Got user info in: 3.03 seconds:
string(59) "The user requested (joe@joe.com) is 7 feet tall and awesome"
string(56) "The user (joe@joe.com) is 1 degree away from Kevin Bacon"
string(43) "The user (joe@joe.com) has no posts, sorry!"
看到上面的3.03 seconds,说明client请求过去的任务被并行分发执行了。
在实际的生产环境中,为了监测gearmand和work的进程没有被意外退出,我们可以借助Supervisor这个工具.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











동시성 프로그래밍 언어인 Golang의 내장 코루틴 메커니즘과 멀티스레드 작업은 가벼운 멀티태스킹을 가능하게 합니다. 그러나 다중 프로세스 처리 시나리오에서는 서로 다른 프로세스 간의 통신 및 공유 메모리가 프로그램 개발의 주요 문제가 되었습니다. 이번 글에서는 Golang에서 여러 프로세스 간 공유 메모리를 구현하는 응용 방법을 소개합니다. 1. Golang에서 다중 프로세스 구현 방법 Golang에서는 다중 프로세스 동시 처리를 포크(fork), os.Process,

Node.js가 단일 스레드라는 것은 누구나 알고 있지만 Node.js가 일부 특수 작업의 처리 속도를 높이기 위해 다중 스레드 모듈도 제공한다는 사실은 모릅니다. 이 기사를 통해 Node.js의 다중 스레드를 이해할 수 있습니다. js. 다들 도움이 되셨으면 좋겠습니다!

Golang은 멀티 프로세스이고 그 스레드 모델은 MPG 모델입니다. 전체적으로 Go 프로세스와 커널 스레드는 다대다에 해당하므로 우선 멀티 스레드여야 합니다. Golang에는 소위 M 비율 N 모델이 있습니다. N go 루틴은 M 스레드에서 생성될 수 있습니다. 일반적으로 N은 M보다 훨씬 큽니다. 그러나 코루틴의 스케줄링은 Go에 의해 결정됩니다. 개발자는 코루틴 간 동기화를 위해 채널을 사용해야 한다는 점을 강조합니다.

동시 프로그래밍의 잠금 및 동기화 동시 프로그래밍에서는 여러 프로세스 또는 스레드가 동시에 실행되므로 리소스 경합 및 불일치 문제가 발생할 수 있습니다. 이러한 문제를 해결하려면 공유 리소스에 대한 액세스를 조정하는 잠금 및 동기화 메커니즘이 필요합니다. 잠금 개념 잠금은 한 번에 하나의 스레드나 프로세스만 공유 리소스에 액세스할 수 있도록 허용하는 메커니즘입니다. 하나의 스레드나 프로세스가 잠금을 획득하면 잠금이 해제될 때까지 다른 스레드나 프로세스가 리소스에 액세스하는 것이 차단됩니다. 잠금 유형 파이썬에는 여러 유형의 잠금이 있습니다. 뮤텍스 잠금(Mutex): 한 번에 하나의 스레드나 프로세스만 리소스에 액세스할 수 있도록 보장합니다. 조건 변수: 스레드나 프로세스가 특정 조건을 기다린 다음 잠금을 획득하도록 허용합니다. 읽기-쓰기 잠금: 여러 스레드가 동시에 리소스를 읽을 수 있지만 하나의 스레드만 리소스를 쓸 수 있습니다.

PHP 개발 기술: Gearman 예약 작업을 사용하여 MySQL 데이터베이스를 처리하는 방법 소개: Gearman은 작업을 병렬로 실행하고 시스템 처리 기능을 향상시키는 데 사용할 수 있는 오픈 소스 분산 작업 예약 시스템입니다. PHP 개발에서 우리는 시간이 많이 걸리는 작업이나 비동기 작업을 처리하기 위해 Gearman을 사용하는 경우가 많습니다. 이 기사에서는 Gearman을 사용하여 MySQL 데이터베이스 작업을 처리하기 위한 예약된 작업을 구현하는 방법을 소개합니다. 1. Linux 시스템에 Gearman을 설치하면 다음과 같은 작업이 가능합니다.

노드에서 다중 프로세스를 구현하는 방법은 무엇입니까? 노드 프로젝트를 배포하는 방법은 무엇입니까? 다음 기사는 Node.js 다중 프로세스 모델 및 프로젝트 배포에 대한 관련 지식을 습득하는 데 도움이 될 것입니다.

이 기사에서는 PHP 다중 프로세스 개발과 관련된 문제를 주로 소개합니다. 다음은 몇 가지 다중 프로세스 개발 문제에 대한 답변을 함께 살펴보겠습니다. 모두에게 도움이 되세요.

Golang 동시 프로그래밍 기술: 다중 프로세스 모델에 대한 심층 분석 동시 프로그래밍 분야에서 강력한 프로그래밍 언어인 Golang은 간결한 구문과 내장된 동시성 지원으로 인해 개발자들에게 선호됩니다. Golang에서는 고루틴과 채널을 사용하여 동시 프로그래밍을 쉽게 구현할 수 있어 프로그램 성능과 효율성이 향상됩니다. 그러나 일부 특정 시나리오에서는 다중 프로세스 모델을 사용하는 것도 효과적인 동시 프로그래밍 방법입니다. 이 기사에서는 Golang을 사용하는 방법에 대한 심층적인 분석을 제공합니다.
