- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个正在记录应用程序的 webapp,我需要那里的备份/恢复/导入/导出功能。我用 laravel 成功地做到了这一点,但与 Phalcon 有一些并发症。我没有在 phalcon 中看到 native 函数会拆分大型 php 脚本的 block 执行。
问题是日志将被备份和恢复以及用户以 ADIF 格式 (adif.org) 导入我有该格式的解析器,它将文件转换为数组数组然后每条记录都应该搜索另一个表,包含 2000 个正则表达式,并在那里找到 3-10 个匹配并将一个表中的导入记录连接到另一个表中的记录(模型关系 hasMany)这意味着每个导入的记录应该有相当长的处理时间。 laravel 以某种方式导入了 3500 条记录,我不知道它将如何处理更多。平均一次导入会包含10000条记录,每条记录需要用2000个正则表达式验证。
主要问题是如何将这个巨大的处理量分成更小的 block ,这样我就不会超时?
最佳答案
这个函数可以完美地完成在一个表中添加 3862 条记录的工作,并且作为处理每条记录的结果,在另一个表中添加 8119 条记录:
public function restoreAction()
{
$this->view->disable();
$user = Users::findFirst($this->session->auth['id']);
if ($this->request->isPost()) {
if ($this->request->isAjax()) {
$frontCache = new CacheData(array(
"lifetime" => 21600
));
$cache = new CacheFile($frontCache, array(
"cacheDir" => "../plc/app/cache/"
));
$cacheKey = $this->request->getPost('fileName').'.cache';
$records = $cache->get($cacheKey);
if ($records === null) {
$rowsPerChunk = 50;
$adifSource = AdifHelper::parseFile(BASE_URL.'/uploads/'.$user->getUsername().'/'.$this->request->getPost('fileName'));
$records = array_chunk($adifSource, $rowsPerChunk);
$key = array_keys($records);
$size = count($key);
}
for ($i = 0; $i < $size; $i++) {
if (!isset($records[$i])) {
break;
}
set_time_limit(50);
for ($j=0; $j < $rowsPerChunk; $j++) {
$result = $records[$i][$j];
if (!isset($result)) {
break;
}
if(isset($result['call'])) {
$p = new PrefixHelper($result['call']);
}
$bandId = (isset($result['band']) && (strlen($result['band']) > 2)) ? Bands::findFirstByName($result['band'])->getId() : null;
$infos = (isset($p)) ? $p->prefixInfo() : null;
if (is_array($infos)) {
if (isset($result['qsl_sent']) && ($result['qsl_sent'] == 'q')) {
$qsl_rcvd = 'R';
} else if (isset($result['eqsl_qsl_sent']) && ($result['eqsl_qsl_sent'] == 'c')) {
$qsl_rcvd = 'y';
} else if (isset($result['qsl_rcvd'])) {
$qsl_rcvd = $result['qsl_rcvd'];
} else {
$qsl_rcvd ='i';
}
$logRow = new Logs();
$logRow->setCall($result['call']);
$logRow->setDatetime(date('Y-m-d H:i:s',strtotime($result['qso_date'].' '.$result['time_on'])));
$logRow->setFreq(isset($result['freq']) ? $result['freq'] : 0);
$logRow->setRst($result['rst_sent']);
$logRow->setQslnote(isset($result['qslmsg']) ? $result['qslmsg'] : '');
$logRow->setComment(isset($result['comment']) ? $result['comment'] : '');
$logRow->setQslRcvd($qsl_rcvd);
$logRow->setQslVia(isset($result['qsl_sent_via']) ? $result['qsl_sent_via'] : 'e');
$logRow->band_id = $bandId;
$logRow->user_id = $this->session->auth['id'];
$success = $logRow->save();
if ($success) {
foreach ($infos as $info) {
if (is_object($info)) {
$inf = new Infos();
$inf->setLat($info->lat);
$inf->setLon($info->lon);
$inf->setCq($info->cq);
$inf->setItu($info->itu);
if (isset($result['iota'])) {
$inf->setIota($result['iota']);
}
if (isset($result['pfx'])) {
$inf->setPfx($result['pfx']);
}
if (isset($result['gridsquare'])) {
$inf->setGrid($result['gridsquare']);
} else if (isset($result['grid'])) {
$inf->setGrid($result['grid']);
}
$inf->qso_id = $logRow->getId();
$inf->prefix_id = $info->id;
$infSuccess[] = $inf->save();
}
}
}
}
}
sleep(1);
}
}
}
}
我知道,脚本需要大量改进,但目前的任务只是让它发挥作用。
关于php - PhalconPHP 中的大进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29584194/
我是 phalconphp 的新手并遵循他们的教程,据我所知,我不需要创建特定的路由组件,并且它应该选择一个路由(如果存在)。我在这里显然可能犯了很大的错误,这意味着纠正我应该很容易!但到目前为止,唯
如何使用PhalconPHP 来向用户显示500错误? 我使用此代码显示404错误(显示错误404.volt View )和500错误(显示错误500.volt View )。 404错误页面将按预期
我刚刚开始开发一个简单的 Restful 服务。我的文件夹结构如下: root - /api --/api/customers.php 例如,在浏览器中我打算调用http://domain/api/c
SELECT * FROM (SELECT post.* FROM post ORDER BY post.timestamp DESC) as post GROUP BY post.topic_id
我像这样实例化我的数据库适配器: return new \Phalcon\Db\Adapter\Pdo\MySql(array( "host" => $options["host"],
我有一个正在记录应用程序的 webapp,我需要那里的备份/恢复/导入/导出功能。我用 laravel 成功地做到了这一点,但与 Phalcon 有一些并发症。我没有在 phalcon 中看到 nat
使用 PhalconPHP,是否可以使用带有注释元数据的 ORM 模型在数据库中创建表?例如,使用 symphony one 可以实现我想要的效果:http://symfony.com/doc/cur
我使用 PhalconPHP 开发了一个网站。该网站在我的本地计算机上运行良好,具有以下规范: PHP Version 7.0.22 Apache/2.4.18 PhalconPHP 3.3.1 还有
我正在使用很棒的 PhalconPHP Framework .我有不同的用户级别并加载正确的 Controller ,我在调度程序类中使用命名空间。 $di->set('dispatcher', fu
我刚刚开始研究一个简单的 restful 服务。我的文件夹结构是这样的: root - /api --/api/customers.php 例如在浏览器中我打算调用http://domain/api/
我有一个 games 表和两个表来存储他们的分数,game_scores 和 thirdparty_game_scores 具有完全相同的结构,如下所示: ----------------------
我有两个表: AuctionPackage $this->belongsTo('id', 'AuctionPackageTranslation', 'auction_package_id', NULL
好的,我有两张 table 。一个称为 Properties,另一个称为 PrInfo。 Properties 是基表,PrInfo 是另一个包含额外信息的表。 我想将它们连接在一起,以便我可以在网站
在 status 为 abanadoned 或 completed 的计划中查找节省的金额的正确语法是什么: $total = self::sum([ 'column' => 'amount_
我有两张 table ;加入的 Pages 和 PagesTranslation。我可以得到所有的数据和翻译;例如,在单个页面上,我可以通过 { page.pagestranslation.getTi
我正在使用 PhalconPHP,到目前为止我遇到的问题很少。 框架很好。 但是,我遇到了一个无法解决的问题。这可能是一件非常简单的事情,但我一直在兜圈子,找不到任何关于这个问题的引用。 问题是,如果
我正在使用 PhalconPHP 1.3.4 构建一个网络应用程序,我试图同时从多个表中选择数据,因为某些值通过关系存储在另一个表中。 我的查询在 MySQL 工作台中运行良好,但是当我尝试使用 Ph
如何将变量传递给主视图,而不仅仅是 Controller View 。 事实上,我想在所有 View 中共享一条数据。我怎样才能在 phalcon 中做到这一点。 例如,在 Laravel 中,我可以
我目前正计划为我的应用程序开发一个 REST API,我一直在研究现有的 PHP 框架,以及加快 PHP 执行速度的现有解决方案。 我的目标是在不影响开发速度的情况下获得最佳性能。 我一直在两者之间犹
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
我是一名优秀的程序员,十分优秀!