bash脚本基础

一,概述

shell脚本

程序:指令+数据

程序编程风格:

过程式:以指令为中心,数据服务于指令

对象式:以数据为中心,指令服务于数据

shell程序:提供了编程能力,解释执行

编程逻辑处理方式:

顺序执行 循环执行 选择执行

shell编程:过程式、解释执行

编程语言的基本结构:

数据存储:变量、数组

表达式: a + b

语句:if

shell脚本是包含一些命令或声明,并符合一定格式的文本文件

格式要求:首行shebang机制

#!/bin/bash

#!/usr/bin/python

#!/usr/bin/perl

shell脚本的用途有:

自动化常用命令

执行系统管理和故障排除

创建简单的应用程序

处理文本或文件

第一步:使用文本编辑器来创建文本文件

第一行必须包括shell声明序列:#!

#!/bin/bash

添加注释

注释以#开头

第二步:运行脚本

给予执行权限,在命令行上指定脚本的绝对或相对路径

直接运行解释器,将脚本作为解释器程序的参数运行

脚本调试

blob.png

变量

变量:命名的内存空间

数据存储方式:

字符:

数值:整型,浮点型

变量:变量类型

作用:

1、数据存储格式

2、参与的运算

3、表示的数据范围

类型:

字符

数值:整型、浮点型

强类型:定义变量时必须指定类型、参与运算必须符合类型要求;调用未声明变量会产生错误

如java,python

弱类型:无须指定类型,默认均为字符型;参与运算会自动进行隐式类型转换;变量无须事先定义可直接调用

如:bash 不支持浮点数

变量命名法则:

1、不能使程序中的保留字:例如if, for;

2、只能使用数字、字母及下划线,且不能以数字开头

3、见名知义

4、统一命名规则:驼峰命名法(小驼峰为后一个单词开头的字母大写,大驼峰为所有单词开头的第一个字母大写)

根据变量的生效范围等标准:

本地变量:生效范围为当前shell进程;对当前shell之外的其它shell进程,包括当前shell的子shell进程均无效

变量赋值:name=‘value’,

可以使用引用value:

(1) 可以是直接字串; name=“root"

(2) 变量引用:name="$USER"

(3) 命令引用:name=`COMMAND`, name=$(COMMAND)

变量引用:${name}, $name

"":弱引用,其中的变量引用会被替换为变量值

'':强引用,其中的变量引用不会被替换为变量值,而保持原字符串

显示已定义的所有变量:set

删除变量:unset name

——————————————————————

环境变量:生效范围为当前shell进程及其子进程

变量声明,赋值

export name=VALUE

declare -x name=VALUE

变量引用:$name,${name}

显示所有环境变量

export

env

printenv

删除: unset name

bash有许多内奸的环境变量:

PATH,SHELL,USER,UID,HISTSIZE,HOME,PWD,OLDPWD,HISTFILE,PS1等等

只读变量:只能声时,但不能修改和删除

readonly name

declare -r name

———————————————

局部变量:生效范围为当前shell进程中某代码片断(通常指函数)

位置变量:$1, $2, …来表示,用于让脚本在脚本代码中调用通过命令行传递给它的参数

特殊变量:$?, $0, $*, $@, $#

$1,$2,….:对应第1,第2等参数,shift [n] 换位置

$0:命令本身

$*:传递给脚本的所有参数,全部参数何为一个字符串

$@:传递给脚本的所有参数,每个参数为独立字符串

$#:传递给脚本的参数的个数

$@ $*只在被双引号包起来的时候才会有差异

算数运算

bash中的算数运算:help let

+,-,*,/,%取模(取余),**(乘方)

实现算数运算:

  1. let var=算术表达式

  2. var=$[算数表达式]

  3. var=$((算数表达式))

  4. var=$(expr arg1 arg2 arg3…)

  5. declare -i var =数值

  6. echo`算术表达式`|bc

  7. 乘法符号有些场景中需要转移,如*

    bash有内建的随机数生成器:$RANDOM(1-32767)

    echo $[$RANDOM%50]:0-49之间随机数

增强型赋值

+=,-=,*=,%=

let var OPERvalue

例如:let count+=3

自加3后自赋值

自增,自减:

let var+=1

let var++

let var-=1

let var–

逻辑运算

true,false

1,0

与:

1与1=1

1与0=0

0与1=0

0与0=0

1或1=1

1或0=1

0或1=1

0或0=0

非:!

!1 =0

!0 =1

短路运算:

短路与:

第一个为0,结果必定为0

第一个为1,第二个必须要参与运算

短路或:

第一个为1结果毕竟为1;

第一个为0,第二个必须要参与运算;

异或:^

异或的两个值,相同为假,不同为真

聚集命令:

有两种聚集命令的方法:

复合式: date; who |wc -l

命令会一个接一个的运行

子shell:(date;who |wc -l)>>/tmp/trace

所有的输出都被发送给单个STDOUT和STDERR

退出状态

进程使用退出状态来报告成功或失败

-代表成功,1-255代表失败

$? 变量保存最近的命令退出状态

例如

ping -c1 -Wl hostdown &> /dev/null

echo $?

条件测试

判断某需求是否满足,需要由测试机制来实现.

专用的测试表达式需要由测试命令辅助完成测试过程;

评估布尔声明,以便在条件性执行中

若真,则返回0

若假,则返回1

测试命令

test EXPRESSION

[EXPRESSION]

[[EXPRESSION]]

注意:EXPRESSION前后必须是空白字符

数值测试:

-gt : 是否大于

-ge :是否大于等于

-eq :是否等于

-ne :是否不等于

-lt :是否小于

-le:是否小于等于

字符串测试:

==: 是否等于

>: ascii码石头大于ascii码

<:是否小于

!=是否不等于

=~:左侧字符串是否能够被右侧的PATTER所匹配

注意:此表达式一般用于[[]]中;

-z "STRING":字符串是否为空,空为真,不空为假

-n "STRING":字符串是否不空,不空为真,空为假

注意:用于字符串比较时的用到的操作数都应该使用引号

文件测试

存在性测试

-a FILE: 同-e

-e FILE: 文件存在性测试,存在为真,否则为假

存在性及类别测试

-b FILE:是否存在且为块设备文件

-c FILE:是否存在且为字符设备文件

-d FILE:是否存在且为目录文件

-f FILE:是否存在且为普通文件

-h FILE或-L FILE:是否存在且为符号链接文件;

-p FILE:是否存在且为命名管道文件

-S FILE:是否存在且为套接字文件

文件权限测试:

-r FILE:是否存在可读

-w FILE:是否存在可写

-x FILE:是否存在且可执行

文件特殊权限测试:

-g FILE:是否存在且拥有SGID权限

-u FILE:是否存在且拥有SUID权限

-k FILE:是否存在且拥有sticky权限

文件大小测试:

-s FILE:是否存在且非空

文件是否打开:

-t fd: fd表示文件描述符是否已经打开且某终端相关

-N FILE:文件自上一次读取之后是否被修改过

-O FILE:当前有效用户是否为文件属主

-G FILE:当前有效用户是否为文件属组

双目测试:

FILE1 -ef FILE2 :FILE1与FILE2是否指向同一个设备上相同的inode

FILE1 -nt FILE2 :FILE1是否新与FILE2

FILE1 -ot FILE2 :FILE1是否旧与FILE2

组合测试条件

原创文章,作者:Kartik,如若转载,请注明出处:http://www.178linux.com/35541

(0)
KartikKartik
上一篇 2016-08-19 08:36
下一篇 2016-08-19 08:36

相关推荐

  • mysql进阶至mysql备份基础及备份工具

    一、mysql备份、恢复基础 备份:存储的数据副本 还原:把副本应用到线上系统,仅能恢复至备份操作时刻的数据状态。 硬件上的冗余并不能有效恢复逻辑操作上的错误。 备份:数据备份、服务配置文件备份、系统环境备份。程序的运行依赖于一定的系统环境,仅提供数据本身并不能确保恢复数据之后系统可用,数据备份的目的在于确保系统出现不可预料的灾难事故之后能够快速恢复运行,降…

    2016-11-18
  • 网络N22期-第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who | cut -d" " -f1 | uniq root 2、取出最后登录到当前系统的用户的相关信息。 [roo…

    Linux干货 2016-08-29
  • 使用fail2ban防止暴力破解ssh及vsftpd密码

    此文介绍一个linux下通过监控日志防止密码被暴力破解的软件-fail2ban。fail2ban支持常用的服务,如sshd, apache, qmail, proftpd, sasl, asterisk等的密码验证保护,当发现暴力破解的迹像时,可以通过iptables, tcp-wrapper, shorewall等方式阻止此IP的访问。 python安装 …

    Linux干货 2015-03-04
  • mysql 备份脚本的编写

        最近在为做一些边边角角的工作,现在有一个需求要每天把mysql的数据库dump出来到备份机器上面去. 看似简单的任务也潜在了很多的需求,整理如下:     自动运行-crontab      脚本的环境变量设置-由于通过crontab 启动执…

    Linux干货 2015-12-15
  • N25 the second week

    1.文件管理命令 1.1.cat concatenate files and print on the standard output # 正序打印文件 cat [OPTION]… [FILE]… # 常用参数 -n 编号显示每行 -E 显示每行的结束符 1.2.tac concatenat…

    Linux干货 2016-12-19