Init Repo

This commit is contained in:
root
2019-09-06 23:53:10 +08:00
commit f0ef89dfbb
7905 changed files with 914138 additions and 0 deletions

49
vendor/swoole/examples/task/http.php vendored Executable file
View File

@ -0,0 +1,49 @@
<?php
$serv = new swoole_http_server("127.0.0.1", 9501);
$serv->set(array(
'worker_num' => 1,
'task_worker_num' => 1,
// 'task_ipc_mode' => 3,
// 'message_queue_key' => 0x70001001,
//'task_tmpdir' => '/data/task/',
));
$serv->on('Request', function ($req, $resp)
{
$data = str_repeat('A', 8192 * 10);
global $serv;
$serv->task(array($data, 1000), -1, function ($serv, $task_id, $data) use ($resp)
{
$resp->end("Task#$task_id finished." . PHP_EOL);
});
});
$serv->on('Task', function (swoole_server $serv, $task_id, $from_id, $data) {
//echo "#{$serv->worker_id}\tonTask: [PID={$serv->worker_pid}]: task_id=$task_id, data_len=".strlen($data).".".PHP_EOL;
// $serv->finish($data);
return $data;
});
$serv->on('Finish', function (swoole_server $serv, $task_id, $data) {
echo "Task#$task_id finished, data_len=".strlen($data).PHP_EOL;
});
$serv->on('workerStart', function($serv, $worker_id) {
global $argv;
if ($serv->taskworker)
{
swoole_set_process_name("php {$argv[0]}: task_worker");
}
else
{
swoole_set_process_name("php {$argv[0]}: worker");
}
});
$serv->on('workerStop', function (swoole_server $serv, $id) {
echo "stop\n";
var_dump($id);
});
$serv->start();

74
vendor/swoole/examples/task/msg_push.php vendored Executable file
View File

@ -0,0 +1,74 @@
<?php
echo "Sending text to msg queue.\n";
class SwooleTask
{
protected $queueId;
protected $workerId;
protected $taskId = 0;
function __construct($key, $workerId = 0)
{
$this->queueId = msg_get_queue($key);
if ($this->queueId === false)
{
throw new \Swoole\Exception("msg_get_queue() failed.");
}
$this->workerId = $workerId;
}
protected function pack($data)
{
$fromFd = 0;
$type = 7;
if (!is_string($data))
{
$data = serialize($data);
$fromFd |= 2;
}
if (strlen($data) >= 8180)
{
$tmpFile = tempnam('/tmp/', 'swoole.task');
file_put_contents($tmpFile, $data);
$data = pack('l', strlen($data)) . $tmpFile . "\0";
$fromFd |= 1;
$len = 128 + 24;
}
else
{
$len = strlen($data);
}
//typedef struct _swDataHead
//{
// int fd;
// uint16_t len;
// int16_t from_id;
// uint8_t type;
// uint8_t flags;
// uint16_t from_fd;
//} swDataHead;
return pack('lSsCCS', $this->taskId++, $len, $this->workerId, $type, 0, $fromFd) . $data;
}
function dispatch($data)
{
if (!msg_send($this->queueId, $this->workerId + 1, $this->pack($data), false))
{
return false;
}
else
{
return true;
}
}
}
$task = new SwooleTask(0x70001001);
//普通字符串
$task->dispatch("Hello from PHP!");
//数组
$task->dispatch(array('data' => str_repeat('A', 1024), 'type' => 1));
//大包
$task->dispatch(array('data' => str_repeat('B', 1024 * 32), 'type' => 2));

37
vendor/swoole/examples/task/shared_client.php vendored Executable file
View File

@ -0,0 +1,37 @@
<?php
$client = new swoole_client(SWOOLE_SOCK_TCP);
if(!$client->connect('127.0.0.1', 9501))
{
exit("connect failed\n");
}
function help()
{
echo "get eg: php ".__FILE__." get key".PHP_EOL;
echo "set eg: php ".__FILE__." set key value".PHP_EOL;
echo "del eg: php ".__FILE__." del key".PHP_EOL;
echo "task eg: php ".__FILE__." task key".PHP_EOL;
exit();
}
if($argc < 3) {
help();
}
$keys = array(
1 => 'cmd',
2 => 'key',
3 => 'val'
);
$sends = array();
foreach ($keys as $i => $key)
{
if (isset($argv[$i]))
{
$sends[$key] = $argv[$i];
}
}
if (empty($sends))
{
help();
}
$client->send(serialize($sends));
$data = $client->recv();
echo $data . PHP_EOL;

142
vendor/swoole/examples/task/shared_server.php vendored Executable file
View File

@ -0,0 +1,142 @@
<?php
$serv = new swoole_server("127.0.0.1", 9501);
$serv->set(array(
'worker_num' => 1,
//'open_eof_check' => true,
//'package_eof' => "\r\n",
'task_worker_num' => 1,
//'dispatch_mode' => 2,
//'daemonize' => 1,
//'heartbeat_idle_time' => 5,
//'heartbeat_check_interval' => 5,
));
function my_onStart($serv)
{
echo "MasterPid={$serv->master_pid}|Manager_pid={$serv->manager_pid}\n";
echo "Server: start.Swoole version is [".SWOOLE_VERSION."]\n";
//$serv->addtimer(1000);
}
function my_onShutdown($serv)
{
echo "Server: onShutdown\n";
}
function my_onTimer($serv, $interval)
{
echo "Server:Timer Call.Interval=$interval\n";
}
function my_onClose($serv, $fd, $from_id)
{
//echo "Client: fd=$fd is closed.\n";
}
function my_onConnect($serv, $fd, $from_id)
{
//throw new Exception("hello world");
// echo "Client:Connect.\n";
}
function my_onWorkerStart($serv, $worker_id)
{
global $argv;
if ($worker_id >= $serv->setting['worker_num']) {
swoole_set_process_name("php {$argv[0]} task worker");
} else {
swoole_set_process_name("php {$argv[0]} event worker");
}
//echo "WorkerStart|MasterPid={$serv->master_pid}|Manager_pid={$serv->manager_pid}|WorkerId=$worker_id\n";
//$serv->addtimer(500); //500ms
}
function my_onWorkerStop($serv, $worker_id)
{
echo "WorkerStop[$worker_id]|pid=".posix_getpid().".\n";
}
function my_onReceive(swoole_server $serv, $fd, $from_id, $rdata)
{
$data = unserialize($rdata);
if (isset($data['cmd']))
{
switch ($data['cmd'])
{
case 'get':
$s = microtime(true);
$res = $serv->taskwait($data, 0.5, 0);
echo "use " . ((microtime(true) - $s) * 1000) . "ms\n";
$serv->send($fd, PHP_EOL . "get " . $res['key'] . ": " . $res['val']);
break;
case "set":
$serv->task($data, 0);
$serv->send($fd, "OK\n");
break;
case "del":
$serv->task($data, 0);
break;
case "reload":
break;
default:
echo "server:" . $data . PHP_EOL;
}
}
}
function my_onTask(swoole_server $serv, $task_id, $from_id, $data)
{
static $datas = array();
if (isset($data['cmd']))
{
switch ($data['cmd']) {
case 'get':
$key = $data['key'];
$val = isset($datas[$key]) ? $datas[$key] : "";
$serv->finish(array('key'=>$key, 'val' => $val));
break;
case "set":
$key = $data['key'];
$val = $data['val']."_".$from_id;
$datas[$key] = $val;
return;
break;
case "del":
$key = $data['key'];
if(isset($datas[$key])) {
unset($datas[$key]);
}
break;
case "task":
$key = $data['key'];
echo "Do task " . $key . PHP_EOL;
break;
}
}
echo "AsyncTask[PID=".posix_getpid()."]: task_id=$task_id.".PHP_EOL;
// $serv->finish("OK");
}
function my_onFinish(swoole_server $serv, $task_id, $from_worker_id, $data)
{
echo "AsyncTask Finish: Connect.PID=" . posix_getpid() . PHP_EOL;
}
function my_onWorkerError(swoole_server $serv, $worker_id, $worker_pid, $exit_code)
{
echo "worker abnormal exit. WorkerId=$worker_id|Pid=$worker_pid|ExitCode=$exit_code\n";
}
$serv->on('Start', 'my_onStart');
$serv->on('Connect', 'my_onConnect');
$serv->on('Receive', 'my_onReceive');
$serv->on('Close', 'my_onClose');
$serv->on('Shutdown', 'my_onShutdown');
$serv->on('Timer', 'my_onTimer');
$serv->on('WorkerStart', 'my_onWorkerStart');
$serv->on('WorkerStop', 'my_onWorkerStop');
$serv->on('Task', 'my_onTask');
$serv->on('Finish', 'my_onFinish');
$serv->on('WorkerError', 'my_onWorkerError');
$serv->start();

50
vendor/swoole/examples/task/task.php vendored Executable file
View File

@ -0,0 +1,50 @@
<?php
$serv = new swoole_server("127.0.0.1", 9501,SWOOLE_BASE);
$serv->set(array(
//'worker_num' => 1,
'task_worker_num' => 1,
// 'task_ipc_mode' => 3,
// 'message_queue_key' => 0x70001001,
//'task_tmpdir' => '/data/task/',
));
$serv->on('Receive', function(swoole_server $serv, $fd, $from_id, $data) {
//AsyncTask
$data = trim($data);
//$data = str_repeat('A', 8192*100);
// if ($data == 'async')
if(false)
// if (true)
{
$task_id = $serv->task($data, 0);
$serv->send($fd, "Dispath AsyncTask: id=$task_id\n");
}
//Sync Task
else
{
$res = $serv->taskwait($data, 10);
echo "Dispath SyncTask: result=".$res.PHP_EOL;
}
//$serv->send($fd, "OK\n");
});
$serv->on('Task', function (swoole_server $serv, $task_id, $from_id, $data) {
echo "#{$serv->worker_id}\tonTask: [PID={$serv->worker_pid}]: task_id=$task_id, data_len=".strlen($data).".".PHP_EOL;
$serv->finish($data);
// return $data;
});
$serv->on('Finish', function (swoole_server $serv, $task_id, $data) {
echo "Task#$task_id finished, data_len=".strlen($data).PHP_EOL;
});
$serv->on('workerStart', function($serv, $worker_id) {
global $argv;
if($worker_id >= $serv->setting['worker_num']) {
swoole_set_process_name("php {$argv[0]}: task_worker");
} else {
swoole_set_process_name("php {$argv[0]}: worker");
}
});
$serv->start();

42
vendor/swoole/examples/task/task_coro.php vendored Executable file
View File

@ -0,0 +1,42 @@
<?php
$serv = new swoole_server("127.0.0.1", 9501);
$serv->set(array(
'worker_num' => 1,
'task_worker_num' => 4,
//'task_tmpdir' => '/data/task/',
));
$serv->on('Receive', function(swoole_server $serv, $fd, $from_id, $data) {
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
//等待所有Task结果返回超时为10s
var_dump($tasks);
$results = $serv->taskWaitMulti($tasks, 2);
var_dump($results);
});
$serv->on('Task', function (swoole_server $serv, $task_id, $from_id, $data) {
echo "onTask: [ID={$serv->worker_id}]: task_id=$task_id, data=$data, data_len=".strlen($data).".".PHP_EOL;
//测试超时
if ($serv->worker_id % 4 == 3)
{
sleep(3);
}
elseif ($serv->worker_id % 4 == 2)
{
usleep(1500000);
}
elseif ($serv->worker_id % 4 == 1)
{
usleep(200000);
}
return "hello world.[{$data}]";
});
$serv->on('Finish', function (swoole_server $serv, $task_id, $data) {
echo "Task#$task_id finished, data_len=".strlen($data).PHP_EOL;
});
$serv->start();

46
vendor/swoole/examples/task/task_num.php vendored Executable file
View File

@ -0,0 +1,46 @@
<?php
$serv = new swoole_server("127.0.0.1", 9501);
$serv->set(array(
'worker_num' => 1,
'task_worker_num' => 2,
//'task_tmpdir' => '/data/task/',
));
$serv->on('Receive', function(swoole_server $serv, $fd, $from_id, $data) {
//AsyncTask
$data = intval($data);
for($i=0;$i<$data;$i++) {
$tid = mt_rand(0,1);
echo "data:{$i} to task: {$tid} ".PHP_EOL;
$serv->task($i, $tid);
}
});
$serv->on('Task', function (swoole_server $serv, $task_id, $from_id, $data) {
echo "onTask: [PID=".posix_getpid()."]: task_id=$task_id, data_len=".strlen($data).".".PHP_EOL;
sleep(10);
//$serv->finish($data);
echo 'finish'.PHP_EOL;
return;
});
$serv->on('Finish', function (swoole_server $serv, $task_id, $data) {
echo "Task#$task_id finished, data_len=".strlen($data).PHP_EOL;
});
$serv->on('Timer', function(swoole_server $serv, $time) {
echo "{$time} call".PHP_EOL;
print_r($serv->stats());
});
$serv->on('workerStart', function($serv, $worker_id) {
global $argv;
if($worker_id >= $serv->setting['worker_num']) {
swoole_set_process_name("php {$argv[0]}: task_worker");
} else {
$serv->addtimer(5000);
swoole_set_process_name("php {$argv[0]}: worker");
}
});
$serv->start();

33
vendor/swoole/examples/task/task_queue.php vendored Executable file
View File

@ -0,0 +1,33 @@
<?php
$serv = new swoole_server("127.0.0.1", 9501, SWOOLE_BASE);
$serv->set(array(
//'worker_num' => 1,
'task_worker_num' => 4,
'task_ipc_mode' => 3,
'message_queue_key' => 0x70001001,
'task_tmpdir' => '/data/task/',
));
$serv->on('Receive', function(swoole_server $serv, $fd, $from_id, $data) {
});
$serv->on('Task', function (swoole_server $serv, $task_id, $from_id, $data) {
echo "#{$serv->worker_id}\tonTask: [PID={$serv->worker_pid}]: TASK_ID=$task_id]\n";
var_dump($data);
});
$serv->on('Finish', function (swoole_server $serv, $task_id, $data) {
echo "Task#$task_id finished, data_len=".strlen($data).PHP_EOL;
});
$serv->on('workerStart', function($serv, $worker_id) {
global $argv;
if($worker_id >= $serv->setting['worker_num']) {
swoole_set_process_name("php {$argv[0]}: task_worker");
} else {
swoole_set_process_name("php {$argv[0]}: worker");
}
});
$serv->start();

53
vendor/swoole/examples/task/task_stream.php vendored Executable file
View File

@ -0,0 +1,53 @@
<?php
$serv = new swoole_server("127.0.0.1", 9501, SWOOLE_BASE);
$serv->set(array(
'worker_num' => 1,
'task_worker_num' => 1,
'task_ipc_mode' => 4,
// 'message_queue_key' => 0x70001001,
));
$serv->on('Receive', function(swoole_server $serv, $fd, $from_id, $data) {
//AsyncTask
$data = trim($data);
//$data = str_repeat('A', 8192*100);
// if ($data == 'async')
// if(false)
if (true)
{
$task_id = $serv->task($data, 0);
$serv->send($fd, "Dispath AsyncTask: id=$task_id\n");
}
//Sync Task
else
{
$res = $serv->taskwait($data, 10);
echo "Dispath SyncTask: result=".$res.PHP_EOL;
}
//$serv->send($fd, "OK\n");
});
$serv->on('Task', function (swoole_server $serv, $task_id, $from_id, $data) {
echo "#{$serv->worker_id}\tonTask: [PID={$serv->worker_pid}]: task_id=$task_id, data_len=".strlen($data).".".PHP_EOL;
$serv->finish($data);
return $data;
});
$serv->on('Finish', function (swoole_server $serv, $task_id, $data) {
echo "Task#$task_id finished, data_len=".strlen($data).PHP_EOL;
});
$serv->on('workerStart', function($serv, $worker_id) {
global $argv;
if ($serv->taskworker)
{
swoole_set_process_name("php {$argv[0]}: task_worker");
}
else
{
swoole_set_process_name("php {$argv[0]}: worker");
}
echo "Worker#$worker_id, pid=".posix_getpid()." start".PHP_EOL;
});
$serv->start();