Ubuntu中shell脚本无法使用source命令的原因与解决方法

时间:2021-02-10 03:28:43

本文简要描述了在ubuntu系统下无法使用source命令的原因,及对应的两种解决方法,并在附录中引用一篇文章来详细解释source命令的用法

问题:

由于在交叉编译时,需要在当前shell内执行source命令来临时指定系统的编译环境为嵌入式环境。故希望通过编写一个shell脚本来自动执行编译命令,然而在脚本中通过source命令指定编译环境时,系统会提示找不到命令

原因:

source命令是bash shell的内置命令,而ubuntu 默认用的是dash(基本POSIX标准的命令解释器),与bash的最大不同在于,dash遵守POSIX标准,ubuntu在启动的时候会运行很多shell脚本,使用dash可以加快启动速度。

解决方法:

方法一:

在ubuntu下将shell切换回bash

ls -l /bin/sh

可以查到当前系统shell使用的版本

Ubuntu中shell脚本无法使用source命令的原因与解决方法

执行以下命令,并选择No,可以将默认的shell切换回bash

Ubuntu中shell脚本无法使用source命令的原因与解决方法

Ubuntu中shell脚本无法使用source命令的原因与解决方法

Ubuntu中shell脚本无法使用source命令的原因与解决方法

在bash下的SHELL脚本即可执行source命令

方法二:

在shell脚本中,将默认用于执行的脚本的程序设置为bash

#!/bin/bash

然后执行该脚本即可

附:linux下的source命令(.命令)解释及应用

source是什么?

通知当前shell读入路径为filename 的文件并依次执行文件中的所有语句

通常用于重新执行刚修改的初始化文件,使之立即生效,而不必注销并重新登录。例如,当我们修改了/etc/profile文件,并想让它立刻生效,而不用重新登录,就可以使用source命令,如“source /etc/profile”。

source命令是bash shell的内置命令。而点命令(即“.”命令)则是source的另一名称。这两个命令都以一个脚本为参数,该脚本将作为当前shell的环境执行,即不会启动一个新的子进程。所有在脚本中设置的变量将成为当前Shell的一部分。

鉴于上述的描述,最简单的一种应用场景就是,进行交叉编译时,在当前shell内采用source命令临时指定系统的编译环境为嵌入式编译环境,然后进行源码的编译和调试。而在别的shell内或者你关闭本shell时,一切又恢复原样。

“source filename”“sh filename”“./filename”的联系与区别

这三个命令都可以用于执行一个脚本文件

  • 当shell脚本具有可执行权限时,用sh filename与./filename是没有区别的。./filename是因为当前目录没有在PATH中,所以"."是用来表示当前目录的。
  • sh filename会重新建立一个子shell,在子shell中执行脚本里面的语句,该子shell继承父shell的环境变量,但子shell是新建的,其改变的变量不会被带回父shell,除非使用export。
  • source filename读取脚本里面的语句依次在当前shell里面执行,没有建立新的子shell。那么脚本里面所有新建、改变变量的语句都会保存在当前shell里面。

在实践中体会

新建一个test.sh脚本,内容为:A=1;

修改其可执行权限:chmod +x test.sh;

运行sh test.sh后,echo $A,显示为空,因为A=1并未传回给当前shell;

运行./test.sh后,也是一样的效果;

运行source test.sh 或者 . test.sh,然后echo $A,则会显示1,说明A=1的变量在当前shell中;