定时杀掉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
  • 2017-12-25 11:07:58

    mogodb 备份

    error connecting to db server: server returned error on SASL authentication

  • 2017-12-25 15:53:15

    MongoDB3.4版本配置详解

    配置文件方面,mongod和mongos有很多相同之处,下文中如有区别之处将会特别指出。 在一个节点上,通常同时启动mongod和mongos进程是正常的,他们之间不存在资源竞争,但是为了避免冲突,我们希望它们使用各自的配置文件,比如mongod.conf、mongos.conf;mongodb的某些平台下的安装包中没有自带配置文件,需要开发者自己创建。