Python定时执行脚本

 

最近测试hbase,老发现服务挂掉,自己不能及时发现,想了想,写了个脚本,让脚本每个小时执行一次,以便检测是否有服务挂掉,如果有服务挂掉,及时启动

 

import os
import datetime
class CheckService(object):

    def __init__(self):
        pass
  
    def getService(self):
        # service list
        service = ['Jps'
                ,'EmbeddedServer'
                ,'QuorumPeerMain'
                ,'NodeManager'
                ,'ResourceManager'
                ,'NameNode'
                ,'SecondaryNameNode'
                ,'HMaster'
                ,'HRegionServer'
                ,'RunJar'

                ]
        # Traversal list
        for i in service:
            a = "jps | awk '{print $2}'|grep "+i
            res = os.system(a)
            # Determine whether the service is running
            if res != 0 :
                print "%s is not running!" %(i)
                if i == 'HMaster':
                    os.system('start-hbase.sh')
                elif i == 'HRegionServer':
                    os.system('local-regionservers.sh start 1')
                elif i == 'EmbeddedServer':
                    os.system('ranger-admin start')
                elif i == 'QuorumPeerMain':
                    os.system('zkServer.sh start')
                    else:
                    print 'restart Hadoop !!!'

    def timerFun(self,sched_Timer):
        flag = 0
        while True:
            now = datetime.datetime.now()
            if now == sched_Timer:
                self.getService()
                flag = 1
          else: if flag == 1: sched_Timer = sched_Timer + datetime.timedelta(hours=1) flag = 0 if __name__ == "__main__": cs = CheckService() sched_Timer = datetime.datetime(2017,7,25,9,14) print 'run the timer task at {0}'.format(sched_Timer) cs.timerFun(sched_Timer)

这个代码也可以扩展,把hours=1改成minutes=1就变成了每个小时定时任务,改成days=1就变成每天的定时任务

posted @ 2017-07-25 11:00  RoyFans  阅读(11631)  评论(0编辑  收藏  举报