shell脚本学习笔记2

Shell script(Shell脚本)的工作方式有两种:

①交互式(Interactive):用户每输入一条命令,然后Shell立即执行一次;

②批处理(Batch):由用户实现编写好一个完整的Shell脚本,Shell会一次性执行脚本中诸多的命令。

查看系统可用的shell(/etc/shells文件)


~ # cat /etc/shells
# /etc/shells: valid login shells
/bin/sh
/bin/bash
~ # 

Linux系统默认的命令行终端解释器为Bash
~ # echo $SHELL
/bin/sh
~ #

Shell脚本文件的格式:

  1. 第一行(一般必须写明):指定脚本使用的shell(若不写明也不影响脚本的执行,系统会自动以sh解析脚本)。"#!/bin/bash"声明文件内的语法使用bash的语法,当这个程序被执行时,加载bash的相关环境配置文件(一般是non-login shell中的~/.bashrc文件)。
  2. 第二部分的注释(可写):程序内容的说明。shell脚本中,井号#用作批注(除第一行的"#!"外),shell不会解释以#开头的行(除第一行bash声明外)。
  3. 主要环境变量的声明(可写)
  4. 脚本的程序部分。
  5. 程序执行结束,回传一个数值给系统告知执行的结果(可写。默认命令执行成功返回数值0)。

sh -x:实现shell脚本逐条语句的跟踪

sh -n:不执行脚本,仅进行语法的检查

sh -v:执行脚本前,先将脚本的内容输出到屏幕上

Shell中运行的每个命令都使用退出状态码告诉shell它运行完毕。退出状态码:0-255的整数值,在命令结束运行时由命令传给shell。变量$?用于保存上个已执行命令的退出状态码。退出状态码可配合exit命令使用。

Shell script的的默认变量(接受用户参数的变量)

  • $0:当前Shell脚本程序的名称;
  • $#:参数的个数;
  • $*:所有位置的参数值;
  • $?:上一条命令的执行返回值;
  • $1、$2、$3……:第N个位置的参数值。

示例

1.Linux判断进程是否存在并启动该进程

#!/bin/bash
#判断进程是否存在,如果不存在就启动它
PIDS=`ps -ef |grep myprocess |grep -v grep | awk '{print $1}'`
if [ "$PIDS" != "" ]; then
echo "myprocess is runing!"
else
cd /root/
./myprocess
#运行进程
fi
2.linux判断进程是否存在并重启该进程

#!/bin/bash
#判断进程是否存在,如果不存在就启动它如果存在就重启它
PIDS=`ps -ef |grep myprocess |grep -v grep | awk '{print $1}'`
if [ "$PIDS" != "" ]; then
kill -9 $PIDS
#先关闭进程,在运行此进程
cd /root/myprocess
sudo ./myprocess
#重新运行进程
else
cd /root/myprocess
sudo ./myprocess
#运行进程
fi
最后编辑crontab -e 按需要设置运行时间。

原创文章 96 获赞 48 访问量 6万+

猜你喜欢

转载自blog.csdn.net/wteruiycbqqvwt/article/details/100077232
今日推荐