#! /bin/sh
#echo $0 文件名
#echo $1 第一个参数
#echo "$*" 所有参数列表
#echo "$@" 所有参数列表
#myname="lisalian" 定义变量
#echo $myname 输出变量
#echo ${myname} 输出变量
# ------------------上面是基本的用法-------------------------------
PROJECT_PATH="/data/web/"
is_work=1
# 判断是否有两个参数: 项目名:启动端口
if [ $# != "2" ]
then
echo "usage: $0 "
is_work=0
fi
# 定义一个函数
run_temp_server(){
project_name=$1 # 传到函数的第一个参数 $0依然是文件名
runport=$2 # 第二个参数 端口
project_dir="$PROJECT_PATH$project_name/" # 拼接字符串
# 检查项目文件夹是否存在
if [ ! -d $project_dir ]
then
echo "no such file or directory: $project_dir"
# 存在则执行下面命令
else
# 像在终端一样使用这些shell 命令
deactiavte
source `which virtualenvwrapper.sh`
cd $project_dir
workon $project_name
python manage.py runserver 0.0.0.0:$runport
fi
}
if [ $is_work -eq "1" ]
then
# 执行函数 并且传入参数
run_temp_server $1 $2
fi
执行命令
[~/shell]$ . ./runserver.sh owan_web 9006
这里可以看到执行的方式 . ./runserver 而不是直接./runserver
原因是:
shell 运行的这个runserver脚本是一个子shell , 子shell 有它自己的变量, 在子shell里面是cd 成功了, 但是随着子shell 结束, 就回到了父shell。
Linux Source命令及脚本的执行方式解析
执行脚本一般用sh来执行该脚本或者./脚本名。
但有时候我们并不想修改文件权限,可能我们也没有那个权限,所以我们可以使用.(点号)+文件名来临时执行一个脚本而无须修改权限。
source(或点)命令通常用于重新执行刚修改的初始化文档,如 .bash_profile 和 .profile 等等。例如,假如在登录后,对.bash_profile中的 EDITER 和 TERM 变量做了修改,则能够用source命令重新执行.bash_profile中的命令而不用注销并重新登录。
source命令的作用就是用来执行一个脚本,
那么:source a.sh 同直接执行 ./a.sh 有什么不同呢:
1.当shell脚本具有可执行权限时,用sh filename与./filename执行脚本是没有区别得。./filename是因为当前目录没有在PATH中,所有"."是用来表示当前目录的。
2.sh filename 重新建立一个子shell,在子shell中执行脚本里面的语句,该子shell继承父shell的环境变量,但子shell新建的、改变的变量不会被带回父shell,除非使用export。
3.source filename:这个命令其实只是简单地读取脚本里面的语句依次在当前shell里面执行,没有建立新的子shell。那么脚本里面所有新建、改变变量的语句都会保存在当前shell里面。
总结就是: source 脚本是不会创建子shell , 直接在当前的shell执行脚本, 而且不需要脚本有x可执行权限。
export 作用 和 source的作用比较
export 是将变量换成环境变量的用法
source 是把脚本放在当前shell执行
如果a.sh 里面是定义了
WEB_PATH='/data/web'
如果我们执行source ./a.sh 那么会在当前环境生成一个变量WEB_PATH 我们echo $WEB_PATH也是可以获取的。
但是这个$WEB_PATH变量不是环境变量,只是普通变量。
环境变量的作用是什么?
环境变量是当父shell创建子shell的时候,会完整复制一份给子shell的变量。所以当我们执行脚本的时候,这个脚本默认会获取父shell所有环境变量(export得到的变量)
我们修改以下a.sh
WEB_PATH='/data/web'
export WEB
执行
./a.sh
这样执行不能echo 的时候不会有任何内容,因为这个子shell 的变量已经销毁了。哪怕它用export。
要这样执行
source a.sh
才能让它变成真正的环境变量
出的结论是:
1、执行脚本时是在一个子shell环境运行的,脚本执行完后该子shell自动退出;
2、一个shell中的系统环境变量才会被复制到子 shell中(用export定义的变量);
3、一个shell中的系统环境变量只对该shell或者它的子shell有效,该shell结束时变量消失 (并不能返回到父shell中)。
4、不用export定义的变量只对该shell有效,对子shell也是无效的。
Linux 环境变量设置
写完脚本后把脚本的路径加入$PATH 可以全局使用这个命令
vim ~/.zshrc
# 在这里面加入下面这句,就能把当前脚本目录加入$PATH
export PATH=/home/lidongwei/shell/:$PATH
这里就说明一些Linux下设置环境变量有三种方法:
一种用于当前终端
一种用于当前用户
一种用于所有用户
一:用于当前终端:
在当前终端中输入:export PATH=$PATH:
不过上面的方法只适用于当前终端,一旦当前终端关闭或在另一个终端中,则无效。
export NDK_ROOT=/home/jiang/soft/Android-ndk-r8e #只能在当前终端使用。
二:用于当前用户:
在用户主目录下有一个 .bashrc 隐藏文件,可以在此文件中加入 PATH 的设置如下:
$ vim ~/.bashrc 我用on-my-zsh 所以是用 vim ~/.zshrc
加入:
export PATH=:$PATH
如果要加入多个路径,只要:
export PATH=:: ...... :$PATH
当中每个路径要以冒号分隔。
这样每次登录都会生效
添加PYTHONPATH的方法也是这样,在.bashrc中添加
export PYTHONPATH=/home/zhao/setup/caffe-master/python:/home/zhao/setup/mypy:$PYTHONPATH
保存后在终端输入 $ source ~/.bashrc 使环境变量立即生效
三:用于所有用户:
$ sudo vim /etc/profile
加入:
export PATH=:$PATH
就可以了。
终端输入:echo $PATH 可以查看环境变量
注意,修改环境变量后,除了第一种方法立即生效外,第二第三种方法要立即生效,可以source ~/.bashrc或者注销再次登录后就可以了!
参考