首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Shell脚本调用另一个脚本的三种方法

bash #------------------ #@file:first.sh #------------------ echo 'your are in first file' 如何在其它Shell脚本调用...使用sh命令来调用另外的脚本和前面两种方法有着本质的区别。使用sh命令则会开启新的Shell进程来执行指定的脚本,这样的话,父进程中的变量在子进程中就无法访问。.../bin/bash echo 'your are in first file' echo 'second:' $second second.sh内容,通过上面介绍的三种方法来调用first.sh,看看对...(3)全局变量:在脚本中定义,仅在当前Shell脚本中有效,其他Shell脚本进程不能访本,其作用域定义的位置开始,到脚本结束或被显示删除的地方为止。...注意,全局变量既可以在Shell函数内定义,也可以在shell函数外定义,因为shell函数内定义的变量默认为global,且作用域“函数被调用时执行变量定义的地方”开始,到脚本结束或被显示删除的地方为止

11.9K50
您找到你想要的搜索结果了吗?
是的
没有找到

在 Shell 脚本调用另一个 Shell 脚本的三种方式

exec exec 与 fork 不同,不需要新开一个子 Shell 来执行被调用脚本. 被调用脚本与父脚本在同一个 Shell 内执行。...所以被调用脚本中声明的变量和环境变量, 都可以在主脚本中进行获取和使用。 其实从命名上可以感知到其中的细微区别,下面通过两个脚本来体会三种调用方式的不同: 第一个脚本,我们命名为 1.sh: #!...fork fork 方式可以看出,两个脚本都执行了,运行顺序为1-2-1,两者的PID值(1.sh PID=82266, 2.sh PID=82267),可以看出,两个脚本是分成两个进程运行的。...pid值看,两者是在同一进程 PID=82287 中运行的。 source ? source source方式的结果是两者在同一进程里运行。该方式相当于把两个脚本先合并再运行。...参考: 在shell脚本调用另一个脚本的三种不同方法(fork, exec, source)

4.3K20

【Groovy】Groovy 脚本调用 ( Groovy 类中调用 Groovy 脚本 | 创建 GroovyShell 对象并执行 Groovy 脚本 | 完整代码示例 )

文章目录 一、Groovy 类中调用 Groovy 脚本 1、创建 GroovyShell 对象并执行 Groovy 脚本 2、代码示例 二、完整代码示例 1、调用者 Groovy 脚本的类 2、被调用者...Groovy 脚本 3、执行结果 一、Groovy 类中调用 Groovy 脚本 ---- 1、创建 GroovyShell 对象并执行 Groovy 脚本 首先 , 创建 GroovyShell 对象..., 在构造函数中 , 需要传入 Binding 对象 ; def shell = new GroovyShell(getClass().getClassLoader(), binding) 然后 ,...设置要调用的 Groovy 脚本对应的 File 文件对象 ; def file = new File("Script.groovy") 最后 , 调用 GroovyShell 对象的 evaluate...File("Script.groovy") shell.evaluate(file) } } new Test().startScript() 二、完整代码示例 ---- 1、调用

1.3K10

【Groovy】Groovy 脚本调用 ( Java 类中调用 Groovy 脚本 )

文章目录 前言 一、Groovy 类中调用 Groovy 脚本 1、参考 Script#evaluate 方法分析 Groovy 类中调用 Groovy 脚本 2、创建 Binding 对象并设置 args...参数 3、创建 GroovyShell 对象并执行 Groovy 脚本 4、代码示例 二、完整代码示例 1、调用者 Groovy 脚本的类 2、被调用者 Groovy 脚本 3、执行结果 前言 Java...对象并设置 args 参数 , 创建 GroovyShell 对象并执行 Groovy 脚本 , 就可以在 Java 类中启动 Groovy 脚本 ; 一、Groovy 类中调用 Groovy 脚本...在类方法中调用 Groovy 脚本 ; 在 evaluate 方法中 , 首先创建 GroovyShell 实例对象 , 然后执行该实例对象的 evaluate 方法 , 传入要调用的 Groovy...然后 , 设置要调用的 Groovy 脚本对应的 File 文件对象 ; File file = new File("src/main/groovy/Script.groovy"); 最后 , 调用 GroovyShell

1.6K30

【Groovy】Groovy 脚本调用 ( Groovy 类中调用 Groovy 脚本 | 参考 Script#evaluate 方法 | 创建 Binding 对象并设置 args 参数 )

文章目录 一、Groovy 类中调用 Groovy 脚本 1、参考 Script#evaluate 方法分析 Groovy 类中调用 Groovy 脚本 2、创建 Binding 对象并设置 args...参数 一、Groovy 类中调用 Groovy 脚本 ---- 1、参考 Script#evaluate 方法分析 Groovy 类中调用 Groovy 脚本 可以参考 groovy.lang.Script...类的 evaluate 方法 , 通过 GroovyShell 在类方法中调用 Groovy 脚本 ; 在 evaluate 方法中 , 首先创建 GroovyShell 实例对象 , 然后执行该实例对象的...evaluate 方法 , 传入要调用的 Groovy 脚本对应的 File 对象 ; public abstract class Script extends GroovyObjectSupport...GroovyShell 构造函数 ; 在 Binding 对象中的 Map variables 成员中 , 设置 args 参数 , 作为调用 Groovy 脚本的执行参数 ; 首先 , 要在 Groovy

1.8K70

【Groovy】Groovy 脚本调用 ( Groovy 脚本调用另外一个 Groovy 脚本 | 调用 evaluate 方法执行 Groovy 脚本 | 参数传递 )

文章目录 一、Groovy 脚本调用另外一个 Groovy 脚本 1、调用 evaluate 方法执行 Groovy 脚本 2、参数传递 二、完整代码示例 1、调用者 Groovy 脚本 2、被调用者...Groovy 脚本 3、执行结果 一、Groovy 脚本调用另外一个 Groovy 脚本 ---- 1、调用 evaluate 方法执行 Groovy 脚本 在 【Groovy】Groovy 脚本调用...( Groovy 脚本编译 | Groovy 脚本字节码文件分析 ) 博客中 , 已经分析了 Groovy 脚本的本质 , Groovy 脚本继承了 groovy.lang.Script 类 ; 调用...groovy.lang.Script 类的 evaluate 方法 , 传入 Groovy 脚本文件对应的 File 对象 , 即可执行该 Groovy 脚本 ; /** * 一个助手方法...= "arg1" 这样在被调用的 Groovy 脚本中 , 就可以获取 上述 args 参数 ; 二、完整代码示例 ---- 1、调用者 Groovy 脚本 // 要传入的参数 args = [] args

1.7K40

Spring AOP不拦截对象内部调用的方法原因

System.out.println("模拟执行权限检查"); } } 接下来我就以比喻进行说明了,明白我的比喻的前提你要知道动态代理是什么,打个不恰当的比方吧,就是动态生成一个新的**类**(注意不是对象...在spring的源代码中通过一个增强对象的检查,控制了当前的内部调用是否使用代理来执行,这让人感到无奈。spring的作者们很隐晦的提出避免内部调用的方法。...虽然这是spring官方推荐的避免内部调用的idea。 查看了相关资料,得到了一种方法,即在method1的内部,通过直接获取当前代理对象的方式然后通过代理对象调用method2,这样触发拦截。...看看代码: public void method1(){ logger.error("1"); // 如果希望调用的内部方法也被拦截,那么必须用过上下文获取代理对象执行调用...AopContext来获取当前代理对象,然后调用其方法,这样做还必须的一个步骤是将当前的代理暴露给线程使用,在配置文件中需要配置一个参数:

2.5K10

浅析远程对象调用

而“远程对象调用”,正是在“状态”这个环节上,和RPC不同——它是由框架去保证某种状态的。当我们发起一个远程对象调用的时候,是需要首先“找到”一个远程对象,然后再发起“方法”(成员函数)调用。...因为每一个数据操作,都需要去他们这里读取数据,然后再回写结果(如果有数据修改操作的话)。...由于远程对象本身已经包含了数据,所以对于所需的数据,都是内存中直接读写,这方面的延迟是绝对最快的。...那么只要在远程调用发起的时候,也就是通过lookup()查找远程对象的时候,把请求导向到对象所在进程,那么就能很方便的本地进程对象池中获得对象。...如果对象同时能够支持持久化,那么这种数据搬迁,只需要简单的让对象写入持久化。然后在新的机器上,通过缓存建立的策略,持久化设备读取出对象即可。

1.9K10

浅析“远程对象调用

而“远程对象调用”,正是在“状态”这个环节上,和RPC不同——它是由框架去保证某种状态的。当我们发起一个远程对象调用的时候,是需要首先“找到”一个远程对象,然后再发起“方法”(成员函数)调用。...因为每一个数据操作,都需要去他们这里读取数据,然后再回写结果(如果有数据修改操作的话)。...由于远程对象本身已经包含了数据,所以对于所需的数据,都是内存中直接读写,这方面的延迟是绝对最快的。...那么只要在远程调用发起的时候,也就是通过lookup()查找远程对象的时候,把请求导向到对象所在进程,那么就能很方便的本地进程对象池中获得对象。...如果对象同时能够支持持久化,那么这种数据搬迁,只需要简单的让对象写入持久化。然后在新的机器上,通过缓存建立的策略,持久化设备读取出对象即可。

2.7K00
领券