草庐IT

PHP脚本无故突然停止工作

coder 2023-06-19 原文

我正在运行一个大型 PHP 脚本,它可能需要 一整天 才能完成它的工作,
这个脚本从 MySQL 数据库中获取数据并将其与 curl 一起使用来测试东西..它用大约 40,000 记录来完成..
因此,为了让它在后台运行所需的时间,我使用终端来执行它。在 PHP 脚本本身中,它具有这些设置以确保它尽可能长时间地运行,直到它完成:

set_time_limit(0); // run without timeout limit

因为我从另一个单独的 PHP 脚本执行它,所以我使用了这个函数

ignore_user_abort(1); // ignore my abort

因为直接从命令行执行它,它会给我两个选择..
1)等到脚本完成
2)取消整个过程

在搜索之后,有一篇文章给了我第三种选择,它可以在后台运行它尽可能长的时间通过创建一个外部 PHP 脚本来在后台执行主要的 BIG PHP 脚本使用这个函数:

exec("php bigfile.php");

这意味着我可以从浏览器正常打开这个外部页面并退出它而不必担心,因为 ignore_user_abort 会保持它在后台运行。这仍然不是问题

问题是.. 在一段未知的时间后,脚本停止工作.. 我怎么知道的? 我告诉它在外部文件中写入它工作的每条记录的当前日期时间上,所以我每次都刷新到那个外部页面,看看它是否停止更新,

经过一段未知的时间后,它实际上无缘无故地停止了,脚本没有说停止或任何东西..如果发生任何错误,我告诉它跳过记录(没有发生任何错误,他们都在同一个行,如果一个有效,那么所有都应该有效)

然而,我的主要疑虑在于:

  • Apache 有一个终止它的超时
  • 这不是在后台执行 PHP 脚本的正确方法
  • 某处超时,无论是在 PHP 还是 Apache 或 (MySQL !?)
    这就是我最大的疑问所在。MySQL,它会停止从 while 向 PHP 循环提供记录吗?如果发生错误,它会导致整个脚本崩溃吗?它是否有任何导致整个脚本崩溃的超时?

如果这些都不适用于它,是否有任何方法可以记录现在脚本中到底发生了什么?或者它为什么会崩溃?任何详细的方法来记录一切?


更新:

我在 /var/log/messages 文件中找到了这个:

Dec 29 16:29:56 i0sa shutdown[5609]: shutting down for system halt
Dec 29 16:30:14 i0sa exiting on signal 15
Dec 29 16:30:28 i0sa syslogd 1.5.0#6: restart.
Dec 29 16:50:28 i0sa -- MARK --
            .....
Dec 29 18:50:31 i0sa -- MARK --
Dec 29 19:02:36 i0sa shutdown[3641]: shutting down for system halt
Dec 29 19:03:11 i0sa exiting on signal 15
Dec 29 19:03:48 i0sa syslogd 1.5.0#6: restart.

它说系统暂停..我会尝试确保在未来的崩溃和比赛时间中可能是这样,这会导致它吗?为什么? memory_limit 是 128M,而我有 2GB 服务器内存 ram,可能是这样吗?

P.S.:我手动重启了几次服务器..但是这个说 shutdown and halt ?

最佳答案

对于这种情况,我会像这样使用成功的 nohup 命令:

nohup php  /home/cron.php >/dev/null  2>&1 &

之后您可以检查脚本是否正在运行:

jobs -l

注意: 当您使用 nohup 命令时,php 文件的路径必须是绝对路径而不是相对路径。 我认为从一个 php 文件调用另一个 php 文件只是为了防止执行在完成工作之前停止不是很优雅。

外部引用: http://en.wikipedia.org/wiki/Nohup

还要确保您的脚本中没有内存泄漏,导致脚本在一段时间后因“内存不足”而崩溃。

关于PHP脚本无故突然停止工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14090316/

有关PHP脚本无故突然停止工作的更多相关文章

  1. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  4. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  5. ruby-on-rails - 独立 ruby​​ 脚本的配置文件 - 2

    我有一个在Linux服务器上运行的ruby​​脚本。它不使用rails或任何东西。它基本上是一个命令行ruby​​脚本,可以像这样传递参数:./ruby_script.rbarg1arg2如何将参数抽象到配置文件(例如yaml文件或其他文件)中?您能否举例说明如何做到这一点?提前谢谢你。 最佳答案 首先,您可以运行一个写入YAML配置文件的独立脚本:require"yaml"File.write("path_to_yaml_file",[arg1,arg2].to_yaml)然后,在您的应用中阅读它:require"yaml"arg

  6. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  7. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  8. ruby - JetBrains RubyMine 3.2.4 调试器不工作 - 2

    使用Ruby1.9.2运行IDE提示说需要gemruby​​-debug-base19x并提供安装它。但是,在尝试安装它时会显示消息Failedtoinstallgems.Followinggemswerenotinstalled:C:/ProgramFiles(x86)/JetBrains/RubyMine3.2.4/rb/gems/ruby-debug-base19x-0.11.30.pre2.gem:Errorinstallingruby-debug-base19x-0.11.30.pre2.gem:The'linecache19'nativegemrequiresinstall

  9. ruby - `rescue $!` 是如何工作的? - 2

    我知道全局变量$!包含最新的异常对象,但我对下面的语法感到困惑。谁能帮助我理解以下语法?rescue$! 最佳答案 此构造可防止异常停止您的程序并使堆栈跟踪冒泡。它还会将该异常作为值返回,这很有用。a=get_me_datarescue$!在此行之后,a将保存请求的数据或异常。然后您可以分析该异常并采取相应措施。defget_me_dataraise'Nodataforyou'enda=get_me_datarescue$!puts"Executioncarrieson"pa#>>Executioncarrieson#>>#更现实的

  10. postman——集合——执行集合——测试脚本——pm对象简单示例02 - 2

    //1.验证返回状态码是否是200pm.test("Statuscodeis200",function(){pm.response.to.have.status(200);});//2.验证返回body内是否含有某个值pm.test("Bodymatchesstring",function(){pm.expect(pm.response.text()).to.include("string_you_want_to_search");});//3.验证某个返回值是否是100pm.test("Yourtestname",function(){varjsonData=pm.response.json

随机推荐