【已解决】Linux中程序脚本可以手动执行成功,但加在rc.local中不能开机自启

之前开发遇到的一个问题:在Linux中,明明程序脚本可以手动执行成功,但加到开机自启动里,却会失败,属实让人摸不着头脑。

问题排查:

有以下几种可能:

  1. 自启动脚本,执行权限不足或者脚本中使用了相对路径;
  2. 程序依赖其他服务,需要等待前置服务完全可用,比如依赖数据库、消息队列等;
  3. 开机启动时未加载用户自定义的环境变量(如PATH、LD_LIBRARY_PATH等)

解决办法

前两个很好解决,设置权限,修改脚本,增加sleep时间即可。

而博主刚好遇到是第三种情况,软件需要配置自定义的环境变量,尽管在/etc/profile中已经设置了环境变量,但是当只把程序的开启自启动加在rc.local中时,程序所需要的环境变量并不会被自动加载进来。可以在rc.local中在xx.sh命令之前先export 自定义的环境变量,完美解决。

深入分析

追本溯源,先来看一下Linux系统中rc.local的启动顺序

复制代码
第一步:init /etc/inittab
第二步:启动相应的脚本,并且打开终端
rc.sysinit
rc.d(里面的脚本)
rc.local
第三步:启动login登录界面 login
第四步:在用户登录的时候执行sh脚本的顺序,每次登录的时候都会完全执行的
/etc/profile.d/file
/etc/profile
/etc/bashrc
/root/.bashrc
/root/.bash_profile

这说明rc.local运行在操作系统完全引导成功,但是尚未启动login shell之前。比如我们可以在rc.local中加入env把环境变量打印出来,可以看到环境变量非常少。如果我们在/etc/profiles或bashrc中配置了环境变量,xx.sh依赖这些环境变量,由于rc.local执行阶段看不到这些环境变量,所以会执行失败。

该问题的解决办法:在rc.local中在xx.sh命令之前加上export。

相关推荐
路弥行至13 小时前
C语言入门教程 | 第四讲:深入理解数制与码制,掌握基本数据类型的奥秘
服务器·c语言·开发语言·经验分享·笔记·其他·入门教程
艾莉丝努力练剑13 小时前
【Linux指令 (一)】Linux 命令行入门:从零开始理解Linux系统理论核心概念与基础指令
linux·c++·经验分享·ubuntu·centos
linweidong13 小时前
云服务器磁盘空间管理:binlog导致磁盘快速增长的应对策略与自动化实践
运维·服务器·自动化·binlog·容器化·磁盘管理·运维面经
COWORKSHOP14 小时前
华为芯片泄密案警示:用Curtain e-locker阻断内部数据泄露
运维·服务器·前端·数据库·安全·华为
DeeplyMind14 小时前
rocr专栏介绍
linux·ai·amdgpu·rocm·rocr·libhsakmt·thunk
namekong814 小时前
在 Ubuntu 上可以用几个常用命令查看系统运行情况(内存、CPU、硬盘占用等
linux·运维·服务器
wheeldown14 小时前
【Linux】Linux下的静态链接的底层逻辑
linux·运维·服务器
gsfl14 小时前
环境搭建,Ubuntu 安装、客户端使用与性能认知
linux·运维·ubuntu
EndingCoder14 小时前
构建RESTful API:用户管理示例
linux·javascript·node.js
且行且知15 小时前
在ubuntu下载企业微信
linux·ubuntu·企业微信