1. shell脚本的执行
  当shell脚本以非交互的方式运行时,它会先查找环境变量ENV,该变量指定了一个环境文件(通常是.bashrc),然后从该环境变量文件开始执行,当读取了ENV文件后,shell才开始执行shell脚本中的内容。
  shell脚本的执行通常可以采用以下三种方式:
    ①. Bash script-name 或sh script-name (推荐使用)
    ②. Path/script-name 或./script-name (当前路径下执行脚本)
    ③. Source script-name 或 .script-name #注意“.”点号。
  执行说明
  第一种方法是当脚本文件本身没有可执行权限(即文件X位为-号)时常使用的方法,这里推荐用bash执行,或者文件开头没有指定解释器
  第二种方法需要先将脚本文件的权限改为可执行(即文件加X位),具体方法:chmod u+x script-name 或 chmod 755 script-name 。然后通过脚本路径就可以直接执行脚本了。
  第三种方法通常是使用 source或者“,”点号读入或加载指定的shelll脚本文件(san.sh),然后,依次执行指定shell脚本文件san.sh中的所有语句。这些语句将作为父shell脚本father.sh进程的一部分运行。因此,使用source或者“.”点号可以将san.sh自身脚本中的变量的值或函数等的返回值传递到当前的父shell脚本father.sh中使用。这是第三种方法和前两种方法的最大区别,也是值得读者注意的地方。
  source或者“."点号命令的功能是在当前shell中执行source或者“.”点号加载并执行的相关脚本文件中的命令及语句,而不是产生一个子shell来执行命令文件中的命令。
  下面我们举例说明:

[root@yanwei-test1 scripts]# cat test.sh
echo 'I am oldboy'

 输入“echo ‘I am oldboy”内容后按回车,然后在按ctrl+d组合建即可结束编程。此操作作为特殊编辑方法,作为cat用法的扩展知识提及(老男孩PS:在使用中去记忆是个好习惯)

[root@yanwei-test1 scripts]# cat test.sh
echo 'I am oldboy'
[root@yanwei-test1 scripts]# sh test.sh #使用第一种方式的sh命令执行test.sh脚本文件
I am oldboy
[root@yanwei-test1 scripts]# bash test.sh #使用第一种方式的sh命令执行test.sh脚本文件
I am oldboy

 我们使用第一种方法,发现均可以执行并得到了预期的结果。

[root@yanwei-test1 scripts]# ./test.sh     #使用第二种方式“./”在当前目录下执行test.sh脚本文件,细心的读者可以发现,这个地方无法自动补全。
-bash: ./test.sh: 权限不够 #提示:权限拒绝,此处因为没有执行权限
[root@yanwei-test1 scripts]# chmod +x test.sh
[root@yanwei-test1 scripts]# ./test.sh
I am oldboy

但是可以用source或者"."点号执行

[root@yanwei-test1 scripts]# . test.sh    #请注意,这里“.”执行,必须有空格
I am oldboy
[root@yanwei-test1 scripts]# source test.sh
I am oldboy

我们看到,给test.sh加完可执行权限就可以执行了
  现在测试第三种方法source或者“.”点号的特殊的传递变量值到当前shell的例子

[root@yanwei-test1 scripts]# echo 'userdir=`pwd`' > testsource.sh #一行的内容通常用echo编辑很方便
[root@yanwei-test1 scripts]# cat testsource.sh
userdir=`pwd`
[root@yanwei-test1 scripts]# sh testsource.sh
[root@yanwei-test1 scripts]# echo $userdir
#此处为空,并没有出现当前路径输出,这是为什么呢?

  根据上面例子,我们可以发现,通过sh或bash命令执行过的脚本,脚本结束后在当前shell窗口查看userdir变量的值,发现值是为空的,现在以同样的步骤改用source执行,然后再看看userdir变量的值。

[root@yanwei-test1 scripts]# source testsource.sh
[root@yanwei-test1 scripts]# echo $userdir
/server/scripts

结论:通过source或“.”点号加载执行过的脚本,在脚本结束后脚本中的变量(包括函数)值在当前shell中依然存在,而sh和bash则不行。因此,在做shell脚本开发时,如果脚本中有需求引用其他脚本的内容或者配置文件时,最好用“.”点号或source在脚本开头加载该脚本或配置文件,然后在下面的内容用可以调用source加载的脚本及文件中的变量及函数等内容。
    某互联网公司linux运维职位实际面试笔试填空题:

已知如下命令及返回结果,请问echo $user的返回的结果为( )
[root@yanwei-test1 scripts]# echo 'user=`whoami`' >whoamisource.sh
[root@yanwei-test1 scripts]# cat whoamisource.sh
user=`whoami`
[root@yanwei-test1 scripts]# sh whoamisource.sh
[root@yanwei-test1 scripts]# echo $user 答案:
1、当前用户
2、空(无内容输出) #这个是正确答案

  

shell-脚本的执行的更多相关文章

  1. Shell脚本中执行mysql的几种方式(转)

    Shell脚本中执行mysql的几种方式(转) 对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用 ...

  2. shell脚本循环执行mysql语句

    参考资料:Shell脚本中执行mysql语句 需求:数据库里有张数据表存储的是用户对电影的评价(user_id movie_id rating time),但是我现在要每部电影的总评分. 解决方法: ...

  3. shell脚本中执行另一个shell脚本

    分类: 可以在一个shell脚本中执行另一个shell脚本(或非可执行文件,主要用于取得一些变量的值),方法是: . 文件名(包括路径) 或 变量=文件名(包括路径) . $变量   注意,圆点后面有 ...

  4. Shell脚本中执行sql语句操作mysql的5种方法【转】

    对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...

  5. shell脚本实现监控shell脚本的执行流程及变量的值

    这篇文章主要介绍了shell脚本实现监控shell脚本的执行流程及变量的值本文使用shell完成对执行过程中条件语句中的变量的变化的监控和整个程序的执行流程的观察功能,需要的朋友可以参考下 很多时候, ...

  6. shell脚本中执行sql的例子

    这个例子演示了如何在shell脚本中执行多个sql来操作数据库表. #! /bin/sh USER_HOME=/home/`whoami` . /etc/profile if [ -f ${USER_ ...

  7. 使用shell脚本定时执行备份mysql数据库

    使用shell脚本定时执行备份mysql数据库 #!/bin/bash ############### common file ################ #本机备份文件存放目录 MYSQLBA ...

  8. shell脚本批量执行命令----必需判断上一步执行结果--没有捷径

    # 注意:shell脚本批量执行命令,不能只写一个函数,然后把所有命令复制进去,之前试过这样是不行的.必须要有一个判断命令执行成功与否的语句 # 简单的命令可以不加结果判断符号,但是遇到解压包.sed ...

  9. 如何解决 shell 脚本重复执行的问题

    在开发过程中,经常会使用shell脚本去完成定时备份的任务,普遍的做法是通过系统的定时任务定时执行备份脚本 设想这样一种场景,本次备份时间到了,自动执行备份脚本,如果备份比较耗时的话,会一直持续到下一 ...

  10. shell脚本中执行source命令不生效的解决办法

    一个shell脚本文件中有一个source命令,使用bash a.sh命令执行后source命令进行验证没有生效. 这是因为在shell脚本中执行source会看到效果,但是shell脚本执行完后再次 ...

随机推荐

  1. istio部署

    Istio的部署介绍 目录 Istio的部署介绍 部署模型 集群模式 单集群 多集群 网络模型 单网络 多网络 控制面模型 身份和信任模型 网格中的信任 网格之间的信任 网格模型 单网格 多网格 租户 ...

  2. 【Maven】maven脚本中的maven.test.skip和skipTests的区别

    命令 两种方式跳过编译 test mvn clean install -DskipTests mvn clean install -Dmaven.test.skip=true -DskipTests, ...

  3. C#操作Excel开发报表系列整理

    C#操作Excel进行报表开发系列共写了八篇,也已经有很久没有新东西了,现在整理一下,方便以后查阅,如果有写新的,会同时更新.需要注意的是因为Office的版本不同,实际的代码可能会有所不同,但是都是 ...

  4. ELK入门及基本使用

    预备知识-Restful 起源 在没有前后端分离概念之前,一个网站的完成总是“all in one”,在这个阶段,页面.数据.渲染全部在服务端完成,这样做的最大的弊端是后期维护,扩展极其痛苦,开发人员 ...

  5. vue父子组件状态同步的最佳方式

    哈喽!大家好!我是木瓜太香,一位老牌儿前端工程师,平时我们在使用 vue 开发的时候,可能会遇到需要父组件与子组件某个状态需要同步的情况,通常这个是因为我们封装组件的时候有一个相同的状态外面要用,里面 ...

  6. HTML模仿实现京东登录页面

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. 解决 Mac 上 Docker 无法直接 ping 通的问题

    解决 Mac 上 Docker 无法直接 ping 通的问题 原文连接 一.背景 Mac os Mojave 10.14.3 Docker Desktop community 2.3.0.4 二.问题 ...

  8. JVM性能调优(1) —— JVM内存模型和类加载运行机制

    一.JVM内存模型 运行一个 Java 应用程序,必须要先安装 JDK 或者 JRE 包.因为 Java 应用在编译后会变成字节码,通过字节码运行在 JVM 中,而 JVM 是 JRE 的核心组成部分 ...

  9. linux系统漏洞扫描工具lynis

    lynis 是一款运行在 Unix/Linux 平台上的基于主机的.开源的安全审计软件.Lynis是针对Unix/Linux的安全检查工具,可以发现潜在的安全威胁.这个工具覆盖可疑文件监测.漏洞.恶意 ...

  10. python中unittest参数化

    先安装 pip install parameterized 在测试用例类中,@parameterized.parameterized.expand(这里面传一个列表),这个就是参数化的意思