侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PHP+shell脚本操作Memcached和Apache Status的实例分享

php  /  管理员 发布于 7年前   237

memcached 进程启动及监控
1.memcached_inc.sh
设置路径,端口等讯息。

#!/bin/sh  #config include  HOST=$(hostname) SITE="mysite" PORT=11211  MEMCACHED_PID_FILE="/tmp/memcached.pid" MEMCACHED_DAEMON_PID_FILE="/tmp/memcached_daemon.pid"  MEMCACHED="memcached -d -m 64 -p $PORT -u memcache -l 127.0.0.1 -P $MEMCACHED_PID_FILE" MEMCACHED_DAEMON_FILE="memcached_daemon.sh"  ERROR_LOG_FILE="${ROOT}/memcached_${SITE}_${HOST}_${PORT}.log" 

2.gm_memcached.sh
控制memcached 启动,停止,重启。

#!/bin/sh  #memcached start and stop #$1 action  ROOT=$(cd "$(dirname "$0")"; pwd)  . ${ROOT}/memcached_inc.sh   start() {   if [ -f "$MEMCACHED_PID_FILE" ] && [ -s "$MEMCACHED_PID_FILE" ]; then   printf "memcached already running\n"  else   printf "starting memcached\n"   $MEMCACHED    sleep 2    PID=$(cat $MEMCACHED_PID_FILE)   printf "memcached is started PID:$PID\n"    printf "starting memcached daemon\n"   ${ROOT}/${MEMCACHED_DAEMON_FILE} &   DAEMON_PID=$!   echo ${DAEMON_PID} > ${MEMCACHED_DAEMON_PID_FILE}   printf "memcached daemon is started PID:${DAEMON_PID}\n"  fi  }   stop() {   if [ -f "$MEMCACHED_DAEMON_PID_FILE" ] && [ -s "$MEMCACHED_DAEMON_PID_FILE" ]; then   DAEMON_PID=$(cat $MEMCACHED_DAEMON_PID_FILE)   rm -f ${MEMCACHED_DAEMON_PID_FILE}   if [ ! -z ${DAEMON_PID} ]; then    kill -9 ${DAEMON_PID}   fi   printf "memcached daemon is stopped\n"  else   printf "no memcached daemon running\n"  fi   sleep 1   if [ -f "$MEMCACHED_PID_FILE" ] && [ -s "$MEMCACHED_PID_FILE" ]; then   PID=$(cat $MEMCACHED_PID_FILE)   rm -f ${MEMCACHED_PID_FILE}   if [ ! -z ${PID} ]; then    kill -9 ${PID}   fi   printf "memcached is stopped\n"  else   printf "no memcached running\n"  fi  }   case "$1" in   start)   start   ;;   stop)   stop   ;;   restart)   stop   sleep 3   start   ;;   *)   printf "Usage:$0 {start|stop|restart}\n"   exit 1  esac  exit 0 

3.memcached_daemon.sh
监控memcached 进程,如进程失效则自动启动。

#!/bin/sh  #memcached daemon  ROOT=$(cd "$(dirname "$0")"; pwd)  . ${ROOT}/memcached_inc.sh   while : do  if [ -f "$MEMCACHED_PID_FILE" ] && [ -s "$MEMCACHED_PID_FILE" ]; then   PID=$(cat $MEMCACHED_PID_FILE)  else   PID=""  fi    if [ -z "$PID" ] || [ -z $(ps aux|awk '{print $2}' | grep "^$PID$") ]; then   $MEMCACHED   sleep 1   printf "[$(date +%Y-%m-%d' '%H:%M:%S)] ${SITE} ${HOST} memcached ${PORT} is restarted\n" >> $ERROR_LOG_FILE   echo "Subject: ${SITE} ${HOST} memcached ${PORT} is restarted $(date +%Y-%m-%d' '%H:%M:%S)" | sendmail [email protected]  fi   sleep 5  done  exit 0 

使用方法:

./gm_memcached.sh start #启动memcached ./gm_memcached.sh stop #停止memcached ./gm_memcached.sh restart #重启memcached 


shell 记录apache status并自动更新到数据库
1. 获取apache status
monitor_log.sh

#!/bin/bash  #连接数 site_connects=$(netstat -ant | grep $ip:80 | wc -l) #当前连接数 site_cur_connects=$(netstat -ant | grep $ip:80 | grep EST | wc -l)  #apache apache_speed=$(netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}')  printf "[#start#]\n$(date '+%Y-%m-%d %H:%M:%S')\n" printf "connects:${site_connects}\n" printf "cur connects:${site_cur_connects}\n" printf "apache_speed:\n${apache_speed}\n[#end#]\n\n"  exit 0 

在终端设置crontab执行

* * * * * /home/fdipzone/monitor_log.sh >> /home/fdipzone/monitor.log 

2. 将apache status log 写入数据库
save_monitor_log.php

 '192.168.1.100',    'username' => 'username',    'password' => 'password',    'dbname' => 'mydb',    'tabname' => 'monitor_log' );  $obj = new SaveMonitorLog($dbconfig, 'myweb'); $obj->load($logfile);   // x取monitor log,入db,查看db class SaveMonitorLog{ // class start   private $_apache_state = array('TIME_WAIT', 'CLOSE_WAIT', 'SYN_SENT', 'SYN_RECV', 'FIN_WAIT1', 'FIN_WAIT2', 'ESTABLISHED', 'LAST_ACK', 'CLOSING');  private $_dbconfig = array();  private $_site = null;    /** init */  public function __construct($dbconfig=array(), $site='web'){   if(!isset($dbconfig['host']) || !isset($dbconfig['username']) || !isset($dbconfig['password']) || !isset($dbconfig['dbname']) || !isset($dbconfig['tabname'])){    $this->debug('dbconfig error');   }   $this->_dbconfig = $dbconfig;   $this->_site = $site;   $this->connectdb();  }    /** load data  * @param String $logfile log文件  * @return boolean  */  public function load($logfile){    // x取log   if(file_exists($logfile)){    $logdata = file_get_contents($logfile);    // 清空monitor.log    file_put_contents($logfile, '', true);   }else{    return false;   }    // 正t分析 [#start#]*[#end#]   preg_match_all('/#start#(.*?)#end#.*?/si', $logdata, $data);    if(isset($data[1]) && count($data[1])>0){    $alldata = $data[1];    foreach($alldata as $val){     $indb = $this->parser($val);     $newid = $this->addtodb($indb);    }   }   }    /** parser data  * @param Array $data  * @return Array  */  private function parser($data){   $indb = array();   $tmp = explode(chr(10), $data); // 按Q行分隔    $indb['site'] = $this->_site;   $indb['addtime'] = $tmp[1];   $indb['connects'] = array_pop(explode(':',$tmp[2]));   $indb['cur_connects'] = array_pop(explode(':',$tmp[3]));    for($i=5, $max=count($tmp)-2; $i<$max; $i++){    list($key, $num) = explode(' ', $tmp[$i]);    if(in_array($key, $this->_apache_state)){     $indb[$key] = $num;    }   }    return $indb;  }    /** connect db */  private function connectdb(){   $conn=@mysql_connect($this->_dbconfig['host'], $this->_dbconfig['username'], $this->_dbconfig['password']) or die(mysql_error());   mysql_select_db($this->_dbconfig['dbname'], $conn) or die(mysql_error());  }    /** add to db */  private function addtodb($indb){   $insertkey = '';   $insertval = '';   if($indb){    foreach($indb as $key=>$val){     $insertkey .= $insertkey? " ,".$key : $key;     $insertval .= $insertval? " ,'".mysql_escape_string(trim($val))."'" : "'".mysql_escape_string(trim($val))."'";    }    $sqlstr = "insert into ".$this->_dbconfig['tabname']."($insertkey) values($insertval)";    $query = @mysql_query($sqlstr) or die(mysql_error());    $id = mysql_insert_id();    return $id? $id : false;   }  }    /** debug */  private function debug($msg){   exit($msg."\r\n");  }   } // class end  ?> 

在终端crontab执行

0 0 * * * php /home/fdipzone/save_monitor_log.php 

 
table monitor_log struct

CREATE TABLE IF NOT EXISTS `monitor_log` (  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,  `site` varchar(20) NOT NULL,  `connects` int(10) unsigned NOT NULL DEFAULT '0',  `cur_connects` int(10) unsigned NOT NULL DEFAULT '0',  `TIME_WAIT` int(10) unsigned NOT NULL DEFAULT '0',  `CLOSE_WAIT` int(10) unsigned NOT NULL DEFAULT '0',  `SYN_SENT` int(10) unsigned NOT NULL DEFAULT '0',  `SYN_RECV` int(10) unsigned NOT NULL DEFAULT '0',  `FIN_WAIT1` int(10) unsigned NOT NULL DEFAULT '0',  `FIN_WAIT2` int(10) unsigned NOT NULL DEFAULT '0',  `ESTABLISHED` int(10) unsigned NOT NULL DEFAULT '0',  `LAST_ACK` int(10) unsigned NOT NULL DEFAULT '0',  `CLOSING` int(10) unsigned NOT NULL DEFAULT '0',  `addtime` datetime NOT NULL,  PRIMARY KEY (`id`),  KEY `connects` (`connects`),  KEY `cur_connects` (`cur_connects`),  KEY `TIME_WAIT` (`TIME_WAIT`),  KEY `CLOSE_WAIT` (`CLOSE_WAIT`),  KEY `SYN_SENT` (`SYN_SENT`),  KEY `SYN_RECV` (`SYN_RECV`),  KEY `FIN_WAIT1` (`FIN_WAIT1`),  KEY `FIN_WAIT2` (`FIN_WAIT2`),  KEY `ESTABLISHED` (`ESTABLISHED`),  KEY `LAST_ACK` (`LAST_ACK`),  KEY `CLOSING` (`CLOSING`),  KEY `addtime` (`addtime`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 ; 

您可能感兴趣的文章:

  • Ubuntu服务器配置apache2.4的限速功能shell脚本分享
  • Shell脚本实现apache日志中的状态码分析
  • Shell脚本实现分析apache日志中ip所在的地区
  • Shell脚本判断Apache进程是否存在
  • 智能监测自动重启Apache服务器的Shell脚本
  • Apache下通过shell脚本提交网站404死链的方法


  • 上一条:
    PHP实现文件上传与下载实例与总结
    下一条:
    PHP批量去除BOM头内容信息代码
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客