ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

循环内的PHP sleep()无法更新数据库

2019-11-07 01:16:10  阅读:273  来源: 互联网

标签:flush loops sleep mysql php


我有一个cronjob每分钟触发的php文件.

当php文件被触发时,它会更新数据库,休眠等

它是这样编程的:

$start = microtime(true);
set_time_limit(10);

for($i=0;$i<5;$i++)
{
    updateDB();
    time_sleep_until($start + $i + 1);
}

如果运行这段代码,我看不到数据库中发生任何更改.我注意到的另一件事是,当循环结束时,当我回显某些内容时,我将进行打印.

[edit]我尝试使用flush和ob_flush,但仍然没有为line打印行[/ edit]

我该怎么做才能避免这些错误.数据库需要更新.

我想知道的另一件事是记录这种事情的最佳方法是什么.我可以将结果记录到日志文件中吗?

解决方法:

循环本身看起来不错.如果未更新数据库,则该错误必须出在updateDB()函数中.

至于回声的事情.脚本的输出通常被缓冲.要强制PHP立即打印它,您可以在要刷新输出时调用flush(),也可以在脚本顶部调用ob_implicit_flush(),并且每次打印内容时它将自动刷新.

另外,如果您是通过浏览器调用脚本,则浏览器本身可能会在显示响应之前进一步缓冲响应.

对于日志记录,最简单的方法是在某处选择一个文件,然后使用file_put_contents()打印要记录的任何内容.注意第三个参数的FILE_APPEND标志.

标签:flush,loops,sleep,mysql,php
来源: https://codeday.me/bug/20191107/2002304.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有