Linux下,Apache及PHP项目报Core错误Program terminated with signal 7, Bus error_program terminated with signal 7, bus error.-程序员宅基地

技术标签: 网站开发  core  apache  linux  php  signal  

    最近上线的一个项目,使用Apache 2.2.32及ThinkPHP3.23,每天访问量共有几万吧,但会出现几十次错误,表现就是Apache根目录下,会出现Core.XXXXX的文件,同时错误日志内会显示:[Thu Nov 30 09:06:04 2017] [notice] child pid 11507 exit signal Bus error (7), possible coredump in /www/bin2/apache


   网上搜索,发现一个帖子,差不多是同样的错误 https://bugs.php.net/bug.php?id=52752

  用gdb ./bin/httpd Core.XXXX进行查错显示,打开后,输入 bt,

#0  lex_scan (zendlval=0x7fff0ba3c140) at Zend/zend_language_scanner.c:2037
#1  0x00007fde1da5dbf1 in zendlex (elem=0x7fff0ba3cb20) at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_compile.c:1701
#2  0x00007fde1da4006a in zendparse () at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_language_parser.c:4450
#3  0x00007fde1da4309b in zend_compile (type=2) at Zend/zend_language_scanner.l:585
#4  0x00007fde1da4477b in compile_file (file_handle=0x7fff0ba3cf00, type=2) at Zend/zend_language_scanner.l:635
#5  0x00007fde1d8d585f in phar_compile_file (file_handle=0x7fff0ba3cf00, type=2)
    at /home/cdlonger/setupfile/php-7.1.3/ext/phar/phar.c:3320
#6  0x00007fde1da43ebf in compile_filename (type=2, filename=0x7fde16616a20) at Zend/zend_language_scanner.l:662
#7  0x00007fde1db1533a in zend_include_or_eval (inc_filename=0x7fde16616a20, type=2)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_execute.c:2846
#8  0x00007fde1db1543d in ZEND_INCLUDE_OR_EVAL_SPEC_CV_HANDLER (execute_data=0x7fde166169d0)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_vm_execute.h:35461
#9  0x00007fde1dad7ee8 in execute_ex (ex=<value optimized out>)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_vm_execute.h:432
#10 0x00007fde1da6e0c0 in zend_call_function (fci=0x7fff0ba3d1d0, fci_cache=0x7fff0ba3d210)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_execute_API.c:846
#11 0x00007fde1d97869c in zif_call_user_func_array (execute_data=0x7fde16616960, return_value=0x7fde16616910)
    at /home/cdlonger/setupfile/php-7.1.3/ext/standard/basic_functions.c:4853
#12 0x00007fde1daf8197 in ZEND_DO_FCALL_BY_NAME_SPEC_RETVAL_USED_HANDLER (execute_data=0x7fde16616860)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_vm_execute.h:876
#13 0x00007fde1dad7ee8 in execute_ex (ex=<value optimized out>)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_vm_execute.h:432
#14 0x00007fde1da6e0c0 in zend_call_function (fci=0x7fff0ba3d3f0, fci_cache=0x7fff0ba3d430)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_execute_API.c:846
#15 0x00007fde1d8f1f7f in reflection_method_invoke (execute_data=<value optimized out>, return_value=0x7fff0ba3d4e0, 
    variadic=1) at /home/cdlonger/setupfile/php-7.1.3/ext/reflection/php_reflection.c:3325
#16 0x00007fde1daf93b0 in ZEND_DO_FCALL_SPEC_RETVAL_UNUSED_HANDLER (execute_data=0x7fde16612b90)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_vm_execute.h:970
#17 0x00007fde1dad7ee8 in execute_ex (ex=<value optimized out>)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_vm_execute.h:432
#18 0x00007fde1db23920 in zend_execute (op_array=0x7fde16679000, return_value=<value optimized out>)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend_vm_execute.h:474
#19 0x00007fde1da7c753 in zend_execute_scripts (type=8, retval=0x0, file_count=3)
    at /home/cdlonger/setupfile/php-7.1.3/Zend/zend.c:1476
#20 0x00007fde1da1c060 in php_execute_script (primary_file=0x7fff0ba3f940)
    at /home/cdlonger/setupfile/php-7.1.3/main/main.c:2537
#21 0x00007fde1db26915 in php_handler (r=0x1d250e0)
    at /home/cdlonger/setupfile/php-7.1.3/sapi/apache2handler/sapi_apache2.c:757
#22 0x000000000043b4c0 in ap_run_handler (r=0x1d250e0) at config.c:158
#23 0x000000000043eaee in ap_invoke_handler (r=0x1d250e0) at config.c:376
#24 0x000000000045a5f0 in ap_process_request (r=0x1d250e0) at http_request.c:298
---Type <return> to continue, or q <return> to quit---
#25 0x0000000000457550 in ap_process_http_connection (c=0x1d19270) at http_core.c:190
#26 0x0000000000442a60 in ap_run_process_connection (c=0x1d19270) at connection.c:43
#27 0x0000000000476458 in child_main (child_num_arg=<value optimized out>) at prefork.c:667
#28 0x0000000000476754 in make_child (s=0x1ab5d98, slot=33) at prefork.c:768
#29 0x00000000004773a7 in perform_idle_server_maintenance (_pconf=<value optimized out>, plog=<value optimized out>, 
    s=<value optimized out>) at prefork.c:903
#30 ap_mpm_run (_pconf=<value optimized out>, plog=<value optimized out>, s=<value optimized out>) at prefork.c:1107
#31 0x0000000000426644 in main (argc=3, argv=0x7fff0ba3ff28) at main.c:753

大概意思就是进行php文件编译处理的时候,文件又被别的地方修改了,所以引起了冲突,参考那个帖子里面的操作,

[2017-06-09 19:28 UTC] [email protected]
It seems to be over-allocating on the stack.
Let's see if we can narrow the problem down to finding the file that's causing the problem.


In gbd, jump to frame 5 and print file_handle as well as file_handle as well as file_handle->filename and file_handle->opened_path


(gdb) f 5
(gdb) p file_handle
(gdb) p file_handle->filename
(gdb) p file_handle->opened_path

(gdb) p file_handle.filename
$3 = 0x7fde16424738 "./App/Runtime/Cache/Home/1e0959ec826efaa806577e175cf856b6.php"
我发现是thinkphp目录下的缓存文件,当时系统内设置的是开启DEBUG,TMPL_CACHE_ON=> false,HTML_CACHE_ON=> false,
就意味着每次打开那个页面,都会去重新生成缓存,如果刚好有并发的情况下,可能就冲突了,所以在配置文件内,修改为
APP_DEBUG => false,TMPL_CACHE_ON=>true,HTML_CACHE_ON=> true,这样,只有当php文件被修改时,才会去重新生成缓存,减少了冲突机率。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/belllab/article/details/78673823

智能推荐

Python从入门到入坟(6)-程序员宅基地

文章浏览阅读170次。2020/06/01 面向对象编程面向对象(object oriented programming,OOP)编程的思想主要是针对大型软件设计而来的。面向对象编程使程序的扩展性更强、可读性更好,使得编程可以像搭积木一样简单。Python中一切皆对象。Python支持面向过程、面向对象、函数式编程等多种编程范式。面向对象和面向过程的区别面向过程思维:更加关注的是“程序的逻辑流程”,是一种“执行者”思维,适合编写小规模的程序。面向对象思维:更加关注的是“软件中对象之间的关系”,是一种“设计者”思维_python从入门到入坟

用Python 绘制多个同心圆 (Python经典编程案例)_python利用负循环画10个同心圆-程序员宅基地

文章浏览阅读4.1w次,点赞12次,收藏14次。案例:绘制多个同心圆代码如下:import turtlet = turtle.Pen()my_colors = ("red", "green", "yellow", "black")t.width(4)t.speed(1)for i in range(10): # 0 1 2 3 4 t.penup() t.goto(0, -i*10) # 0, -100,-2..._python利用负循环画10个同心圆

pki的java实现书籍_精通PKI网络安全认证技术与编程实现 PDF扫描版[214MB]-程序员宅基地

文章浏览阅读240次。精通PKI网络安全认证技术与编程实现从实战出发,介绍了PKI应用开发过程和细节。《精通PKI网络安全认证技术与编程实现》共32章,分6篇,主要内容包括PKI基础知识、OpenSSL开发、CrytoAPI开发、JavaSecurity开发、电子商务网站应用、PKI技术应用等,涉及C语言、Java语言、JSP、ASP/ASP.NET、PHP等开发语言。为了方便读者深入了解PKI,《精通PKI网络安全认..._api安全技术与实战pdf

c语言字符串函数 小数,C语言modf()函数:求双精度数的小数部分-程序员宅基地

文章浏览阅读644次。函数名: modf头文件:函数原型: double modf(double value, double *iptr);功 能: 求双精度数的小数部分参 数: double value 为要操作的双精度数 ,double *iptr 为要传回整数部分的变量指针返回值: 返回value的小数部分程序例: 分别求出双精度number的小数部分和整数部分,并将结果输出#include#includ..._c语言求一个双精度数的整数部分和小数部分

SYN flood_http存在synflood吗-程序员宅基地

文章浏览阅读288次。最近在学习DDos相关知识,参考一些只是,做了摘要,供自己参考。 参考:http://blog.csdn.net/xlf13872135090/article/details/8059538SYN Flood 攻击原理 利用TCP协议缺陷,发送了大量伪造的TCP连接请求,使得被攻击方资源耗尽,无法及时回应或处理正常的服务请求。一个正常的TCP连接需要三次握手,首先客户端发送一个包含SYN标志的数_http存在synflood吗

测牛学堂:软件测试之数据库操作语句sql的外键查询_sql查询外键id的数据-程序员宅基地

文章浏览阅读775次。我们之前学习的都是针对一个表的操作。如果要进行多个表之间的操作,就要用到外键把他们关联起来。外键的作用:能够让多个表进行关联,使表与表之间有联系,实现共性抽取。如果数据项比较多的情况下,把所有数据都存放在一个表中,如果表太大,影响操作效率。解决办法就是把一个表拆分成多个表,并且用外键去关联。例子:如果要设计一个员工表1)员工表:编号、姓名、年龄、性别、所在分公司、所在部门2)部门表:编号、部门名称、部门经理、主要任务3)公司表:编号、分公司名,地址、电话、法人把公司和部门的数据抽取出来,形成_sql查询外键id的数据

随便推点

学习布局(15) 段落类的样式_段落元素设置样式-程序员宅基地

文章浏览阅读220次。line-height: 设置元素当中的每行文本的行高(行间距) .test { width: 300px; height: 40px; margin-bottom: 20px; padding: 10px; background-color:..._段落元素设置样式

opencv: 使用InRange函数进行阈值操作 Thresholding Operations using inRange_inrange和cv2.threshold一起使用-程序员宅基地

文章浏览阅读1.3k次。目标:使用OpenCV cv::inRange 函数进行基本的 阈值操作, 基于像素值在HSV色度空间的范围进行对象检测理论:前一篇文章中我们学习了如何使用cv::threshold 阈值函数进行阈值操作 本文我们将学习使用 cv::inRange 来进行处理 原理是一样的但是现在我们增加了一个我们所需要的 【像素值的范围】HSV色度空间 HSV colorspaceHSV ..._inrange和cv2.threshold一起使用

瑜伽教学法 | 为什么你说的口令会员没反应?_会员病了无法来上瑜伽课怎么说-程序员宅基地

文章浏览阅读154次。  瑜伽培训课程层出不穷,但市面上都没有教授瑜伽老师们如何“教”的系统培训。瑜伽行业表面看似繁荣,但大多数老师缺失教学的“灵魂”。  为此,心合瑜伽学院王梓涵院长结合多年来积累的经验以及瑜伽老师的痛点,与心合教学团队不断打磨,开创瑜伽培训先河,首创贴合瑜伽老师的『瑜伽教学法』,教学法正是指导瑜伽老师们如何上课的法门!  不少老师们,有时会有这样的问题:  “我把正确的口令讲出来了,但是会员好像不听我的口令,并没有按照口令去做,需要我不停地辅助和做示范才能完成...”  一个优秀的老师,总可以_会员病了无法来上瑜伽课怎么说

随机森林sklearn FandomForest,及其调参_随机森林及其调参-程序员宅基地

文章浏览阅读2.2w次,点赞12次,收藏113次。随机森林概述随机森林是集成学习方法bagging类中的翘楚。与集成学习boosting类的GBDT分庭抗礼。bagging类集成学习采用的方法是:用部分数据 or 部分特征 or 多个算法 训练一些模型;然后再组合这些模型,对于分类问题采用投票多数表决,回归问题采用求平均。各个模型训练之间互不影响,天生就适合并行化处理。在如今大数据时代背景下很有诱惑力。 主要效果:重点关注降低方差,..._随机森林及其调参

解决Exception: org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Ljava/lang/String;I)Z-程序员宅基地

文章浏览阅读1.5k次,点赞2次,收藏2次。解决Exception: org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Ljava/lang/String;I)Z和Error: JAVA_HOME is incorrectly set.Please update D:\Software\hadoop260\conf\hadoop-env.cmd‘-Xmx512m’ 不是内部或外部命令,也不是可运行的程序或批处理文件。这个错误目前我知道的有以下几种解决办法:一、查看hadoop安装是_org.apache.hadoop.io.nativeio.nativeio$windows.access0(ljava/lang/string;i)z

linux 找不到防火墙设置的,linux怎么样查看防火墙有没开启-程序员宅基地

文章浏览阅读2.6k次。我的是linux系统,那么要怎么样才能查看防火墙有没有开启呢?下面由学习啦小编给你做出详细的linux查看防火墙是否开启方法介绍!希望对你有帮助!linux查看防火墙是否开启方法一:service iptables status可以查看到iptables服务的当前状态。但是即使服务运行了,防火墙也不一定起作用,你还得看防火墙规则的设置 iptables -L在此说一下关于启动和关闭防火墙的命令:1..._linux防火墙服务找不到

推荐文章

热门文章

相关标签