Shell脚本切换用户

问题:
服务器维护需要调用多个不同用户的启动脚本.每个启动脚本需要设置不同的环境变量.所以需要使用Export进行环境变量设定
但是调用各个用户的启动脚本之后,在启动脚本中切换用户并不能再次导入用户环境变量.Shell启动脚本启动的用户环境变量就是
启动该shell脚本的用户的环境变量,su - user <<!虽然用的是su - user命令格式,不是su user命令,但是实际因为脚本没有变化
该脚本的环境变量实际是不变的。
start.sh:
#!/usr/bin/ksh
/TNIS/appchk/start/start_advan.sh
/TNIS/appchk/start/start_pkgmap.sh
/TNIS/appchk/start/start_ipcos.sh
/TNIS/appchk/start/start_IF_SP.sh
/TNIS/appchk/start/start_mes.sh
/TNIS/appchk/start/start_tdata.sh
/TNIS/appchk/start/start_tnis.sh

exit 0

start_ipcos.sh:

/usr/bin/su - ipcos <<DONE
########################################################
######################## START #########################
########################################################

#-----------------------------------------------------------

1)com.ipcos_svr.main.Ipcos_Main

#-----------------------------------------------------------
export Log_Home=/Users/ipcos/PROCESS/SVR/log
export Home_Dir=/Users/ipcos/PROCESS/SVR/bin
ps_res=ps -ef |grep com.ipcos_svr.main.Ipcos_Main |grep -v grep
if [ "$ps_res" = "" ]
then
cd $Home_Dir
Today=date +"%Y%m%d%H%M"
Now_Date=date +"%d"
echo " Ipcos_Main Process Not Exist [$Today] " >> $Log_Home/cron_log/IpcosMain$Now_Date.log
nohup java com.ipcos_svr.main.Ipcos_Main & $1>> $Log_Home/cron_log/IpcosMain$Now_Date.log
echo " Ipcos_Main Process Started!!! \n " >> $Log_Home/cron_log/IpcosMain$Now_Date.log
fi

crontab /TNIS/appchk/start/cron_ipcos.dat
exit
DONE

exit 0

解决:
该用su - user -s shell脚本。(在启动脚本调用之前切换用户)
切换用户只执行一条命令的可以用: su - oracle -c command
切换用户执行一个shell文件可以用:su - oracle -s /bin/bash shell.sh

在 Shell 脚本中调用另一个 Shell 脚本的三种方式
先来说一下主要以下有几种方式:

在Linux平台上开发,经常会在console(控制台)上执行另外一个脚本文件,经常用的方法有:./my.sh 或 source my.sh 或 . my.sh;这三种方法有什么不同呢?我们先来了解一下在一个shell脚本中如何调用另外一个shell脚本,其方法有 fork exec source。

1、fork ( /directory/script.sh) :

如果shell中包含执行命令,那么子命令并不影响父级的命令,在子命令执行完后再执行父级命令。子级的环境变量不会影响到父级。

fork是最普通的, 就是直接在脚本里面用/directory/script.sh来调用script.sh这个脚本. 运行的时候开一个sub-shell执行调用的脚本,sub-shell执行的时候,parent-shell还在。

sub-shell执行完毕后返回parent-shell. sub-shell从parent-shell继承环境变量.但是sub-shell中的环境变量不会带回parent-shell

2、exec (exec /directory/script.sh):

执行子级的命令后,不再执行父级命令。

exec与fork不同,不需要新开一个sub-shell来执行被调用的脚本. 被调用的脚本与父脚本在同一个shell内执行。但是使用exec调用一个新脚本以后, 父脚本中exec行之后的内容就不会再执行了。这是exec和source的区别

3、source (source /directory/script.sh):

执行子级命令后继续执行父级命令,同时子级设置的环境变量会影响到父级的环境变量。

与fork的区别是不新开一个sub-shell来执行被调用的脚本,而是在同一个shell中执行. 所以被调用的脚本中声明的变量和环境变量, 都可以在主脚本中得到和使用.

以上三种就是调用shell脚本的不同方法,./my.sh即是fork的方法,source my.sh和. my.sh(点加空格加脚本文件)既是source的方法。

在linux系统上,搭建嵌入式开发平台,在交叉编译代码之前,都需要执行脚本设置环境变量,切记需要使用sourc 或 点的方式执行shell脚本,原因如上。

猜你喜欢

转载自blog.51cto.com/jinfreaks/2545583