shell脚本如判断sqlplus执行成功还是失败_运维面试题|来测测你的shell功底

运维面试题|来测测你的shell功底

4bd8df26515411c55155a6f3df587187.png

偶然间发现的一个问题,拿出来分享下,看看大家的SHELL基本功如何,请说出你的答案。

背景介绍

•jenkins•shell script

jenkins

作为执行入口,因为我们要动态的传参进来,所以用到了Jenkins的插件Active Choices Plugin

Active Choices Plugin[1]

jenkins设置如下
513f9c97304d2b506e6b50fb99e2af7b.png
c03870452299b0741f61cb63df26c3b7.png
Jenkins上执行的代码如下
if [[ $action == "deploy" ]];then   cd /home/www && bash test-exit.shelse   echo "rollback"fiif [[ $action == "restart" ]];then   echo "this is restart"fi

shell script

一段简单的判断数字是否相等的小脚本,脚本内容如下

[zhuima@zhuima ~]# cat test-exit.sh#!/bin/bash#echo "deploy is me"a=2if [[ a -ne 3 ]];then   echo "a is not equal 3"   exit 1fi

那么问题来了,执行结果是成功还是失败?

试问Jenkins的执行结果会是成功还是失败?不要犹豫,请说出你的答案,如果想证实下自己是对的,那么你可以复制下代码,亲自测试下,看看结果是否如预期所想,哈哈,人生啊~

欢迎关注我的公众号“追马Linux”,原创技术文章第一时间推送。

95c29a9070cd0ec062f8d12ae1840ddb.png
引用链接

[1] Active Choices Plugin: https://plugins.jenkins.io/uno-choice/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用sqlplus的`host`命令来执行Linux命令,也可以通过在shell脚本调用sqlplus来实现在数据库执行脚本的功能。以下是两种实现方法: 1. 使用sqlplus的`host`命令执行Linux命令: 首先进入sqlplus,然后输入以下命令执行Linux命令: ``` SQL> host ls -l ``` 这样就可以在sqlplus执行`ls -l`命令,执行结果会直接在终端输出。 2. 在shell脚本调用sqlplus运行脚本: 编写一个shell脚本,在其使用sqlplus执行需要执行脚本,例如: ```shell #!/bin/bash sqlplus -s username/password@database << EOF @/path/to/your/script.sql exit EOF ``` 这样就可以在shell脚本调用sqlplus执行你需要在数据库执行脚本。其`-s`参数表示在静默模式下运行sqlplus,`<< EOF`表示接下来输入的是要执行的sql语句,`@`后面是你要执行脚本的路径,`exit`表示退出sqlplus。 ### 回答2: 可以使用Oracle数据库提供的SQL*Plus工具来执行Linux命令和运行shell脚本。 通过在SQL*Plus使用`!`或`host`命令,可以在Linux命令行执行任何有效的Linux命令。例如,要列出当前目录下的文件,可以执行以下命令: ``` SQL> !ls ``` 要在shell脚本运行Linux命令,可以使用`!`或`host`命令,后跟shell脚本的路径。例如,假设`/home/user/script.sh`是一个shell脚本文件,我们可以在SQL*Plus执行以下命令来运行该脚本: ``` SQL> !/home/user/script.sh ``` 请注意,执行shell脚本时可能需要在脚本的路径前添加`./`,以确保正确执行。例如,如果脚本位于当前目录下,可以执行以下命令: ``` SQL> !./script.sh ``` 需要注意的是,执行Linux命令和运行shell脚本需要您有足够的权限。对于某些敏感的命令和脚本,您可能需要特定的权限才能执行成功。 总结而言,您可以通过在SQL*Plus使用`!`或`host`命令来执行Linux命令,并且可以在SQL*Plus使用这些命令来运行shell脚本。 ### 回答3: 在SQL*Plus执行Linux命令有两种方式:使用“host”命令或者使用“!(感叹号)”命令。 1. 使用“host”命令: 在SQL*Plus输入“host”命令,随后紧跟要执行的Linux命令。 例如: SQL> host ls -l 这将在SQL*Plus执行“ls -l”命令,显示当前目录下的文件列表。 2. 使用“!(感叹号)”命令: 在SQL*Plus输入“!(感叹号)”命令,随后紧跟要执行的Linux命令。 例如: SQL> !uname -a 这将在SQL*Plus执行“uname -a”命令,显示当前操作系统的详细信息。 通过SQL*Plus运行Shell脚本也有两种方法:使用“@”命令或者使用“@@”命令。 1. 使用“@”命令: 在SQL*Plus输入“@”命令,随后紧跟要执行Shell脚本的文件路径。 例如: SQL> @/path/to/script.sh 这将在SQL*Plus执行指定的Shell脚本。 2. 使用“@@”命令: 在SQL*Plus输入“@@”命令,随后紧跟要执行Shell脚本的文件路径。 例如: SQL> @@/path/to/script.sh 这将在SQL*Plus执行指定的Shell脚本。 通过以上两种方式,可以在SQL*Plus方便地执行Linux命令和运行Shell脚本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值