from datetime import datetime 
 
     now = datetime.now() 
 
     f = open('test.log', 'a') 
 
     f.write('%s' % now) 
 
     f.close()



    Linux在启动时,会自动执行/etc/rc.d目录下的初始化程序,因此我们可以把启动任务放到该目录下,有两种办法: 
    方案一: 
    1、因为其中的rc.local是在完成所有初始化之后执行,因此我们可以把启动脚本写到里面 
    2、用root账号登陆Linux,vi /etc/rc.d/rc.local编辑文件,在最后加入两行需要执行的脚本程序: 
    cd /home/test1 --该步不可少,否则会提示没有权限打开'test.log'文件 
    su test1 -c "python /home/test1/test.py" --把要执行的命令作为一个参数传递级su 

    方案二: 
    1、init.d目录下都为可执行程序,他们其实是服务脚本,按照一定格式编写,Linux 在启动时会自动执行,类似Windows下的服务 
    2、用root帐号登录,vi /etc/rc.d/init.d/mystart,追加如下内容: 

#!/bin/bash 
      #chkconfig:2345 80 05 --指定在哪几个级别执行,0一般指关机,6指的是重启,其他为正常启动。80为启动的优先级,05为关闭的优先级 
      #description:mystart service 
      RETVAL=0 
      # 启动服务的入口函数 
      start() 
      { 
          echo -n "mystart serive ..." 
          cd /home/test1 
          su test1 -c "python /home/test1/test.py" 
      } 
      # 关闭服务的入口函数 
      stop() 
      { 
          echo "mystart service is stoped..." 
      } 
      # 使用case,可以进行交互式操作 
      case $1 in 
          start) 
              start 
          ;; 
          stop) 
              stop 
          ;; 
      esac 
      exit $RETVAL



    3、运行chmod +r /etc/rc.d/init.d/mystart,使之可直接执行 
    4、运行chkconfig --add mystart,把该服务添加到配置当中
    5、运行chkconfig --list mystart,可以查看该服务进程的状态 

    总结: 
    两种方案的的核心都是切换用户到test1,然后执行命令启动Python程序,做成服务的好处是可以定义多个交互命令,比如:start,stop,restart,reset...,在服务运行的过程中还可以做相应操作。

最开始的时候,我按照一般的思路写了如下脚本,却怎么也执行不了: 
    su test1 --切换到test1用户
    cd /home/test1 --切换到根目录
    python test.py --执行python程序
    exit --退出test1帐号

    看起来好象一切都没错,但是发现只运行了第一行的命令,后面的都没有运行,直到退出test1用户后才发现好象执行完毕。分析原因,是因为Linux启动的时候是在root帐号下,执行su test1等于打开了一个新的shell脚本,因此下面的代码都在等着新的Shell脚本结束才能运行,就象在主程序里调用了一个子程序,而子程序是个死循环。知道了发生的原因,那么解决的办法就相对简单了,就是在执行上述脚本程序时,不要离开本身的Shell。我们可以把执行命令做为su的一个参数传递进去,因为没有涉及到打开新的Shell,因此可以正常执行你期望的脚本程序,顺利实现开机自动启动指定的脚本程序。