定时杀掉processlist sleep状态的线程

2018-12-06 10:03:36

由于程序设计的Bug,导致目前这个项目使用的数据库中有很多Sleep状态的线程。找了很多解决办法,还没发现最终有效的解决方案。只能临时使用如下方法:

编写shell文件,如killSleepProcess.sh


while :do
  n=`mysqladmin -uroot -p*** processlist | grep -i sleep | wc -l`
  date=`date +%Y%m%d\[%H:%M:%S]`  echo $n

  if [ "$n" -gt 10 ]  then
    for i in `mysqladmin -uroot -p*** processlist | grep -i sleep | awk '{print $2}'`    do
      mysqladmin  -uroot -p*** kill $i
    done
    echo "sleep is too many i killed it" >> /root/tmp/sleep.log    echo "$date : $n" >> /root/tmp/sleep.log  fisleep 120 #每隔120 秒 执行一次done
  • 2019-08-31 14:05:00

    JNI Crash:异常定位与捕获处理

    在Android JNI开发中,经常会遇到JNI崩溃的问题,尤其带代码量大,或者嵌入了第三方代码的情况下,很难进行问题定位和处理。本文将介绍两种常见的JNI崩溃处理方法,包括: 每个JNI调用后进行异常检测处理(适用于JNI代码量很小的情况) 捕获系统崩溃的Signal,并进行异常处理(适用于JNI代码量大,难以每句话后面都进行异常检测的情况)