openresty 报错:lua entry thread aborted: runtime error
【1】问题现象
(1)本地openresty系统
(2)报错信息
2019/09/10 08:13:55 [error] 2385#2385: *4 lua entry thread aborted: runtime error: /usr/local/lib/ubcservd/bin/../work/bill_timer.lua:1647: attempt to concatenate global 'value' (a nil value)
(3)分析原因
value变量为nil值的场景预先没有考虑到,导致连接字符串时失败。
(4)解决(容错)方案
打印value值时,增加nil值的判断。如下:
ngx.log(ngx.ERR, 'todo and print value: ' .. (value or 'nil'))
【2】问题追思
如上异常,出现过"lua entry thread aborted"以后,这个worker process(即id为2385)到底还存活吗?
注意,这里所谓的存活是相对于C++程序的空指针导致应用程序异常崩溃而言。
模拟场景,分析过程如下:
(1)具体思路:
设计两个定时器,分别设置不同的时间间隔(第一个时间间隔120s短于第二个180s),启动nginx系统:
当第一个定时器执行异常(如上错误)后,观察第二个定时器是否可以正常执行。
(2)源码如下:
[1] 配置文件:
nginx.conf,如下:
worker_processes ;
user root;
events
{
worker_connections ;
}
http
{
default_type application/octet-stream;
sendfile on;
send_timeout ;
keepalive_timeout ;
lua_package_path "/usr/local/lib/ubcservd/lualib/?.lua;;";
lua_package_cpath "/usr/local/lib/ubcservd/lualib/?.so;;";
init_worker_by_lua_file work/bill_timer.lua;
}
[2] 定时器文件:
bill_timer.lua,如下:
local new_timer = ngx.timer.at
local function timer_test_one(permature)
if not premature then
ngx.log(ngx.ERR, "into timer_test_one print value " .. value)
, timer_test)
if not ok then
ngx.log(ngx.ERR, "failed to create timer_test_one timer : ", err)
else
ngx.log(ngx.ERR, ')
end
end
end
local function timer_test_two(permature)
if not premature then
ngx.log(ngx.ERR, "into timer_test_two print ")
, timer_test_two)
if not ok then
ngx.log(ngx.ERR, "failed to create timer_test_two timer : ", err)
else
ngx.log(ngx.ERR, ')
end
end
end
== ngx.worker.id() then
, timer_test_one)
if not ok then
ngx.log(ngx.ERR, "failed to create timer_test_one timer : " .. err)
else
ngx.log(ngx.ERR, ')
end
, timer_test_two)
if not ok then
ngx.log(ngx.ERR, "failed to create timer_test_two timer : " .. err)
else
ngx.log(ngx.ERR, ')
end
end
[3] 启动nginx系统
成功启动,创建3个worker process,如下图:

[4] 日志分析
第一个定时器执行异常中止错误信息,立即观察worker进程情况:

进程id值为2869仍然存在,安然无恙。
第二个定时器执行正常打印信息,所有日志,如下图:

综上所述:“thread aborted” 并非崩溃,仅仅只是当前函数执行失败中止,此函数其余语句不会再执行。
Good Good Study, Day Day Up.
顺序 选择 循环 总结
openresty 报错:lua entry thread aborted: runtime error的更多相关文章
- lua entry thread aborted: runtime error: /usr/../process.lua:448: attempt to concatenate field 'np_sum_duration' (a userdata value)
[1]问题场景原代码 引起问题的原代码,访问数据库,汇总数据后,使用汇总结果报异常: local function amount_sum_fee(cycleid) local select_produ ...
- 【Azure App Service】C#下制作的网站,所有网页本地测试运行无误,发布至Azure之后,包含CHART(图表)的网页打开报错,错误消息为 Runtime Error: Server Error in '/' Application
问题描述 C#下制作的网站,所有网页本地测试运行无误,发布至Azure之后,包含CHART(图表)的网页打开报错,错误消息为 Runtime Error: Server Error in '/' Ap ...
- 【hibernate postgresql】注解@TypeDef/@Enumerated/数据库字段gender为枚举类型,从前台接受到实体后进行保存报错:org.postgresql.util.PSQLException: ERROR: column "gender" is of type gender but expression is of type character varying
数据库字段gender为枚举类型,从前台接受到实体后进行保存报错:org.postgresql.util.PSQLException: ERROR: column "gender" ...
- 安装php时,make步骤报错make: *** [ext/gd/gd.lo] Error 1
安装PHP时,make步骤报错make: *** [ext/gd/gd.lo] Error 1 /usr/local/src/LAMP+memcahed+catci/php-5.4.0/ext/gd/ ...
- windows 8 安装 oracle 11g 报错:command line option syntax error,type command/? for help
windows 8 安装 oracle 11g 报错:command line option syntax error,type command/? for help 在windows8操作系统上安装 ...
- python——报错ImportError:DLL load failed with error code -1073741795的解决方式
python中导入一个包,import cv2总是报错'ImportError:DLL load failed with error code -1073741795',报错形式: 网上找了好久的解决 ...
- 【Linux基础】mount报错:mount.nfs: Remote I/O error
问题描述:mount 报错:mount.nfs: Remote I/O error 挂载时需要指明版本,由于NFS服务器有多个版本,V2.V3.V4.而且各版本同时运行,因此挂载时需要说明版本号. 由 ...
- eclipse项目无故报错,markers信息为An error occurred while filtering resources
eclipse项目无故报错,markers信息为An error occurred while filtering resources 描述:eclipse项目和resource文件上有红色的叉,其m ...
- CentOS6.5 重启网络报错:Bringing up interface eth0: Error: Connection activation failed: Device not managed by NetworkManager or unavailable
CentOS6.5 重启网络报错: Bringing up interface eth0: Error: Connection activation failed: Device not manage ...
随机推荐
- 谈谈JavaScript Navigator 对象属性
Navigator 对象属性 可以在Navigator对象上使用以下属性: 属性 描述 appCodeName 返回浏览器的代码名称 appName 返回浏览器的名称 appVersion 返回浏览器 ...
- PDO封装增删改查
<?phpclass db{ public $table=null; public $pdo; public $where=null; //where 条件 public $field=null ...
- webpack加载css文件及其配置
webpack加载css文件及其配置 当我们写了几个css文件之后如果想要引用到html中去的话我们最开始的方式就是通过link标签将css文件导入进去,但是如果我们的css文件有很多的话,一个个的导 ...
- warning: Unexpected unnamed function (func-names)
warning: Unexpected unnamed function (func-names) 看到这个提示基本是就是说你的函数不能是匿名函数,最好可以起一个名字,然后你增加一个函数名称就好了 R ...
- swift(三)字典数组操作
//1.数组的概念和定义 var array = [,,,] var array1:Array = [,,,] var array2:Array<Int> = [,,,]; var arr ...
- JavaWeb项目——博客系统
系统介绍 博客是互联网平台上的个人信息交流中心.通常博客就是用来发表文章,所有的文章都是按照年份和日期排列,有些类似斑竹的日记.看上去平淡无奇,毫无可炫耀之处,但它可以让每个人零成本.零维护地创建自己 ...
- spring boot的异常处理
原文:https://blog.csdn.net/tianyaleixiaowu/article/details/70145251 全局异常处理是个比较重要的功能,一般在项目里都会用到. 我大概把一次 ...
- testlink 1.9.19安装
环境平台: 系统:Centos 7.6 数据库:mysql 5.7 PHP版本:PHP 5.6 testlink版本:testlink- 链接:https://pan.baidu.com/s/10Pr ...
- Flask框架入门(一)
Flask诞生于2010年,是Armin ronacher(人名)用 Python 语言基于 Werkzeug 工具箱编写的轻量级Web开发框架. Flask 本身相当于一个内核,其他几乎所有的功能都 ...
- 如何防止XSS攻击?
来自: https://www.freebuf.com/articles/web/185654.html 前端安全 随着互联网的高速发展,信息安全问题已经成为企业最为关注的焦点之一,而前端又是引发企业 ...