一、准备工作
1、为了防止,处理业务途中出现的宕机,请配置好gearman的持久化方式。
2、使用gearmanManager来管理我们的worker脚本,方便测试。
上述两条请看我之前写的两篇文章
二、编写测试脚本
sendEmail.php代码如下:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<?php
function sendEmail( $job ) {
$workId = uniqid();
$data = json_decode( $job ->workload(), true);
sleep(1);
echo "workId: {$workId} 发送 {$data['email']} 成功\n" ;
}
|
client.php代码如下:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<?php
$client = new GearmanClient();
$client ->addServer( '127.0.0.1' , 4730);
$cnt = 5000;
$ret = array ();
for ( $i = 0; $i < $cnt ; ++ $i ) {
$ret [ $i ] = $client ->doBackground( 'sendEmail' , json_encode( array (
'email' => "{$i}@qq.com" ,
'title' => "邮件标题{$i}" ,
'body' => "我是内容{$i}" ,
)));
}
|
三、修改gearmanManager中配置信息
我的gearmanManager是安装在/data/GearmanManager/下
?
1
|
> vi /data/GearmanManager/etc/GearmanManager .ini
|
添加如下信息,我们为sendEmail启动五个进程
?
1
2
3
4
5
|
[sendEmail]
;指定5个进程
dedicated_count=5
;5个进程都只做sendEmail工作
dedicated_only=1
|
四、启动gearman
?
1
2
3
4
5
6
7
|
> gearmand -d -q mysql \
--mysql-host=192.168.1.100 \
--mysql-port=3306 \
--mysql-user=gearman \
--mysql-password=123456 \
--mysql-db=gearman \
--mysql-table=gearman_queue &
|
五、启动gearmanManager
?
1
2
|
> cd /data/GearmanManager
> . /bin/pecl_manager .php -c /data/GearmanManager/etc/GearmanManager .ini -vvv
|
六、运行client.php
?
1
|
> /data/php56/bin/php /data/client .php
|
当我们对pecl_manager.php进行ctrl+c时,强行关闭worker,client.php那边仍可正常的发送请求,不过数据都被保存在了mysql中。
当我们重新把worker启动时,gearman会重新载入没有处理的进行处理。
我的mysql是装在主机的,虚拟机里装了gearman,如果有朋友发现gearman无法连接mysql,可暂时关闭win10防火墙,和开启win10被ping的回显。
|