GitHub中的Swoole案例(二)

参考于Git地址:https://github.com/LinkedDestiny/swoole-doc

第二章 Swoole的task使用

开启Task功能

开启Task功能只需要在swoole_server的配置项中添加[task_worker_num]

$serv->set(array(
    'task_worker_num' => 8
));

必须给swoole_server绑定两个回调函数

[onTask],[onFinish]

首先是发起一个Task,代码如下:

```php

public function onReceive( swoole_server $serv, $fd, $from_id, $data ) {
    echo "Get Message From Client {$fd}:{$data}\n";

    // send a task to task worker.
    $param = array(
        'fd' => $fd
    );
    // start a task
    $serv->task( json_encode( $param ) );
    echo "Continue Handle Worker\n";
}

```

可以看到,发起一个任务时,只需通过swoole_server对象调用task函数即可发起一个任务。swoole内部会将这个请求投递给task_worker,而当前Worker进程会继续执行。

当一个任务发起后,task_worker进程会响应[onTask]回调函数

```php

public function onTask($serv,$task_id,$from_id, $data) {
   echo "This Task {$task_id} from Worker {$from_id}\n";
   echo "Data: {$data}\n";

   for($i = 0 ; $i < 10 ; $i ++ ) {
       sleep(1);
       echo "Task {$task_id} Handle {$i} times...\n";
   }

   $fd = json_decode( $data , true )['fd'];
   $serv->send( $fd , "Data in Task {$task_id}");
   return "Task {$task_id}'s result";
}

```

在onTask回调中,我们通过task_id和from_id(也就是worker_id)来区分不同进程投递的不同task。当一个task执行结束后,通过return一个字符串将执行结果返回给Worker进程。Worker进程将通过[onFinish]回调函数接收这个处理结果。(Task return的值会传到onFinish回调中)

```php

public function onFinish($serv,$task_id, $data) {
   echo "Task {$task_id} finish\n";
   echo "Result: {$data}\n";
}

```

可以通过在传递的data中存放fd、buff等数据,来延续投递Task之前的工作、

swoole_client有两种工作模式:同步阻塞模式和异步回调模式。

创建一个异步client的代码如下:

```php

$client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC);

```

其中,**SWOOLE_SOCK_ASYNC**选项即表明创建一个异步client。

既然是异步,那当然需要回调函数。swoole_client一共有四个回调函数,如下:

```php

$client->on("connect", function($cli) {
   $cli->send("hello world\n");
});


$client->on("receive", function($cli, $data){
    echo "Received: ".$data."\n";
});


$client->on("error", function($cli){
    echo "Connect failed\n";
});


$client->on("close", function($cli){
    echo "Connection close\n";
});

```

猜你喜欢

转载自blog.csdn.net/qq_36289732/article/details/82285897
今日推荐