python daemon 守护进程

代码
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/

你可能感兴趣的:(python)