博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

python daemon 守护进程

Posted on 2010-08-27 22:07  月光林地  阅读(2817)  评论(0编辑  收藏  举报
代码
import sys, os    
def main():   
    
""" A demo daemon main routine, write a datestamp to   
        /tmp/daemon-log every 10 seconds.  
    
"""  
    import time   
    f 
= open("/tmp/daemon-log""w")    
    
while 1:    
        f.write(
'%s\n' % time.ctime(time.time()))    
        f.flush()    
        time.sleep(
10)    
if __name__ == "__main__":   
    # 
do the UNIX double-fork magic, see Stevens' "Advanced    
    # Programming in the UNIX Environment" for details (ISBN 0201563177)   
    try:    
        pid 
= os.fork()    
        
if pid > 0:   
            # exit first parent   
            sys.exit(
0)    
    except OSError, e:    
        print 
>>sys.stderr, "fork #1 failed: %d (%s)" % (e.errno, e.strerror)    
        sys.exit(
1)   
    # decouple from parent environment   
    os.chdir(
"/")    
    os.setsid()    
    os.umask(
0)    
    # 
do second fork   
    
try:    
        pid 
= os.fork()    
        
if pid > 0:   
            # exit from second parent, print eventual PID before   
            print 
"Daemon PID %d" % pid    
            sys.exit(
0)    
    except OSError, e:    
        print 
>>sys.stderr, "fork #2 failed: %d (%s)" % (e.errno, e.strerror)    
        sys.exit(
1)    
    # start the daemon main loop   
    main()   

 

以上代码中main()函数包括了一个永久循环过程:把时间戳写入一个文件。

运行的时候,建立一个进程,linux会分配个进程号。然后调用os.fork()创建子进程。若pid>0就是自己,自杀。子进程跳过if语句,通过os.setsid()成为linux中的独立于终端的进程(不响应sigint,sighup等)。

第二次os.fork再创建一个子进程,自己自杀。原因是os.setsid()后成为父进程,虽然已经不被动响应信号,但访问终端文件时控制权还是会失去。这次创建的进程真的是孤魂野鬼的daemon,并且外界对它影响被控制在最小。

代码来自:http://code.activestate.com/recipes/66012/download/1/