自动检测memcached进程,不存在则自动重启(脚本)

来源:互联网 发布:m网络语什么意思 编辑:程序博客网 时间:2024/04/29 19:51

服务器开启memcached对网站速度提升是非常明显的,可是由于资源分配、内存用满等等原因,memcached可能会挂掉,此时网站就非常卡了,甚至打不开。

以下脚本为检测该进程,不存在则启动服务,并输出日志。

首先创建一个sh脚本

vim memcached_check.sh

内容如下:

#!/bin/sh#check memcached process and restart if downDATE=`date -d "today" +"%Y-%m-%d-%H:%M"`#用ps命令查看memcached进程MM=`ps aux |grep "memcached" |grep "11211" |grep -v "grep" |wc -l`#if语句判断进程是否存在,如果不存在,输出日志记录并重启memcached服务if [ "$MM" == "0" ];then    echo "$DATE The memcached is problem and restart" >> /root/memcached_check.logs    memcached -d -m 50 -u cloud -p 11211 -c 1024#wdcp的memcached路径重启命令,语句可以通过ps aux|grep "memchched"fi

并添加至crontab计划任务中,每隔5分钟检测一次即可。

*/5 * * * * /bin/bash /root/sh/memcached_check.sh

———————————结束————————————

memcached启动参数:

-p 指定端口号(默认11211)-U <num> UDP监听端口 (默认: 11211, 0 时关闭)-s <file> 用于监听的UNIX套接字路径(禁用网络支持)-a <mask> UNIX套接字访问掩码,八进制数字(默认:0700)-m 指定最大使用内存大小(默认64MB)-t 线程数(默认4) -l <ip_addr> 绑定地址 (默认:所有都允许,无论内外网或者本机更换IP,有安全隐患,若设置为127.0.0.1就只能本机访问)-d start 启动memcached服务-d restart 重起memcached服务-d stop|shutdown 关闭正在运行的memcached服务-u <username> 绑定使用指定用于运行进程 <username> (只有root用户可以使用这个参数)-P <file> 将PID写入文件<file>,这样可以使得后边进行快速进程终止, 需要与 -d 一起使用-m 最大内存使用,单位MB。默认64MB -M 内存耗尽时返回错误,而不是删除项-c 最大同时连接数,默认是1024-f 块大小增长因子,默认是1.25-n <bytes>最小分配空间,key+value+flags默认是48-k锁定所有内存页。注意你可以锁定的内存上限。 试图分配更多内存会失败的,所以留意启动守护进程时所用的用户可分配的内存上限。(不是前面的 -u <username> 参数;在sh下,使用命令"ulimit -S -l NUM_KB"来设置。)-v 提示信息(在事件循环中打印错误/警告信息。)-vv 详细信息(还打印客户端命令/响应)-vvv 超详细信息(还打印内部状态的变化)-h 打印这个帮助信息并退出。-i 打印memcached和libevent的许可。-L 尝试使用大内存页(如果可用的话)。提高内存页尺寸可以减少"页表缓冲(TLB)"丢失次数,提高运行效率。 为了从操作系统获得大内存页,memcached会把全部数据项分配到一个大区块。-D <char> 使用 <char> 作为前缀和ID的分隔符。这个用于按前缀获得状态报告。默认是":"(冒号)。如果指定了这个参数,则状态收集会自动开启;如果没指定,则需要用命令"stats detail on"来开启。-t <num> 使用的线程数(默认:4)-R 每个连接可处理的最大请求数。-C 禁用CAS。-b 设置后台日志队列的长度(默认:1024)-B 绑定协议 - 可能值:ascii,binary,auto(默认)-I 重写每个数据页尺寸。调整数据项最大尺寸。

转自 http://sunweiwei.com/1898/
0 0
原创粉丝点击