成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Swoole筆記(二)

jsummer / 544人閱讀

摘要:配置了參數(shù)后將會啟用功能,務(wù)必要注冊個事件回調(diào)函數(shù)。周期性定時器一次性定時器清除定時器定時器回調(diào)函數(shù)注意最大不得超過。進(jìn)程中不能添加定時器。建議在回調(diào)里寫定時器。定時器示例防止重復(fù)每隔觸發(fā)一次后執(zhí)行此函數(shù)

本文示例代碼詳見:https://github.com/52fhy/swoo...。

重新打開日志

在1.8.11及之后版本支持重新打開日志:向Server主進(jìn)程發(fā)送SIGRTMIN信號。假設(shè)主進(jìn)程id是3427,那么我們可以:

kill -34 3427

注:SIGRTMIN信號的id是34。通過kill -l查看。

那么如何利用這個特征實現(xiàn)每天自動寫入新的日志文件里面呢?

假設(shè)日志文件是/log/swoole.log,我們可以在每天0點運行shell命令:

mv /log/swoole.log /log/$(date -d "-1 day" +%y-%m-%d).log
kill -34 $(ps aux|grep swoole_task|grep swoole_task_matser|grep -v grep|awk "{print $2}") # 找到主進(jìn)程,需要提前命名

我們也可以把master進(jìn)程的PID寫入到文件:

$server->set(array(
    "pid_file" => __DIR__."/server.pid",
));

在Server關(guān)閉時自動刪除PID文件。此選項在1.9.5或更高版本可用。

信號管理

Swoole支持的信號:

SIGKILL -9 pid 強制殺掉進(jìn)程
SIGUSR1 -10 master_pid 重啟所有worker進(jìn)程
SIGUSR2 -12 master_pid 重啟所有task_worker進(jìn)程
SIGRTMIN -34 master_pid 重新打開日志(版本1.8.11+)

master_pid代表主進(jìn)程pid。示例(假設(shè)主進(jìn)程名稱是swoole_server,pid是3427):

# 殺掉進(jìn)程swoole_server
kill -9 $(ps aux|grep swoole_server|grep -v grep|awk "{print $2}")

# 重啟swoole_server的worker進(jìn)程
kill -10 $(ps aux|grep swoole_server|grep -v grep|awk "{print $2}")

# 重新打開日志
kill -34 3427
Task

我們可以在worker進(jìn)程中投遞一個異步任務(wù)到task_worker池中。此函數(shù)是非阻塞的,執(zhí)行完畢會立即返回。worker進(jìn)程可以繼續(xù)處理新的請求。

通常會把耗時的任務(wù)交給task_worker來處理。

我們可以通過如下代碼判斷是Worker進(jìn)程還是TaskWorker進(jìn)程:

function onWorkerStart($serv, $worker_id) {
    if ($worker_id >= $serv->setting["worker_num"]) {  //超過worker_num,表示這是一個task進(jìn)程

    }
}

看一個示例:

set(array(
    "daemonize" => false,
    "reactor_num" => 2,
    "worker_num" => 1,
    "task_worker_num" => 1,
));

$server->on("start", function ($serv){ 
    swoole_set_process_name("swoole_task_matser"); //主進(jìn)程命名
});

$server->on("connect", function ($serv, $fd){ 
    echo "client connect. fd is {$fd}
";
});

$server->on("receive", function ($serv, $fd, $from_id, $data){
    
    echo sprintf("onReceive. fd: %d , data: %s
", $fd, json_encode($data) );
    
    $serv->task(json_encode([
        "fd" => $fd,
        "task_name" => "send_email",
        "email_content" => $data,
        "email" => "[email protected]"
    ]));
});

$server->on("close", function ($serv, $fd){
    echo "client close. fd is {$fd}
";
});

$server->on("task", function (swoole_server $serv, $task_id, $from_id,  $data){
    echo $data;
    
    $data = json_decode($data, true);
    $serv->send($data["fd"], "send eamil to {$data["email"]}, content is : {$data["email_content"]}
");
    
    //echo "task finished";
    //return "task finished";
    $serv->finish("task finished");
});

$server->on("finish", function (swoole_server $serv, $task_id, $data){
    echo "onFinish:" .$data;
});

$server -> start();

這里新建了一個tcp服務(wù)器,參數(shù)里設(shè)置worker_num進(jìn)程為1,task_worker_num為1。

配置了task_worker_num參數(shù)后將會啟用task功能,swoole_server務(wù)必要注冊onTask/onFinish2個事件回調(diào)函數(shù)。如果沒有注冊,服務(wù)器程序?qū)o法啟動。

onTask回調(diào)接收4個參數(shù),分別是serv對象、任務(wù)ID、自于哪個worker進(jìn)程、任務(wù)的內(nèi)容。注意的是,$data必須是字符串。我們可以在worker進(jìn)程里使用`swoole_server->task
($data)`進(jìn)行任務(wù)投遞。

onFinish回調(diào)用于將處理結(jié)果告知worker進(jìn)程,此回調(diào)必須有,但是否被調(diào)用由OnTask決定。在OnTask里使用return或者finish()可以將處理結(jié)果發(fā)生到onFinish回調(diào),否則onFinish回調(diào)是不會被調(diào)用的。也就是說:finish()是可選的。如果worker進(jìn)程不關(guān)心任務(wù)執(zhí)行的結(jié)果,不需要調(diào)用此函數(shù)。onFinish回調(diào)里的$data同樣必須是字符串。

我們新起一個窗口,使用telnet發(fā)送消息到服務(wù)端進(jìn)行測試:
client端:

telnet 127.0.0.1 8088
Trying 127.0.0.1...
Connected to 127.0.0.1.

hhh
send eamil to [email protected], content is : hhh

server端:

client connect. fd is 1
onReceive. fd: 1 , data: "hhh
"
{"fd":1,"task_name":"send_email","email_content":"hhh
","email":"[email protected]"}
onFinish:task finished

onFinish回調(diào)里不使用return或者finish(),我們將看不到server端最后一行輸出。

此時服務(wù)器進(jìn)程模型:

pstree -ap | grep swoole
  |   |       `-php,3190 swoole_task.php
  |   |           |-php,3192 swoole_task.php
  |   |           |   |-php,3194 swoole_task.php
  |   |           |   `-php,3195 swoole_task.php

看到兩個worker進(jìn)程,其中一個是worker進(jìn)程,另外一個是task_worker進(jìn)程。

定時器

Swoole提供強大的異步毫秒定時器,基于timerfd+epoll實現(xiàn)。主要方法:
1、swoole_timer_tick:周期性定時器,類似于JavaScript里的setInterval() 。
2、swoole_timer_after:一次性定時器。
3、swoole_timer_clear:清除定時器。

# 周期性定時器
int swoole_timer_tick(int $ms, callable $callback, mixed $user_param);

# 一次性定時器
swoole_timer_after(int $after_time_ms, mixed $callback_function, mixed $user_param);

# 清除定時器
bool swoole_timer_clear(int $timer_id)

# 定時器回調(diào)函數(shù)
function callbackFunction(int $timer_id, mixed $params = null);

注意:

$ms 最大不得超過 86400000。

manager進(jìn)程中不能添加定時器。

建議在WorkerStart回調(diào)里寫定時器。

定時器示例:

$server->on("WorkerStart", function (swoole_server $server, $worker_id){
    if ($server->worker_id == 0){//防止重復(fù)
        //每隔2000ms觸發(fā)一次
        swoole_timer_tick(2000, function ($timer_id) {
            echo "tick-2000ms
";
        });
        
        //3000ms后執(zhí)行此函數(shù)
        swoole_timer_after(3000, function () {
            echo "after 3000ms.
";
        });
    }
});

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/23062.html

相關(guān)文章

  • PHP多進(jìn)程系列筆記(五)

    摘要:消息隊列更常見的用途是主進(jìn)程分配任務(wù),子進(jìn)程消費執(zhí)行。子進(jìn)程前面加了個,這是為了防止父進(jìn)程還未往消息隊列中加入內(nèi)容直接退出。 前面幾節(jié)都是講解pcntl擴展實現(xiàn)的多進(jìn)程程序。本節(jié)給大家介紹swoole擴展的swoole_process模塊。 swoole多進(jìn)程 swoole_process 是swoole提供的進(jìn)程管理模塊,用來替代PHP的pcntl擴展。 首先,確保安裝的swoole...

    qianfeng 評論0 收藏0
  • swoole 學(xué)習(xí)筆記swoole 真的優(yōu)秀一個框架

    摘要:所以,我感覺學(xué)習(xí),需要一個引導(dǎo)。學(xué)習(xí)參考鏈接喵星球特別厲害的一個官網(wǎng)的幾個框架文檔優(yōu)勢先看一下的結(jié)構(gòu)設(shè)計的應(yīng)用場景的設(shè)計項目中引入一個簡易的具體參考一篇文章,集合和的簡易實例項目中引入結(jié)合致敬 前期學(xué)完了操作系統(tǒng),特別是知道了進(jìn)程,線程 調(diào)度的問題?;貋砜矗l(fā)現(xiàn)了很多細(xì)節(jié)。第三次看文檔,最初經(jīng)一個高手朋友的介紹,看swoole,說文檔寫的賊好。但是看的時候,也是很一頭霧水,只知道把de...

    13651657101 評論0 收藏0
  • Swoole筆記(一)

    摘要:修復(fù)添加超過萬個以上定時器時發(fā)生崩潰的問題增加模塊,下高性能序列化庫修復(fù)監(jiān)聽端口設(shè)置無效的問題等。線程來處理網(wǎng)絡(luò)事件輪詢,讀取數(shù)據(jù)。當(dāng)?shù)娜挝帐殖晒α艘院?,由這個線程將連接成功的消息告訴進(jìn)程,再由進(jìn)程轉(zhuǎn)交給進(jìn)程。此時進(jìn)程觸發(fā)事件。 本文示例代碼詳見:https://github.com/52fhy/swoo...。 簡介 Swoole是一個PHP擴展,提供了PHP語言的異步多線程服務(wù)器...

    SHERlocked93 評論0 收藏0
  • swoole 學(xué)習(xí)筆記

    摘要:安裝準(zhǔn)備或更高版本或更高版本安裝擴展配置支持編輯在其中加入擴展支持服務(wù)端代碼服務(wù)端客戶端代碼測試代碼在命令模式下輸入重新再開一個窗口可以用檢測如服務(wù)端客戶端如上,表示服務(wù)端啟動,客戶端連接服務(wù)端返回消息,一個閉環(huán)形成開發(fā)者頭條 1.安裝準(zhǔn)備 php-5.3.10 // 或更高版本 gcc-4.4 //或更高版本 make autoconf 2.安裝swoole擴展 w...

    justCoding 評論0 收藏0
  • Swoole筆記(四)

    摘要:配合模塊,創(chuàng)建的子進(jìn)程可以異步的事件驅(qū)動模式。默認(rèn)為阻塞讀取。函數(shù)用于將一個加入到的事件監(jiān)聽中。為事件類型的掩碼,可選擇關(guān)閉開啟可讀可寫事件,如,,或者。在程序中使用,可以理解為在進(jìn)程中將此注冊到事件中。 Process Process是swoole內(nèi)置的進(jìn)程管理模塊,用來替代PHP的pcntl擴展。 swoole_process支持重定向標(biāo)準(zhǔn)輸入和輸出,在子進(jìn)程內(nèi)echo不會打印屏...

    yzd 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<