python—memcached启动脚本

简介:

一、一般模式

    启动选项:start、stop、restart、status

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#!/usr/bin/env python
#encoding:utf-8
 
import  sys
import  os
from  subprocess  import  Popen, PIPE
 
class  Process( object ):
     '''memcached rc script'''
     def  __init__( self ,name,program,argv,workdir):   # 初始化类,包含:self、程序名、程序启动文件、执行参数、pid文件路径
         self .name  =  name
         self .program  =  program
         self .argv  =  argv
         self .workdir  =  workdir
      
         
     def  __workDir( self ):    # 判断pid文件路径,没有则创建
         '''/var/tmp/memcached'''
         if  not  os.path.exists( "/var/tmp/memcached" ):
             os.mkdir( "/var/tmp/memcached" )
             os.chdir( "/var/tmp/memcached" )
             
     def  __pidFile( self ):    # 获取pid文件,带路径
         '''/var/tmp/memcached/memcached.pid'''
         return  os.path.join( self .workdir, "%s.pid"  %  self .name)
         
     def  __writePid( self ):   # 将pid写进pid文件中,pid为字符串类型
         if  self .pid:
             with  open ( self .__pidFile(), "w" ) as fd:
                 fd.write( str ( self .pid))
                 
     def  start( self ):
         pid  =  self .__getPid()    # 判断进程,如已存在则退出
         if  pid:
             print  ( "%s is running"  %  self .name)
             sys.exit()
       
         self .__workDir()
         cmd  =  self .program  +  " "  +  self .argv
         =  Popen(cmd,stdout = PIPE,shell = True )    # 启动进程方式
         self .pid  =  p.pid      # 加self,声明为类的属性,便于其他内部函数调用
         self .__writePid()
         print ( "%s start successful"  %  self .name)
      
         
     def  __getPid( self ):
         =  Popen([ "pidof" , self .name],stdout = PIPE)   # 获取pid方式
         pid  =  p.stdout.read().strip()     # 过滤pid                 
         return  pid
         
     def  stop( self ):
         pid  =  self .__getPid()
         if  pid:
             os.kill( int (pid), 15 )          # 杀掉进程方式,pid为数值类型
             if  os.path.exists( self .__pidFile()):
                 os.remove( self .__pidFile())      # 删掉pid文件
             print ( "%s is stopped"  %  self .name)
      
             
     def  restart( self ):
         self .stop()
         self .start()
      
         
     def  status( self ):
         pid  =  self .__getPid()
         if  pid:
             print  ( "%s is running"  %  self .name)
         else :
             print  ( "%s is not running"  %  self .name)
     
             
     def  help ( self ):
         print  ( "Usage: %s {start|stop|restart|status}"  %  __file__)
     
         
def  main():
     name  =  "memcached"
     program  =  "/data/program/memcached/bin/memcached"
     workdir  =  "/var/tmp/memcached"
     argv  =  "-u nobody -p 11211 -c 1024 -m 64"
     pm  =  Process(name  =  name,
                  program  =  program,
                  workdir  =  workdir,
                  argv  =  argv)     # 传参,也可以按顺序只写实参
     try :
         cmd  =  sys.argv[ 1 ]   # 如启动参数有误,则抛出异常,并退出
    
     except  Exception as e:
         raise  e
         sys.exit()
         
     if  cmd  = =  "start" :
         pm.start()
         
     elif  cmd  = =  "stop" :
         pm.stop()
         
     elif  cmd  = =  "restart" :
         pm.restart()
         
     elif  cmd  = =  "status" :
         pm.status()
         
     else :
         pm. help ()
         
if  __name__  = =  "__main__" :
     main()



二、后台模式

   说明:后台方式:-d -P XXX.pid ;如有配置文件,则配置文件参数替换掉默认参数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
#!/usr/bin/env python
#encoding:utf-8
 
import  sys
import  os
from  subprocess  import  Popen, PIPE
 
class  Process( object ):
     '''memcached rc script'''
      
     argv  =  { "USER" "memcached" ,
             "PORT" "11211" ,
             "MAXCONN" "1024" ,
             "CACHESIZE" "64" ,
             "OPTIONS" : ""}    # 默认启动参数
             
     def  __init__( self ,name,program,workdir):   # 初始化类,包含:self、程序名、程序启动文件、pid文件路径
         self .name  =  name
         self .program  =  program
         self .workdir  =  workdir
     
         
     def  __readConf( self ,f):     # 读取配置文件,返回字典
         with  open (f, "r" ) as fd:
             lines  =  fd.readlines()
             return  dict ([i.strip().split( "=" for  in  lines])
             
     def  __parseArgv( self ):     # 配置文件替换默认参数
     '''/etc/sysconfig/memcached'''
         conf  =  self .__readConf( "/etc/sysconfig/memcached" )
         
         if  "USER"  in  conf:
             self .argv[ "USER" =  conf[ "USER" ]
             
         if  "PORT"  in  conf:
             self .argv[ "PORT" =  conf[ "PORT" ]
             
         if  "MAXCONN"  in  conf:
             self .argv[ "MAXCONN" =  conf[ "MAXCONN" ]
             
         if  "CACHESIZE"  in  conf:
            self .argv[ "CACHESIZE" =  conf[ "CACHESIZE" ]
         
         options  =  [ "-u" , self .argv[ "USER" ],
                    "-p" , self .argv[ "PORT" ],
                    "-m" , self .argv[ "CACHESIZE" ],
                    "-c" , self .argv[ "MAXCONN" ]]   # 替换的参数,以列表形式返回
                    
         os.system( "chown %s %s"  %  ( self .argv[ "USER" ], self .workdir))  # 修改pid文件目录的属主为启动用户,才能写pid文件
         print  ( "启动参数为:%s"  %  str (options))
         return  options
         
     def  __workDir( self ):    # 判断pid文件路径,没有则创建
         '''/var/tmp/memcached'''
         if  not  os.path.exists( "/var/tmp/memcached" ):
             os.mkdir( "/var/tmp/memcached" )
             os.chdir( "/var/tmp/memcached" )
             
     def  __pidFile( self ):    # 获取pid文件,带路径
         '''/var/tmp/memcached/memcached.pid'''
         return  os.path.join( self .workdir, "%s.pid"  %  self .name)
         
     def  start( self ):
         pid  =  self .__getPid()
         if  pid:
             print  ( "%s is running"  %  self .name)
             sys.exit()
       
         self .__workDir()
         cmd  =  [ self .program]  +  self .__parseArgv()  +  [ "-d" "-P" self .__pidFile()]   # 启动参数,后台启动方式,按指定文件自动写pid
         =  Popen(cmd,stdout = PIPE)    # 启动进程方式
         print ( "%s start successful"  %  self .name)
      
         
     def  __getPid( self ):
         =  Popen([ "pidof" , self .name],stdout = PIPE)   # 获取pid方式
         pid  =  p.stdout.read().strip()     # 过滤pid                 
         return  pid
         
     def  stop( self ):
         pid  =  self .__getPid()
         if  pid:
             os.kill( int (pid), 15 )          # 杀掉进程方式,pid为数值类型
             if  os.path.exists( self .__pidFile()):
                 os.remove( self .__pidFile())      # 删掉pid文件
             print ( "%s is stopped"  %  self .name)
      
             
     def  restart( self ):
         self .stop()
         self .start()
      
         
     def  status( self ):
         pid  =  self .__getPid()
         if  pid:
             print  ( "%s is running"  %  self .name)
         else :
             print  ( "%s is not running"  %  self .name)
     
             
     def  help ( self ):
         print  ( "Usage: %s {start|stop|restart|status}"  %  __file__)
      
         
def  main():
     name  =  "memcached"
     program  =  "/data/program/memcached/bin/memcached"
     workdir  =  "/var/tmp/memcached"
     
     pm  =  Process(name  =  name,
                  program  =  program,
                  workdir  =  workdir)     # 传参,也可以按顺序只写实参
     try :
         cmd  =  sys.argv[ 1 ]   # 如启动参数有误,则抛出异常,并退出
    
     except  Exception as e:
         raise  e
         sys.exit()
         
     if  cmd  = =  "start" :
         pm.start()
         
     elif  cmd  = =  "stop" :
         pm.stop()
         
     elif  cmd  = =  "restart" :
         pm.restart()
         
     elif  cmd  = =  "status" :
         pm.status()
         
     else :
         pm. help ()
         
if  __name__  = =  "__main__" :
     main()









本文转自 huangzp168 51CTO博客,原文链接:http://blog.51cto.com/huangzp/2048280,如需转载请自行联系原作者
目录
相关文章
|
11天前
|
Python
自动化微信朋友圈:Python脚本实现自动发布动态
本文介绍如何使用Python脚本自动化发布微信朋友圈动态,节省手动输入的时间。主要依赖`pyautogui`、`time`、`pyperclip`等库,通过模拟鼠标和键盘操作实现自动发布。代码涵盖打开微信、定位朋友圈、准备输入框、模拟打字等功能。虽然该方法能提高效率,但需注意可能违反微信使用条款,存在风险。定期更新脚本以适应微信界面变化也很重要。
117 60
|
2月前
|
数据采集 监控 数据挖掘
Python自动化脚本:高效办公新助手###
本文将带你走进Python自动化脚本的奇妙世界,探索其在提升办公效率中的强大潜力。随着信息技术的飞速发展,重复性工作逐渐被自动化工具取代。Python作为一门简洁而强大的编程语言,凭借其丰富的库支持和易学易用的特点,成为编写自动化脚本的首选。无论是数据处理、文件管理还是网页爬虫,Python都能游刃有余地完成任务,极大地减轻了人工操作的负担。接下来,让我们一起领略Python自动化脚本的魅力,开启高效办公的新篇章。 ###
|
1月前
|
数据采集 存储 监控
21个Python脚本自动执行日常任务(2)
21个Python脚本自动执行日常任务(2)
94 7
21个Python脚本自动执行日常任务(2)
|
20天前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
88 5
|
1月前
|
Android开发 开发者 Python
通过标签清理微信好友:Python自动化脚本解析
微信已成为日常生活中的重要社交工具,但随着使用时间增长,好友列表可能变得臃肿。本文介绍了一个基于 Python 的自动化脚本,利用 `uiautomator2` 库,通过模拟用户操作实现根据标签批量清理微信好友的功能。脚本包括环境准备、类定义、方法实现等部分,详细解析了如何通过标签筛选并删除好友,适合需要批量管理微信好友的用户。
57 7
|
2月前
|
监控 数据挖掘 数据安全/隐私保护
Python脚本:自动化下载视频的日志记录
Python脚本:自动化下载视频的日志记录
|
2月前
|
运维 监控 网络安全
自动化运维的崛起:如何利用Python脚本简化日常任务
【10月更文挑战第43天】在数字化时代的浪潮中,运维工作已从繁琐的手工操作转变为高效的自动化流程。本文将引导您了解如何运用Python编写脚本,以实现日常运维任务的自动化,从而提升工作效率和准确性。我们将通过一个实际案例,展示如何使用Python来自动部署应用、监控服务器状态并生成报告。文章不仅适合运维新手入门,也能为有经验的运维工程师提供新的视角和灵感。
|
2月前
|
存储 Python
Python自动化脚本编写指南
【10月更文挑战第38天】本文旨在为初学者提供一条清晰的路径,通过Python实现日常任务的自动化。我们将从基础语法讲起,逐步引导读者理解如何将代码块组合成有效脚本,并探讨常见错误及调试技巧。文章不仅涉及理论知识,还包括实际案例分析,帮助读者快速入门并提升编程能力。
114 2
|
2月前
|
运维 监控 Python
自动化运维:使用Python脚本简化日常任务
【10月更文挑战第36天】在数字化时代,运维工作的效率和准确性成为企业竞争力的关键。本文将介绍如何通过编写Python脚本来自动化日常的运维任务,不仅提高工作效率,还能降低人为错误的风险。从基础的文件操作到进阶的网络管理,我们将一步步展示Python在自动化运维中的应用,并分享实用的代码示例,帮助读者快速掌握自动化运维的核心技能。
114 3
|
2月前
|
缓存 运维 NoSQL
python常见运维脚本_Python运维常用脚本
python常见运维脚本_Python运维常用脚本
36 3
下一篇
开通oss服务