openresty lua操作redis 出现segmentfault

发布于 2022-09-01 22:41:32 字数 3099 浏览 21 评论 0

openresty 使用nginx 调用lua 操作redis,运行一段时间 会出现段错误。一下是生成core 打印出的信息:

Core was generated by `nginx: worker'.
Program terminated with signal 11, Segmentation fault.
#0  ngx_http_lua_chain_get_free_buf (log=0xac1fd30, p=0x4fa1d10, free=0xf8, len=57)
    at ../ngx_lua-0.9.16/src/ngx_http_lua_util.c:2703
2703        if (*free) {
Missing separate debuginfos, use: debuginfo-install glibc-2.12-1.149.el6_6.9.x86_64 keyutils-libs-1.4-5.el6.x86_64 krb5-libs-1.10.3-37.el6_6.x86_64 libcom_err-1.41.12-21.el6.x86_64 libselinux-2.0.94-5.8.el6.x86_64 nss-softokn-freebl-3.14.3-22.el6_6.x86_64 openssl-1.0.1e-30.el6.11.x86_64 pcre-7.8-6.el6.x86_64 zlib-1.2.3-29.el6.x86_64
(gdb) bt
#0  ngx_http_lua_chain_get_free_buf (log=0xac1fd30, p=0x4fa1d10, free=0xf8, len=57)
    at ../ngx_lua-0.9.16/src/ngx_http_lua_util.c:2703
#1  0x00000000004bee34 in ngx_http_lua_socket_tcp_send (L=0x5cd32e0) at ../ngx_lua-0.9.16/src/ngx_http_lua_socket_tcp.c:2371
#2  0x00000000004deef7 in luaD_precall (L=0x5cd32e0, func=0x4f37510, nresults=2) at ldo.c:320
#3  0x00000000004e8329 in luaV_execute (L=<value optimized out>, nexeccalls=2) at lvm.c:591
#4  0x00000000004dea87 in luaD_rawrunprotected (L=0x5cd32e0, f=0x4df170 <resume>, ud=0x4f374e0) at ldo.c:116
#5  0x00000000004dec50 in lua_resume (L=0x5cd32e0, nargs=<value optimized out>) at ldo.c:428
#6  0x00000000004b2520 in ngx_http_lua_run_thread (L=0x2008960, r=0x4fa1d60, ctx=0x1f013c8, nrets=1)
    at ../ngx_lua-0.9.16/src/ngx_http_lua_util.c:1015
#7  0x00000000004ba4d8 in ngx_http_lua_socket_tcp_resume_helper (r=0x4fa1d60, socket_op=<value optimized out>)
    at ../ngx_lua-0.9.16/src/ngx_http_lua_socket_tcp.c:5184
#8  0x00000000004bbecc in ngx_http_lua_socket_handle_read_success (r=0x4fa1d60, u=0xb26ac98)
    at ../ngx_lua-0.9.16/src/ngx_http_lua_socket_tcp.c:2952
#9  ngx_http_lua_socket_tcp_read (r=0x4fa1d60, u=0xb26ac98) at ../ngx_lua-0.9.16/src/ngx_http_lua_socket_tcp.c:2071
#10 0x00000000004ba410 in ngx_http_lua_socket_tcp_handler (ev=<value optimized out>)
    at ../ngx_lua-0.9.16/src/ngx_http_lua_socket_tcp.c:2703
#11 0x0000000000439d35 in ngx_epoll_process_events (cycle=<value optimized out>, timer=<value optimized out>,
    flags=<value optimized out>) at src/event/modules/ngx_epoll_module.c:822
#12 0x0000000000432395 in ngx_process_events_and_timers (cycle=0x1f5f0b0) at src/event/ngx_event.c:242
#13 0x00000000004382c8 in ngx_worker_process_cycle (cycle=0x1f5f0b0, data=<value optimized out>)
    at src/os/unix/ngx_process_cycle.c:769
#14 0x0000000000436857 in ngx_spawn_process (cycle=0x1f5f0b0, proc=0x438200 <ngx_worker_process_cycle>, data=0x16,
    name=0x4f981e "worker process", respawn=47) at src/os/unix/ngx_process.c:198
#15 0x0000000000438eba in ngx_reap_children (cycle=0x1f5f0b0) at src/os/unix/ngx_process_cycle.c:621
#16 ngx_master_process_cycle (cycle=0x1f5f0b0) at src/os/unix/ngx_process_cycle.c:174
#17 0x000000000041ae86 in main (argc=<value optimized out>, argv=<value optimized out>) at src/core/nginx.c:415

有遇到的吗?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

捶死心动 2022-09-08 22:41:32

用的是稳定版吗

迟月 2022-09-08 22:41:32

应该是你操作redis出错了,检查下参数有没有传错,或参数值。
我用python操作redis也遇到过段错误。检查发现有参数错误

↘人皮目录ツ 2022-09-08 22:41:32

请问这个问题后续有跟进吗?同碰到问题,似乎是lua vm对应的request被释放掉了。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文