zoukankan      html  css  js  c++  java
  • 转shell不能执行su 后的脚本

    ##感谢haoxiaoyu

    https://www.cnblogs.com/haoxiaoyu/p/4302663.html

    shell不能执行su 后的脚本

     
    问题:在shell脚本中执行“su – 用户名”后,脚本终止执行,并且切换到su 中指定用户名的交互式界面 
    现象:我在root中执行一个脚本,但是其中的一些命令或脚本必须用oracle用户来执行。,
    复制代码
    [root@HZ-ITF-01 cron.d]# vi /data/itf/app/oracle/sync/test.sh
     #!/bin/bash
    set -x
    su - oracle
    sqlplus /nolog <<EOF
    conn hxy/hxy
    create table test1 as select * from dba_tables;
    exit
    EOF
    复制代码

    在root用户下执行sh /data/itf/app/oracle/sync/test.sh后,停止在oracle用户的交互界面不在往下执行 ,需要手动输入exit才能继续,但是在脚本中加入exit也不好使 

    分析: 
    a、su – 之后就直接切换环境并且等待用户的交互式访问了,不在继续执行脚本中的命令 
    b、su后的bash是一个子shell,脚本里写exit没有用,这些都要等su这个进程结束后才会执行。 
    解决方案: su – 用户 -c 命令 
         或者 
         sudo -u 用户 命令 参考示例: 参考资料: Shell 中切换用户
     
    然后脚本修改成下面的方式
    复制代码
    #!/bin/bash
    #set -x 
    su - oracle -c sqlplus /nolog <<EOF conn hxy/hxy create table test1 as select * from dba_tables; exit EOF
    复制代码

     脚本顺利执行

    或者改成:
    复制代码
    #!/bin/bash
    set -x 
    su - oracle <<! sqlplus /nolog <<EOF conn hxy/hxy create table test1 as select * from dba_tables; exit EOF
    !
    复制代码

    也可以顺利执行

     

    shell不能执行su 后的脚本

     
    问题:在shell脚本中执行“su – 用户名”后,脚本终止执行,并且切换到su 中指定用户名的交互式界面 
    现象:我在root中执行一个脚本,但是其中的一些命令或脚本必须用oracle用户来执行。,
    复制代码
    [root@HZ-ITF-01 cron.d]# vi /data/itf/app/oracle/sync/test.sh
     #!/bin/bash
    set -x
    su - oracle
    sqlplus /nolog <<EOF
    conn hxy/hxy
    create table test1 as select * from dba_tables;
    exit
    EOF
    复制代码

    在root用户下执行sh /data/itf/app/oracle/sync/test.sh后,停止在oracle用户的交互界面不在往下执行 ,需要手动输入exit才能继续,但是在脚本中加入exit也不好使 

    分析: 
    a、su – 之后就直接切换环境并且等待用户的交互式访问了,不在继续执行脚本中的命令 
    b、su后的bash是一个子shell,脚本里写exit没有用,这些都要等su这个进程结束后才会执行。 
    解决方案: su – 用户 -c 命令 
         或者 
         sudo -u 用户 命令 参考示例: 参考资料: Shell 中切换用户
     
    然后脚本修改成下面的方式
    复制代码
    #!/bin/bash
    #set -x 
    su - oracle -c sqlplus /nolog <<EOF conn hxy/hxy create table test1 as select * from dba_tables; exit EOF
    复制代码

     脚本顺利执行

    或者改成:
    复制代码
    #!/bin/bash
    set -x 
    su - oracle <<! sqlplus /nolog <<EOF conn hxy/hxy create table test1 as select * from dba_tables; exit EOF
    !
    复制代码

    也可以顺利执行

     
  • 相关阅读:
    1.解决有冲突的分支,切换分支时,文件不在了 2.冲突解决到底???
    Github到了一个工作区里面。嵌套了
    【计蒜课】【数据结构】【栈的复习】
    【计蒜课】【数据结构】【队列的复习】
    【计蒜课】【数据结构】【邻接矩阵使用的复习】
    【计蒜课】【数据结构】【链表的创建、插入、遍历操作的复习】
    【计蒜课】【数据结构】【顺序表查找、删除、遍历操作的复习答案】
    【计蒜课】【数据结构】【顺序表的构造、插入、扩容操作习题】
    实验六
    6.6实验五
  • 原文地址:https://www.cnblogs.com/feiyun8616/p/13153939.html
Copyright © 2011-2022 走看看