syslog可能引起得问题_syslog 导致的死锁问题排查记录

本文记录了一个服务器服务因syslog调用导致的死锁问题。通过strace和gdb分析,发现在服务进程和信号处理函数中同时使用syslog可能导致死锁。提供了一段示例代码,展示在主服务循环输出日志和定时器信号处理函数中调用syslog的情景,重现了死锁问题。
摘要由CSDN通过智能技术生成

问题描述:

在服务器上,概率(一个月1次)出现,某个服务停摆了,日志上看,没有任何报错,而且服务进程也在,只是无响应了。

问题分析:

1,用strace命令查看,发现当前进程阻塞在系统API上, futext_wait_queue_me

2, 用gdb命令 attach 当前阻塞进程,bt显示 call trace,发现是syslog系统调用出现了死锁。

3,进一步分析,发现,某个函数在外部流程和信号处理函数(定时任务)中都调到了,而这个函数内部,调用了syslog输出日志。

4,结论:服务进程和信号处理函数同时调用syslog,可能导致死锁。

问题验证:

点击(此处)折叠或打开

1. #include

2. #include

3. #include

4. #include

5. #include

6. #include

7. #include

8. #include

9. #include

10. #include

11. #include

12. #include

13. #include

14. #include

15.

16. intidx\=0;

17. static void sigroutine(intsigno)

18. {

19.     char\*logcnt

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值