你所不知道的Linux Source 命令
来源:互联网 发布:淘宝接单大厅 编辑:程序博客网 时间:2024/05/21 15:48
source命令用法:
source FileName
作用:在当前bash环境下读取并执行FileName中的命令。
注:该命令通常用命令“.”来替代。
如:source .bash_rc 与 . .bash_rc 是等效的。
source命令(从 C Shell 而来)是bash shell的内置命令。点命令,就是个点符号,(从Bourne
Shell而来)是source的另一名称。同样的,当前脚本中配置的变量也将作为脚本的环境,source(或点)命令通常用于重新执行刚修改的初始化
文档,如 .bash_profile 和 .profile 等等。例如,假如在登录后对 .bash_profile 中的,PATHEDITER 和
TERM 变量做了修改,则能够用source命令重新执行 .bash_profile 中的命令而不用注销并重新登录。
比如您在一个脚本里export $KKK=111 ,假如您用./a.sh执行该脚本,执行完毕后,您运行 echo $KKK
,发现没有值,假如您用source来执行 ,然后再echo
,就会发现KKK=111。因为调用./a.sh来执行shell是在一个子shell里运行的,所以执行后,结构并没有反应到父shell里,但是
source不同他就是在本shell中执行的,所以能够看到结果
source命令的一个妙用
在编译核心时,常常要反复输入一长串命令,如
make mrproper
make menuconfig
make dep
make clean
make bzImage
.......
这些命令既长,又繁琐。而且有时候容易输错,浪费你的时间和精力。如果把这些命令做成一个文件,让它自动按顺序执行,对于需要多次反复编译核心的用
户来说,会很方便。用source命令可以办到这一点。它的作用就是把一个文件的内容当成是shell来执行。先在/usr/src/linux-
2.4.20目录下建立一个文件,取名为make_command:
在其中输入如下内容:
make mrproper &&
make menuconfig &&
make dep &&
make clean &&
make bzImage &&
make modules &&
make modules_install &&
cp arch/i386/boot/bzImge /boot/vmlinuz_new &&
cp System.map /boot &&
vi /etc/lilo.conf &&
lilo -v
文件建立好之后,以后每次编译核心,只需要在/usr/src/linux-2.4.20下输入
source make_command
就行了。这个文件也完全可以做成脚本,只需稍加改动即可。这里主要是让大家理解source的用法。如果你用的不是lilo来引导系统,可以把最后两句话去掉。配置你自己的引导程序来引导新内核。
shell编程中的命令有时和C语言是一样的。&&表示与,||表示或。把两个命令用&&联接起来,如
make mrproper && make menuconfig
,表示要第一个命令执行成功才能执行第二个命令。对执行顺序有要求的命令能保证一旦有错误发生,下面的命令不会盲目地继续执行。
- 你所不知道的Linux Source 命令
- 你所不知道的 Linux 命令!
- 你所不知道的Linux svn管理工具命令
- 更多你所不知道的 Linux 命令
- 在 Linux 下你所不知道的 df 命令的那些功能
- 在Linux下你所不知道的df命令的那…
- 在 Linux 下你所不知道的 df 命令的那些功能
- 那些你不知道的linux命令
- Linux shell你所不知道的$($*和$@)
- 你所不知道的linux匿名管道知识
- Linux第一课,你所不知道的快捷键
- 你所不知道list的妙用
- 你所不知道的西安
- 你所不知道的知识
- 你所不知道的华为(z)
- 你所不知道的const
- 告诉你所不知道的typedef
- 告诉你所不知道的typedef
- USB学习网
- VS2008下如何调试matlab使用的动态链接库
- 数据结构
- 洗牌
- 六周任务3
- 你所不知道的Linux Source 命令
- jvm虚拟机
- 浮点数
- CachedIntrospectionResults源码研究(一)
- 黑马程序员--C#基础知识小结(三)
- POJ 1068 Parencodings
- STL之容器适配器:stack,queue , priority_queue
- jquery选择器
- mysql SUM聚合运算的返回值为MYSQL_TYPE_NEWDECIMAL