1、Shell 概述
Shell是一个命令解释器,它接收应用程序/用户命令,然后调用操作系统内核。
说明:Shell是一个功能相当强大的编程语言,易编写,易调试、灵活性强。
1、 提供的Shell解释器
代码: cat /etc/shells
2、bash和sh的关系
让我们尝试再次检查目录,但是这次使用grep专门检查sh文件夹。
代码:ls -l /bin/ | grep sh
单独看bash
3、CentOS默认的解析器是bash
2、Shell 脚本入门
1、脚本格式
脚本以#!/bin/bash开头(指定解析器)
less:翻页查看
查看格式:less /bin/unix-lpr.sh
2、第一个Shell脚本:helloworld.sh。
(1)需求:创建一个Shell脚本,输出helloworld
(2)案例实操
创建一个单独写脚本的目录
脚本内容:
3、脚本的常用执行方式
(1)采用bash或sh+脚本的相对路径或绝对路径(不用赋予脚步+x权限)
sh+脚本的相对路径
相对路径:
绝对路径:
sh是bash的软连接
(2)采用输入脚本的绝对路径或相对路径执行脚本(必须具有可执行权限+x)
首选要赋予helloworld.sh脚本的+x权限
利用相对路径执行脚本
利用绝对路径执行脚本
注意:第一种执行方法本质是bash解析器帮你执行脚本,所以脚本本身不需要执行权限。第二种执行方法,本质是脚步需要自己执行,所有需要可执行权限。
(3)在脚本路径前加上‘.’或者source(个人觉得很重要)
2、分别使用sh、bash、./、和. 的方式执行。结果如下:
1、有以下脚本
(1)sh
(2)bash
(3)./
(4).
ps命令是查看软件进程的命令
很明显这四个命令执行之后echo $A,不难发现前两个是一样的显示不了,只有最后两个命令才能显示出!!!
原因:
前两种方式都是在当前shell中打开一个子shell来执行脚步内容,当脚本内容结束,则子shell关闭,回到父Shell中。
后两种,也就是使用在脚本路径前加‘.’或者source方式,可以使脚本内容在当前shell里执行,而无需打开子shell!这也就是为什么我们每次修改完/etc/profile文件以后,需要source一下的原因。
开子shell和不开子shell的区别就在于环境变量的继承关系,如在子shell中设置的当前变量,父shell1是看不见的。所有利用前两种方式执行脚本变量A在父shell是没有值的!!!
3、变量
3.1 系统预定义变量
1、常用系统变量
HOME 、PWD、SHELL、USER等
2、案例实操
(查看系统变量的值)
显示当前Shell中所有变量:set
set | less
3.2 自定义变量
1、基本语法
(1)定义变量:变量名=变量值(注意:=号前后不能有空格)
(2)撤销变量:unset 变量名
(3)声明静态变量:readonly 变量名 (注意:不能unset)
2、变量定义规则
(1)变量名称可以由字母、数字和下划线组成,但是不能以数字开头,环境变量名建议大写。
(2)等号两侧不能有空格
(3)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算。
(4)变量的值如果有空格,需要使用双引号或单引号括起来。
3、案例实操
(1)定义变量a
(2)给变量a重新赋值
(3)撤销变量a
(4)判断是全局变量还是局部变量
(5)在子shells里面没有所以是局部变量
(6)提升全局变量
(7)在hello.sh添加脚本
在定义一个局部变量,在子shell里面不显示
如果要显示的话
(8)声明只读的变量C=2,不能unset
(9)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算
(10)变量的值如果有空格,需要使用双引号或单引号括起来
3.3 特殊变量
(1)如果把脚本文件放在/bin/目录下,就可以直接执行
3.3.1 $n
1、基本语法
$n (n为数字,$0代表该脚本名称,$1-$9代表第一到第九个参数,十以上的参数需要用大括号包含,如${10});
2、案例实操
$n (n为数字,$0代表该脚本名称,$1-$9代表第一到第九个参数,十以上的参数需要用大括号包含,如${10});
3.3.2 $#
1、基本语法
$# (获取所有输入参数个数,常用于循环,判断参数的个数是否正确以及加强脚本的健壮性)
2、案例实操
3.3.3 $*、$@
1、基本语法
$* (这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
$@ (这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
2、案例实操
3.3.4$?
描述最后一次执行命令的返回值