在linux下对mysql监控自动重启

发布时间:2017-06-13 17:43:12编辑:丝画阁阅读(317)

一般来说1G内存的VPS搭的LNMP生产环境内存非常容易不够,访问量一大就内存不够然后mysql就挂掉了。以前我以为是mysql占用内存太多于是企图监控mysql挂掉的话就重启mysql,结果我发现访问量一大mysql挂掉之后无法重启mysql。然后查看了一下内存发现php-fpm占用了大部分的内存导致mysql挂掉,如果把php-fpm重启一下释放内存的话,mysql就可以顺利重启了。而且mysql根据默认配置参数来的话,在高流量下内存1G内存快用完的时候,我重启php-fpm立刻已占用内存就降得很低,也就是说mysql进程根本没php-fmp那么占内存。问题的症结在与php-fpm占用了过多的内存,我们只需要对php-fpm的占用内存进行监控,如果占用内存过多的话就重启php-fpm释放内存就ok了(当然了可能对后台长时间运行的php进程有影响),后来一想觉得别的进程也可能占用内存我还不如直接检测所有内存占用情况,超过阈值就重启内存老虎php-fpm就OK了。

首先,检测所有内存消耗情况是:free -m,这个命令有3行结果,因为linux总是会利用多余的内存拿来缓存东西,所以我们需要的是第二行的:-/+ buffers/cache这行的used列的数据,这个值才是真正消耗掉的内存,使用awk挖出来就是:

free -m|grep -|awk ‘{print $3}’

1G内存的VPS内存不太充裕,我们设这个值为800,超过了就重启php-fpm就OK了,写个shell脚本如下:

#!/bin/sh
jk=`free -m|grep -|awk '{print $3}'`
if [ $jk -gt 800 ]
then
/etc/init.d/php-fpm restart
echo $(date +"%y-%m-%d %H:%M:%S") "restart php-fpm Mem $jk" >> /home/wwwlogs/jk.log
else
echo $(date +"%y-%m-%d %H:%M:%S") "Mem $jk" >> /home/wwwlogs/jk.log
fi


保存成jk.sh放到/home/jk.sh,然后chmod +x /home/jk.sh,最后在crontab -e设置每分钟检测一次,也就是:* * * * * /home/jk.sh,然后保存,最后就可以在tail -f /var/log/jk.log里看到每分钟检测结果了。

其实流量一大mysql维护起来特别麻烦,不如买阿里RDS之类的云数据库,当然了如果流量不那么大,常用的页面的mysql返回结果用redis之类的做个缓存还是足够应付而且很方便。比如说我有个常访问的页面的mysql查询返回一个php的数组,那么我就把查询的GET和POST的参数作为redis的key,然后把php数组serialize成string保存之(个人觉得比json_encode弄成json格式靠谱,一方面serialize有容错而且这里不需要json的通用性,另一方面php数组保存成json然后再json_decode有时候无法完全还原成原数组),设置expire时间,下次查询直接redis读缓存就ok了。逻辑根本不用大改,访问特别快。另外特别推荐Predis这个纯的php的redis客户端,虽然在纯的简单任务workbench下没有phpredis那么快,但是在稍微复杂任务下基本和phpredis差不多,而且还不依赖额外的php扩展,部署方便。phpredisadmin以及laravel等都采用Predis作为默认的redis客户端。




用命令vi -b 打开你的SHELL脚本文件,你会。发现每行脚本最后多了个^M。

那么接下来就要搞清楚这个^M是什么东东?

long long ago.....  老式的电传打字机使用两个字符来另起新行。一个字符把滑动架移回首位 (称为回车,,ASCII码为0D),另一个字符把纸上移一行 (称为换行,,ASCII码为0A)。当计算机问世以后,存储器曾经非常昂贵。有些人就认定没必要用两个字符来表示行尾。UNIX 开发者决定他们可以用 一个字符来表示行尾,Linux沿袭Unix,也是。Apple 开发者规定了用。开发 MS-DOS以及Windows 的那些家伙则决定沿用老式的。

因为MS-DOS及Windows是回车+换行来表示换行,因此在linux下用Vim查看在Windows下用VC写的代码,行尾后的“^M”符号,表示的是符。

在Vim中解决这个问题,很简单,在Vim中利用替换功能就可以将“^M”都干掉,键入如下替换命令行:

1)vi -b setup.sh

2)在命令编辑行<就是: 按ESC键 然后shift+:冒号>输入:%s/^M//g

注意:上述命令行中的“^M”符,不是“^”再加上“M”,而是由“Ctrl+v”、“Ctrl+M”键生成的。

这样替换掉以后,保存就可以执行了。当然还有其他的替换方式比如:

a.一些linux版本有 dos2unix 程序,可以用来祛除^M。

b.cat filename1 | tr -d "/r" > newfile 去掉^M生成一个新文件,还有sed命令等,凡是可以替换的命令都是可以用来新生成一个文件的。


关键字