使用 python 实现 memcached 的启动服务脚本 rc

简介:   #!/usr/bin/python #coding:utf-8 import sys import os from subprocess import Popen, PIPE class Memcached(object): ''' memcached r...

 

 

#!/usr/bin/python
#coding:utf-8

import sys
import os
from subprocess import Popen, PIPE

class Memcached(object):
    ''' memcached rc script '''
    args = {'USER':'memcached', 'PORT':11211, 'MAXCONN':1024, 'CACHESIZE':64, 'OPTIONS':''}

    def __init__(self, name, program, workdir):
        self.name = name
        self.program = program
        #self.args = args
        self.workdir = workdir

    def _init(self):
        ' /var/tmp/memcached '
        if not os.path.exists(self.workdir):
            os.mkdir(self.workdir)
            os.chdir(self.workdir)
    def _pidFile(self):
        ''' /var/tmp/memcached/memcached.pid '''
        return os.path.join(self.workdir, '%s.pid' % self.name)
    
    def _writePid(self):
        if self.pid:
            with open(self._pidFile(), 'w') as fd:
                fd.write(str(self.pid))
    def _readConf(self, f):
        with open(f) as fd:
            lines = fd.readlines()
            return dict([i.strip().replace('"', '').split('=') for i in lines])

    def _parseArgs(self):
        conf = self._readConf('/etc/sysconfig/memcached')
        if 'USER' in conf:
            self.args['USER'] = conf['USER']
        if 'PORT' in conf:
            self.args['PORT'] = conf['PORT']
        if 'MAXCONN' in conf:
            self.args['MAXCONN'] = conf['MAXCONN']
        if 'CACHESIZE' in conf:
            self.args['CACHESIZE'] = conf['CACHESIZE']
        options = ['-u', self.args['USER'],
                   '-p', self.args['PORT'],
                   '-m', self.args['CACHESIZE'],
                   '-C', self.args['MAXCONN']]
        os.system('chown %s %s' % (self.args['USER'], self.workdir))
        ''' 这个地方要修改工作目录的权限,用户为memcached,需要有写目录的权限。 '''
        return options

    def start(self):
        pid = self._getPid()
        if pid:
            print '%s is running...' % self.name
            sys.exit()

        self._init()
        cmd = [self.program] + self._parseArgs() + ['-d', '-P', self._pidFile()]
        print cmd
        p = Popen(cmd, stdout = PIPE)
        #self.pid = p.pid
        #self._writePid()
        # 如果程序选项中有-P选项,那么应用程序会自动去写pid文件,不用手动去写,而且要注意pid与手动写入的pid有何区别。
        print '%s start Sucessful' % self.name    
    
    def _getPid(self):
        p = Popen(['pidof', self.name], stdout=PIPE)
        pid = p.stdout.read().strip()
        return pid

    

    def stop(self):
        pid = self._getPid()
        if pid:
            os.kill(int(pid), 15)
            if os.path.exists(self._pidFile()):
                os.remove(self._pidFile())
            print '%s is stopped' % self.name
        
    
    def restart(self):
        self.stop()
        self.start()
    
    def status(self):
        pid = self._getPid()
        if pid:
            print '%s is already running' % self.name
        else:
            print '%s is not running' % self.name    

    def help(self):
        print 'Usage: %s {start|stop|status|restart}' % __file__

def main():
    name = 'memcached'
    prog = '/usr/bin/memcached'
    #args = '-u nobody -p 11211 -c 1024 -m 64'
    wdir = '/var/tmp/memcached'

    rc = Memcached(name, prog, wdir)
    try:
        cmd = sys.argv[1]
    except IndexError, e:
        print "Option error"
        sys.exit()

    if cmd == 'start':
        rc.start()
    elif cmd == 'stop':
        rc.stop()
    elif cmd == 'restart':
        rc.restart()
    elif cmd == 'status':
        rc.status()
    else:
        rc.help()

if __name__ == '__main__':
    main()

  

相关文章
|
21天前
|
Linux Shell Python
Linux执行Python脚本
Linux执行Python脚本
26 1
|
1月前
|
JSON API 数据库
解释如何在 Python 中实现 Web 服务(RESTful API)。
解释如何在 Python 中实现 Web 服务(RESTful API)。
25 0
|
10天前
|
JSON 测试技术 持续交付
自动化测试与脚本编写:Python实践指南
【4月更文挑战第9天】本文探讨了Python在自动化测试中的应用,强调其作为热门选择的原因。Python拥有丰富的测试框架(如unittest、pytest、nose)以支持自动化测试,简化测试用例的编写与维护。示例展示了使用unittest进行单元测试的基本步骤。此外,Python还适用于集成测试、系统测试等,提供模拟外部系统行为的工具。在脚本编写实践中,Python的灵活语法和强大库(如os、shutil、sqlite3、json)助力执行复杂测试任务。同时,Python支持并发、分布式执行及与Jenkins、Travis CI等持续集成工具的集成,提升测试效率和质量。
|
17天前
|
数据采集 Java API
python并发编程: Python使用线程池在Web服务中实现加速
python并发编程: Python使用线程池在Web服务中实现加速
17 3
python并发编程: Python使用线程池在Web服务中实现加速
|
17天前
|
存储 监控 异构计算
【Python】GPU内存监控脚本
【Python】GPU内存监控脚本
|
17天前
|
Ubuntu Unix Linux
【Linux/Ubuntu】Linux/Ubuntu运行python脚本
【Linux/Ubuntu】Linux/Ubuntu运行python脚本
|
25天前
|
XML Shell Linux
性能工具之 JMeter 使用 Python 脚本快速执行
性能工具之 JMeter 使用 Python 脚本快速执行
40 1
性能工具之 JMeter 使用 Python 脚本快速执行
|
29天前
|
存储 监控 数据库
Python语言的通用操作系统服务
Python语言的通用操作系统服务
|
1月前
|
负载均衡 Java Nacos
python flask服务如何注册到nacos
一文讲清楚python flask服务如何注册到nacos
83 2
python flask服务如何注册到nacos
|
1月前
|
数据采集 测试技术 Python
Python自动化脚本的魅力与实践
Python自动化脚本的魅力与实践
48 0

热门文章

最新文章