php swoole+redis 队列结构配置
作者:互联网
server服务端
<?php
//创建Server对象,监听 127.0.0.1:9510端口
$serv = new swoole_server("127.0.0.1", 9510);
$serv->on('start', function () {
echo "start success.\n";
});
$serv->set([
// 'daemonize' => 1,
// 'open_cpu_affinity' => 1,
// 'task_worker_num' => 1,
//'open_cpu_affinity' => 1,
//'task_worker_num' => 100,
//'enable_port_reuse' => true,
// 'http_compression' => false,
'worker_num' => 10,
//'log_file' => __DIR__.'/swoole.log',
// 'reactor_num' => 24,
//'dispatch_mode' => 3,
//'discard_timeout_request' => true,
// 'open_tcp_nodelay' => true,
// 'open_mqtt_protocol' => true,
//'task_worker_num' => 1,
//'user' => 'www-data',
//'group' => 'www-data',
//'daemonize' => true,
// 'ssl_cert_file' => $key_dir.'/ssl.crt',
// 'ssl_key_file' => $key_dir.'/ssl.key',
// 'enable_static_handler' => true,
// 'document_root' => '/home/htf/workspace/php/www.swoole.com/web/'
]);
//监听连接进入事件
$serv->on('connect', function ($serv, $fd) {
echo "Client: Connect.\n";
});
//监听数据接收事件
$serv->on('receive', function ($serv, $fd, $from_id, $data) {
$redis = new redis();
$redis->connect('127.0.0.1', 6379);
$redis->select(1);
//只扔数据到redis 队列处理到数据库
$result = $redis->zAdd('queue',microtime(true),$data);
$serv->send($fd, "queue success");
});
//监听连接关闭事件
$serv->on('close', function ($serv, $fd) {
echo "Client: Close.\n";
});
//启动服务器
$serv->start();
?>
client 客户端
<?php
$cli = new swoole_client(SWOOLE_SOCK_TCP);
$cli->connect('127.0.0.1', 9510);
while(true){
$_sendStr=rand(0,10000)."log";
$cli->send($_sendStr);
sleep(1);
}
$data = $cli->recv();
echo $data;
queue 队列消费
<?php
$redis = new Redis();
$redis->connect('localhost',6379);
$redis->select(1);
swoole_timer_tick(3000,function ()use($redis){
$result = $redis->zRange('queue',0,-1);
if($result){
foreach ($result as $res){
$redis->zRem("queue", $res);
echo "队列中的".$res."处理完毕:".date("Y-m-d H:i:s")."\n";
}
}else{
echo "目前没有任务:".date("Y-m-d H:i:s")."\n";
}
});
标签:serv,swoole,data,redis,echo,num,php,true 来源: https://blog.csdn.net/zhang804633234/article/details/120526354