如何编写一个shell脚本,初识shell脚本编程

1.背景介绍

一. Shell基础

shell是链接客商和linux内核的一个下令解释程序,
常见shell包涵bash(linux暗许)以及其余

shell脚本其实大家都已很布满了,它的职能重大是简化大家的操作,不必每一遍都输入那么多的通令。事实上,原本写过多个职务三的自发性计划脚本,前几日自己就在职责三活动布置脚本的基本功上开展优化,目标是学以实用,让大家的机动安顿更加的有利。

1. shell概述

  • 新建三个文书
    vi hello.sh

#!/bin/bash
echo 'hello world';

从前的剧本请看这里

2. 脚本试行方式

  • shell脚本实施有二种办法
    • bash hello.sh
    • chmod 755 hello.sh; ./hello.sh

2.知识分析

3. 小名设置

  1. 临时小名

    • alias vi=vim
    • alias mell=’ls -l –color=auto’
    • 移除一时小名 unalias vi
  2. 长久外号, 修改配置文件

    • vi ~/.bashrc
    • source ~/.bashrc

原先的本子写得很死 只能从一定的地点下载,实际上作者愿意
能够自行内定地点下载。

4. 历史命令 history

配置文件 cat ~/.bash_history

那就必要交互式脚本的使用,大家须求剧本与使用者举办交互。

5. 输入输出

linux标准输入是键盘, 规范输出设备是显示屏

  • /dev/stderr 2 规范错误输出
  • /dev/stdin 0 标准输入
  • /dev/stdout 1 标准输出

老是都急需输入那些太多了,作者想少输入一些,我要制止输入重复的剧情,

5.1. 输出重定向
  1. 覆盖式重定向 ls > 1.log
  2. 充实重定向 ls >> 2.log
  3. 专门的工作错误输出 2>>和2>

ls xdy 2>>1.log
ls xdy &>>2.log 执行正确和错误都输出
ls &>>2.log
ls xdy >> 1.log 2>>2.log

关联到了变量和情状变量 以及变量的相互利用。

5.2. 输入重定向

<< wc << abc

命令好繁琐 ,如何让他更简约,使用外号。

6. 管道符

  1. ; 表示顺序实行
    ls; cd /tmp; touch a;
  2. && 逻辑与
  3. || 逻辑或

ls && echo 'yes' || echo 'no'
abc && echo 'yes' || echo 'no'
  1. | 管道
    netstat -an | grep 22 | wc -l;

3.大范围难题

7. 通配符

  1. ? 三个字符
    • 八个字符
  2. [] 范围

aa=`ls`
 1012  echo $ss
 1013  echo $aa
 1014  echo "$aan"

ls=`head hello.sh `
 1019  echo ls
 1020  echo $ls
 1021  echo $ls + "n"
  echo "$lsn"
 1023  echo 'abc'
 1024  bb=$(ls)
 1025  echo $bb
 1026  echo "n$bbn"

3.1.脚本怎样与客商交互

二. 变量

3,.2.变量如何注解 扩展

1. 客户变量

  • 变量法则

    • 只可以以字母, 下划线早先, 不能够以数字开首
    • 等号两边不可能冒出空格, 如a = 3, 错误的写法
    • 数据类型暗许都以字符串类型
    • 调用时, 必须使用$符号
  • 变量连接

a=123
b=2
a=$a+$b;(不要出现空格)
echo $a;  # a=123+2
c="$a"456
d=${c}789
# d=123+2456789
  • 翻看全体变量 set

set -u 就算变量未定义, 则提示

[root@localhost xdy]# echo $g

[root@localhost xdy]# set -u
[root@localhost xdy]# echo $g
-bash: g: unbound variable
[root@localhost xdy]# 
  • 去除变量
    unset c 不能加$符号

3.3.别称的应用

2. 情况变量

  • 概念情形变量
    • 一贯定义 : export a=1
    • 先定义, 后检出 : b=2; export b;
    • env查看当前持有的境况变量
    • 除去时, 在哪儿定义, 就在那时候删除
  • PATH
    当我们打linux命令时, 其实暗许会在PATH境遇变量定义的目录下搜寻,
    假设找到则推行, 未有找到就报错, 所以我们能够把路子插手到PATH中

[root@localhost ~]# echo $PATH
[root@localhost ~]# PATH="$PATH":/root/test
[root@localhost ~]# echo $PATH
......:/root/test
[root@localhost ~]# hello.sh 
  • PS1 是概念系统起先符号

[root@localhost ~]# echo $PS1
[u@h W]$
[root@localhost ~]# PS1=' [u@a w]$ '
 [root@ ~]# PS1=' [u@t w]$ '
 [root@14:20:38 ~]# PS1='[u@t w]$ '
[root@14:20:46 ~]# cd /usr/bin/
[root@14:21:19 /usr/bin]# 
  • PS2是概念命令换行符号的, 默以为 >

ls
[root@localhost log]# ls 
> haha
  • 语系 LANG
    • 翻开当前语系 locale
    • 查阅所有语系 locale -a
    • echo $LANG
    • 暗中认可语系配置文件/etc/sysconfig/i18n

[root@localhost log]# cat /etc/sysconfig/i18n 
LANG="zh_CN.UTF-8"
  • 职位参数$n
    • $0 : 命令本身
    • $1和$9是率先个到第七个参数 超越多少个, 使用 ${10}

#!/bin/bash

a=20;
b=30;
c=$(( $a + $b))
echo $c;

d=$1;
e=$2;
echo $(( $d + $e))
# 调用时, 需要在命令后跟上两个参数,, 用于填充$d 和 $e
  • $* : 全部参数, 当成多少个完完全全
  • $@ : 全部参数, 分开管理
  • $# : 参数个数

#!/bin/bash

echo $*;
echo $@;
echo $#;

echo "n"
for i in "$*"
        do
                echo $i
        done

for y in "$@"
        do
                echo $y
        done

4.缓慢解决方案

3. 预约义变量

  • $? 表示上一条命令推行的结果, 0 表示正确实施, 非零代表报错
    && || 都以剖断前一条命令的实行结果S?

  • 示例:

ls && echo 'yes' || echo 'no'  :
    |-- 如果ls正确执行, $?为0, echo 'yes' 判断$? = 0, 输出yes
    |-- 如果ls没有正确执行, $?不为0, echo 'yes' 判断非0, 不执行, echo 'no'判断非0, 执行, 输出no

每一条命令都会返回一个状态值, 来标识自己有没有成功执行, 返回的值, 会被保存到$? 预定义变量中
  • $$ 代表近来的进程号
  • $! 表示最终贰个后台进程经过号

发表评论

电子邮件地址不会被公开。 必填项已用*标注