脚本宝典收集整理的这篇文章主要介绍了Linux 环境变量详解及实例,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
Linux环境变量
@R_237_2126@Linux操作系统的时候,"/etc/profile", "~/.bash_profile"等配置文件会被自动执行。
执行过程是这样的:
下面看看"~/.bash_profile"文件里面有什么东西
$cat ~/.bash_profile # .bash_profile # Get the aliases and functions if [ -f ~/.bashrc ]; then . ~/.bashrc fi # User sPEcific environment and startup programs PATH=$PATH:$HOME/bin:/home/work/local/python/lib/python2.6/sITe-packages/django/bin/:$HOME/bin:/home/work/local/MySQL5/bin/; LD_LIbrARY_PATH=/home/work/local/mySQL5/lib/mysql alias py='/home/work/local/python/bin/python' export PATH LD_LIBRARY_PATH unset USERNAME
可以看到~/.bash_profile文件先调用~/.bashrc,然后再把PATH和LD_LIBRARY_PATH加载。
环境变量相关配置文件
/etc/profile是全局性的功能,其中设置的变量作用于所有用户,~/.bash_profile中设置的变量能继承/etc/profile中的变量并作用于用户。
通常二者设置大致相同,所以通常前者会调用后者。
crontab执行环境
大家都知道crontab是个好东东,可以定时执行一些任务,帮助你监控系统状况,帮助你每天重复的做一些机械的事情。但是crontab有一个坏毛病,就是它总是不会缺省的从用户profile文件中读取环境变量参数,经常导致在手工执行某个脚本时是成功的,但是到crontab中试图让它定期执行时就是会出错
一般crontab无法运行的问题都是由环境变量在crontab中不一定可识别引起的。
在运行crontab的时候,是non_login方式调用程序的,此时~/.bash_profile并不会被提前调用。所以,crontab的运行环境相对于login方式进入bash运行的环境来说小得多。如果程序涉及~/.bash_profile使用的环境变量,那么,部分在login方式可以正常运行的程序在crontab下就无法运行。
终极推荐解决方案:
30 12 * * * source ~/.bashrc && cd /home/work/mydir && ./myproj
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
以上是脚本宝典为你收集整理的Linux 环境变量详解及实例全部内容,希望文章能够帮你解决Linux 环境变量详解及实例所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。