自动检测memcached进程,不存在则自动重启(脚本)
2016-04-19 16:40
525 查看
服务器开启memcached对网站速度提升是非常明显的,可是由于资源分配、内存用满等等原因,memcached可能会挂掉,此时网站就非常卡了,甚至打不开。
以下脚本为检测该进程,不存在则启动服务,并输出日志。
首先创建一个sh脚本
内容如下:
并添加至crontab计划任务中,每隔5分钟检测一次即可。
———————————结束————————————
memcached启动参数:
转自 http://sunweiwei.com/1898/
以下脚本为检测该进程,不存在则启动服务,并输出日志。
首先创建一个sh脚本
vim memcached_check.sh
内容如下:
#!/bin/sh #check memcached process and restart if down DATE=`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/
相关文章推荐
- Java测试Memcached
- Linux中Memcached的安装和配置方法
- memcached-session-manager配置
- 云数据库memcached之热点key问题解决方案
- memcache与redis的区别
- MemCache深度解读
- 史上最全互联网分布式缓存技术视频教程(redis、memcached、ssdb)
- yii2 memcache 跨平台交互 键和值不一样
- Memcache-Java-Client-Release源码阅读(之二)
- 通过telnet连接查看memcache服务器
- Redis与Memcached的区别
- 从源码角度理清memcache缓存服务
- windows环境安装memcached以及telnet登陆memcached
- 如何对memcache的数据(key-value)进行遍历操作
- nginx+tomcat+memcached实现session共享
- 全新安装Mac OSX 开发者环境 同时使用homebrew搭建 PHP,Nginx ,MySQL,Redis,Memcache ... ... (LNMP开发环境)
- Nginx+Tomcat+Memcached+kryo序列化集群Session共享
- MemCache超详细解读
- Redis与Memcached的区别
- Redis 和 memcached 区别