• 在Linux中以普通用户开机自动运行脚本程序


     Linux的环境配置文件----.bashrc文件 - CompileLife - 博客园 (cnblogs.com)

    测试环境:CentOS6.5

    管理员:root

    普通用户:test1

    实现目标:在Linux启动时,以普通用户test1自动运行位于根目录下的脚本程序test.py,该程序会在每次执行时自动向本地日志文件追加一条记录,源码如下:

    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 $1 in --使用case,可以进行交互式操作
    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,因此可以正常执行你期望的脚本程序,顺利实现开机自动启动指定的脚本程序。

    执行方案中重要的一个命令是:

    [root@localhost ~]# whoami
    root
    [root@localhost ~]# su - keysystem -c "whoami"
    keysystem
    [root@localhost ~]# 

    以keysystem用户执行whoami的命令:

    [root@localhost ~]# su - keysystem -c "whoami"

    作者:你的雷哥
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须在文章页面给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    Go语言使用grpc
    Go语言中使用protobuf
    proto3语法
    golang标准库io
    走近docker--容器生态系统
    编译技术图式(第四章 语义分析)
    计算机组成原理与结构图示(存储器设计)
    微机原理与汇编接口图式(第一章 数制)
    编译技术图式(第四章 语法分析)03自下而上的语法分析
    计算机组成原理和结构图式(第四章 存储器子系统)
  • 原文地址:https://www.cnblogs.com/henuliulei/p/14979442.html
Copyright © 2020-2023  润新知