背景:
我再测试一个运行的后台脚本不退出的情况下给环境变量文件.bashrc或.bash_profile增加一个环境变量例如$caoge=caoge_test,发现在后台运行的脚本执行source ~ /.barc和source ~/.bash_profile的效果不同,下边是我的测试结果:
关于shell读取环境变量文件:
.bashrc
.bash_profile
的时机问题测试:
.bash_profile
测试代码:
while [[ 1 ]];then
echo $caoge
source ~/.bash_profile
sleep
done
在另一个终端进行给.bash_profile 写入$caoge变量的时shell不能读取到,
增加后删除也不会出现
.bashrc
同上,只不过改为另一个终端操作.bashrc
在另一个终端做相同操作,增加变量时可以读取到,
增加后删除是无法读取的
测试条件三:
while [[ 1 ]];then
echo $caoge
source ~/.bash_profile
sleep
done
在另一个终端操作:给.bashrc增加不存在的变量$caoge后,shell能读取到,删除后依然能读取到
测试条件四:
while [[ 1 ]];then
echo $caoge
source ~/.bashrc
sleep
done
在另一个终端操作:给。bash_profile增加不存在的变量$caoge后,shell不能读取到,删除后依然不能读取到
测试总结:
shell有读取.bashrc和.bash_profile的机制问题,
所以还是看下shell读取.bashrc和.bash_profile的区别以及source的简单原理吧:
source 转载自 :
http://blog.csdn.net/xiaolang85/article/details/7861441
http://www.xxlinux.com/linux/article/development/shell/2006-09-22/4499.html
http://www.diybl.com/course/6_system/linux/Linuxjs/20071027/80454.html
http://linux.chinaunix.net/techdoc/system/2008/09/04/1030374.shtml
exec和source都属于bash内部命令(builtins commands),在bash下输入man exec或man source可以查看所有的内部命令信息。
bash shell的命令分为两类:外部命令和内部命令。外部命令是通过系统调用或独立的程序实现的,如sed、awk等等。内部命令是由特殊的文件格式(.def)所实现,如cd、history、exec等等。
在说明exe和source的区别之前,先说明一下fork的概念。
fork是linux的系统调用,用来创建子进程(child process)。子进程是父进程(parent process)的一个副本,从父进程那里获得一定的资源分配以及继承父进程的环境。子进程与父进程唯一不同的地方在于pid(process id)。
环境变量(传给子进程的变量,遗传性是本地变量和环境变量的根本区别)只能单向从父进程传给子进程。不管子进程的环境变量如何变化,都不会影响父进程的环境变量。