swoole异步任务数据报表生成
<?php include 'vendor/autoload.php'; class server
{
private $serv;
private $db; /**
* [__construct description]
* 构造方法中,初始化 $serv 服务
*/
public function __construct()
{
$this->serv = new swoole_server('0.0.0.0', 9501);
//初始化swoole服务
$this->serv->set(array(
'worker_num' => 1,
'daemonize' => false, //是否作为守护进程,此配置一般配合log_file使用
'max_request' => 1000,
'log_file' => './swoole.log',
'task_worker_num' => 2
)); //设置监听
$this->serv->on('Start', array($this, 'onStart'));
$this->serv->on('WorkerStart', array($this, 'onWorkerStart'));
$this->serv->on('Connect', array($this, 'onConnect'));
$this->serv->on("Receive", array($this, 'onReceive'));
$this->serv->on("Close", array($this, 'onClose'));
$this->serv->on("Task", array($this, 'onTask'));
$this->serv->on("Finish", array($this, 'onFinish')); //开启
$this->serv->start();
} /**
* 连接MySQL
*/
public function connect()
{
$this->db = new medoo([
'database_type' => 'mysql',
'database_name' => 'xxxx',
'server' => '127.0.0.1',
'username' => 'root',
'password' => 'xxxxx',
'prefix' => '',
'charset' => 'utf8'
]);
} /**
* 在worker启动的时候,创建MySQL连接池
* @param $ser
* @param $worker_id
*/
public function onWorkerStart($ser, $worker_id)
{
if ($ser->taskworker) {
$this->connect();
echo "taskWorker Starting ." . spl_object_hash($this->db) . ".........\n";
} else {
echo 'wokerStart...db has=>' . PHP_EOL;
}
} public function onStart($serv)
{
echo SWOOLE_VERSION . " onStart\n";
} public function onConnect($serv, $fd)
{
echo $fd . "Client Connect.\n";
} /**
* 这个发生在worker进程中,当接受到来自mater进程中reactor线程转发过来的客户端
* @param $serv
* @param $fd
* @param $from_id
* @param $data
*/
public function onReceive($serv, $fd, $from_id, $data)
{
echo "Get Message From Client {$fd}:{$data}\n";
$param = array(
'fd' => $fd
);
$serv->task(json_encode($param));
echo "Continue Handle Worker\n";
} public function onClose($serv, $fd)
{
echo "Client Close.\n";
} /**
* 异步任务,用来生成csv表格数据导出
* @param $serv
* @param $task_id
* @param $from_id
* @param $data
* @return string
*/
public function onTask($serv, $task_id, $from_id, $data)
{
echo "This Task {$task_id} from Worker {$from_id}\n";
for ($i = 0; $i < 2; $i++) {
$all_pager = $this->db->count('dtb_checking');
echo '总条数:' . $all_pager . PHP_EOL;
// 其实这里需要判断是否是连接超时,等一系列操作,但是这里就是为了测试数据库连接失效情况。
if ($all_pager === false) {
echo '重新连' . PHP_EOL;
$this->connect();
continue;
}
$fp = fopen(__DIR__ . DIRECTORY_SEPARATOR . rand() . '.csv', 'w');
$page_size = 500;
$page = ceil($all_pager / $page_size);
for ($p = 1; $p <= $page; $p++) {
echo '第' . $p . '页' . PHP_EOL;
$start = ($p - 1) * $page_size;
$list = $this->db->select('dtb_checking', ['id', 'real_name', 'account_no'], ['LIMIT' => [$start, 500]]);
foreach ($list as $k => $row) {
$temp = [
iconv('utf-8', 'gbk', $row['id']),
iconv('utf-8', 'gbk', $row['real_name']),
iconv('utf-8', 'gbk', $row['account_no']),
];
fputcsv($fp, $temp);
}
}
break;
}
return "Task {$task_id}'s result";
} public function onFinish($serv, $task_id, $data)
{
echo "Task {$task_id} finish\n";
echo "Result: {$data}\n";
}
} $server = new server();
swoole异步任务数据报表生成的更多相关文章
- ASP模拟POST请求异步提交数据的方法
这篇文章主要介绍了ASP模拟POST请求异步提交数据的方法,本文使用MSXML2.SERVERXMLHTTP.3.0实现POST请求,需要的朋友可以参考下 有时需要获取远程网站的某些信息,而服务器又限 ...
- flask+sqlite3+echarts3+ajax 异步更新数据
结构: /www | |-- /static |....|-- jquery-3.1.1.js |....|-- echarts.js(echarts3是单文件!!) | |-- /templates ...
- 串行通讯之.NET SerialPort异步写数据
目录 第1章说明 2 1 为什么需要异步写数据? 2 2 异步写数据的代码 2 3 源代码 4 第1章说明 1 为什么需要异步写数据? 如下图所示,以波特率300打开一个串口. ...
- 使用load()方法异步请求数据
使用load()方法通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,它的调用格式为: load(url,[data],[callback]) 参数url为加载服务器地址,可选项d ...
- C# 实现的多线程异步Socket数据包接收器框架
转载自Csdn : http://blog.csdn.net/jubao_liang/article/details/4005438 几天前在博问中看到一个C# Socket问题,就想到笔者2004年 ...
- nettyclient异步获取数据
源代码见,以下主要是做个重要代码记录 http://download.csdn.net/detail/json20080301/8180351 NETTYclient获取数据採用的方式是异步获取数据, ...
- jQuery选取所有复选框被选中的值并用Ajax异步提交数据
昨天和朋友做一个后台管理系统项目的时候涉及到复选框批量操作,如果用submit表单提交挺方便的,但是要实现用jQuery结合Ajax异步提交数据就有点麻烦了,因为我之前做过的项目中基本上没用Ajax来 ...
- echarts异步数据加载(在下拉框选择事件中异步更新数据)
接触echarts 大半年了,从不会到熟练也做过不少的图表,隔了一段时间没使用这玩意,好多东西真心容易忘了.在接触echarts这期间也没有总结什么东西,今天我就来总结一下如何在echart中异步加载 ...
- 从壹开始前后端分离 [ vue + .netcore 补充教程 ] 二九║ Nuxt实战:异步实现数据双端渲染
回顾 哈喽大家好!又是元气满满的周~~~二哈哈,不知道大家中秋节过的如何,马上又是国庆节了,博主我将通过三天的时间,给大家把项目二的数据添上(这里强调下,填充数据不是最重要的,最重要的是要配合着让大家 ...
随机推荐
- 在MVC项目中分页使用MvcPager插件
参考网站 http://www.webdiyer.com/mvcpager/demos/ 这个插件非常简单易用,如果想快速使用 可以参考我这篇文章,其实参考网站也是非常简单的 首先选择你的web项目 ...
- 特征价格(Hedonic price)
特征价格法,又称 Hedonic 模型法和效用估价法,认为房地产由众多不同的特征组成,而房地产价格是由所有特征带给人们的效用决定的.由于各特征的数量及组合方式不同,使得房地产的价格产生差异.因此,如能 ...
- StreamDM:基于Spark Streaming、支持在线学习的流式分析算法引擎
StreamDM:基于Spark Streaming.支持在线学习的流式分析算法引擎 streamDM:Data Mining for Spark Streaming,华为诺亚方舟实验室开源了业界第一 ...
- ASP.NET Core 数据库上下文 - ASP.NET Core 基础教程 - 简单教程,简单编程
原文:ASP.NET Core 数据库上下文 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 数据库上下文 上一章节中我们了解了 Entity Framewo ...
- python 教程 第十一章、 异常
第十一章. 异常 1) try/except/else格式 try: s = raw_input('--> ') except EOFError: print 'Why did you d ...
- OpenGL(十二) 纹理映射(贴图)
OpenGL绘制纹理的步骤: 1. 开启纹理功能 使用glEnable(GL_TEXTURE_2D)开启2D纹理功能,使用glDisable(GL_TEXTURE_2D)关闭纹理,默认情况下纹理是关闭 ...
- Bootstrap按钮组 按钮工具栏 嵌套
@{ Layout = null;}<!DOCTYPE html><html><head> <meta name="viewport&q ...
- xadmin下设置“use_bootswatch = True”无效解决方法
from xadmin import viewsimport xadmin class BaseSetting(object): enable_themes=True use_bootswatch=T ...
- Git 将子文件夹分离为一个新的库
前面的需求 公司Android的项目上,想要将一些module抽取出来,作为一个可以被其它项目上使用的. 所以使用了git submodule的方案. 为了将代码库中的一个文件夹分离后,作为一个单独的 ...
- Win10《芒果TV》商店版更新v3.2.4:新增跨年事件直播、电视台直播,新年快乐
听说半个娱乐圈都来了,<芒果TV>UWP版邀您一起,于2016年12月31日晚,观看<湖南卫视2016·2017跨年演唱会>直播,请更新v3.2.4版,主要新增大事件直播和电视 ...