运维精华-Shell需要牢记几点

目录

Bash特性

输入输出重定向

变量配置文件

声明变量:declare,typeset

       检查系统环境变量的命令:

内置shell命令

内置命令,外置命令

Shell运算符

接受键盘输入

流程控制

循环语句

特殊流程控制语句

正则表达式

字符截取替换命令

sed文档处理工具


 

Shell概念

shell是一个C语言编写的程序,它是用户使用Linux的桥梁。Shell即是一种命令语言,又是一种程序设计语言。

Bash特性

Shell类型:

/bin/sh

/bin/bash

/sbin/nologin

/usr/bin/sh

/usr/bin/bash

/usr/sbin/nologin

引号类型:
      单引号:无视特殊字符

       双引号:识别特殊符号

       无引号:连续的字符可以不加引号

       反引号:引用命令执行结果,等于$()用法

输入输出重定向

       设备名    文件描述符    类型

       /dev/stdin     0     标准输入

       /dev/stdout   1     标准输出

       /dev/stderr    2     标准错误输出

变量类型和加载

变量配置文件

       用户个人配置文件:~/.bash_profile,~/.bashrc远程登录用户特有文件

       全局配置文件:/etc/profile,/etc/bashrc,全局配置文件,影响所有登录系统的用户

声明变量:declare,typeset

declare -i num      #声明整数变量

declare -r readonly      #声明只读变量

declare -a arr=‘([0]=”a” [1]=”b” [2]=”c”)’   #生成数组变量

      

      

       检查系统环境变量的命令:

              set:输出所有变量,包括全局变量,局部变量

              env:只显示全局变量

              declare:输出所有变量

              export:显示和设置环境变量值

       撤销环境变量

              unset 变量名,删除变量或函数

       设置只读变量

              直接readonly显示当前系统只读变量

              readonly name只读变量

       特殊变量

              $0:获取shell脚本文件名,以及脚本路径
              $n:获取shell脚本的第n个参数,n在1~9之间,参数需要空格隔开

              $#:获取执行的shell脚本后面的参数总个数

              $*:获取shell所有参数

              $@:同$*,如果加了双引号,会把所有参数为独立的字符串分开

       特殊状态变量

              $?:上次命名执行状态,0正确,其他为失败

              $$:当前shell的进程号

              $!:上一次后台进程PID

              $_:获取上一次执行的命令的最后一个参数

       特殊shell扩展变量           

${parameter:-word}     #如果parameter变量值为空,返回word字符串
${parameter:=word}     #如果parameter变量为空,则word替代变量值,且返回
${parameter:?word}     #如果parameter变为空,word当作错误输出,否则正常输出
${parameter:+word}     #如果变量为空,什么都不做,否则word返回

 

内置shell命令

echo命令

选项:

       -n:不换行

       -e:解析字符串中的特殊字符

              \n换行

              \回车

              \t制表符

              \b退格

printf命令

       作用:打印与echo相同

       与echo的区别:自动识别特殊字符,不自动添加换行服

eval命令

       作用:执行多个命令

       格式:eval 命令;命令;命令

exec命令

       作用: 不创建子进程,执行后续命令;并执行完毕后,自动exit退出

Shel字串的花括号用法

${变量名}:返回变量值

${#变量名}:返回变量长度,字符长度

截取:

${变量名:start}:返回变量start数值之后的字符,start是数字

${变量名:start:stop}:返回变量从start下标到stop的所有字符

删除:

${变量名#word}:从变量开头删除最短匹配的word字串

${变量名##word}:从变量开头删除最长匹配的word字串

${变量名%word}:从变量结尾删除最短的word字串

${变量名%%word}:从变量结尾删除最长匹配的word字串

替换:

${变量名/pattern/string}:用string代替第一个匹配的pattern字串

${变量名//pattern/string}:用string代替所有的pattern字串

内置命令,外置命令

内置命令:在系统启动时就载入内存,常驻内存,执行效率高,但是占用资源

外置命令:用户需要从硬盘中读取程序文件,再读入内存加载

Shell运算符

1.算数运算符

逻辑概念:真为1  假为0

shell中常见的算数运算命令

(())          用于整数运算的常用运算符,效率高

let          用于整数运算,类似(())

expr        可用于整数运算,但是还有很多其他功能

bc          计算器程序(适合整数及小数运算)

$[ ]         用于整数运算

awk        awk既可以整数运算,和小数运算

declare   定义变量值和属性,-i参数可以用于定义整形变量做运算

特殊符号符号

++:自增

--:自减

2.关系运算符

运算符       说明

-eq    检测两个数是否相等

-ne    检测两个数是否不同

-gt     检测第一个数值是否大于右边数值

-lt      检测第一个数值是否小于右边数值

-ge    检测第一个数值是否大于等于右边的数值

-le     检测第一个数值是否小于等于第二个数值

3.逻辑运算符

运算符       说明

!              非运算,取反

-o              或运算,第一个表达式为true则返回true

-a              与(并且)运算,所有表达式都为true才返回true

4.字符串运算符

运算符                说明

=                        检测两个字符是否相等

!=                    检测两个字符是否不相等

-z                       检测字符串长度是否为0

-n                       检测字符串长度是否不等于0

str                       检测字符串是否为空

5.文件测试运算符

操作符                说明

-b file         检测文件是否是块文件

-c file         检测文件是否是字符设备文件

-d file         检测文件是否是目录

-f file          检测文件是否是普通文件

-p file         检测文件是否是有名管道

-g file         检测文件是否设置了SGID位

-k file         检测文件是否设置了粘着位

-u file         检测文件是否设置了SUID位

-r file          检测文件是否可读

-w file        检测文件是否可写

-x file         检测文件是否可执行

-s file         检测文件是否为空

-e file         检测文件是否存在

接受键盘输入

read [选项] [变量名]

选项:

       -a:后面跟一个变量,该变量会被认为是个数组,然后给其赋值,默认是以空格为分割符。

       -p:提示信息:在等待read输入时,输出提示信息

       -t:秒数:read命令会一直等待用户输入,使用此选项可以指定等待时间

       -n:数字:read命令只接受指定的字符数,就会执行

       -s:隐藏输入的数据,适合机密信息的输入

       -d:后面跟一个标志符,其实只是其后的第一个字符有用,作为结束的标志

       -e:在输入的时候可以使用命令补全功能

变量名:

       变量名可以自定义,如果不指定变量名,会把输入保存默认变量REPLY

       如果只提供了一个变量名,则整个输入行赋予给变量

       如果提供了一个以上的变量,则输入行分为若干字,一个接一个的赋予各个变量,而命令行上的最后一个变量取得剩余的所有字

流程控制

单分支if语法:

       if [ 条件判断式 ]

              then

                     程序

       fi

双分支if条件语句

       if [ 条件判断式 ]

              then

                     条件成立时,执行的程序

              else

                     条件不成立,执行的另一个程序

       fi

多分支if条件语句

       if [ 条件判断式1 ]

              then

                     当条件判断式1成立时,执行程序1

       elif [ 条件判断式2 ]

              then

                     当条件判断式2成立时,执行程序2

       else

                     当所有条件都不成立,最后执行程序

       fi

多分支case条件语句

       case $变量名 in

              “值1”)

              如果变量的值等于值1,则执行程序1

              ;;

              “值2”)

              如果变量的值等于值2,则执行程序2

              ;;

              *)

              如果变量的值都不是以上的值,则执行此程序

              ;;

       esac

循环语句

for语法一:

for 变量 in 值1 值2 值3 (可以是一个文件等)

do

          程序

done

注:这种语法中for循环的次数,取决于in后面值的个数(空格分割),有几个值就循环几次,并且每次循环都把值赋予变量。

for语法二:

for ((初始值;循环控制条件;变量变化))

          do

                  程序

          done

注:语法二注意:

初始值:在循环开始时,需要给某个变量赋予初始值,如i=1

循环控制条件:用于指定变量循环次数,如i<=100,则只要i的值小于等于100,循环就会继续

变量变化:每次循环之后,变量该如何变化,如i=i+1。代表每次循环之后,变量i的值都加1

while循环语法:

while [ 条件判断式 ]

          do

                  程序

          done

until循环语法:

until [ 条件判断式 ]

          do

                  程序

          done

注:和whlie循环相反,until循环时只要条件判断式不成立则进行循环,并执行循环程序,一旦循环条件成立,则终止循环。
 

函数

语法:

function 函数名 () {

          程序

          return 返回值

}

特殊流程控制语句

exit语句:

注:系统中使用exit命令,用于退出当前用户。可是在Shell脚本中,exit语句是用来退出当前脚本

exit [返回值]

返回值:这个脚本执行完之后的返回值就是我们自己定义的返回值。

break语句:

注:当程序执行到break语句时,会结束整个当前循环。

continue语句:

注:continue也是结束流程控制语句,如果在循环中,continue语句只会结束单次当前循环。

字符截取,替换和处理命令

正则表达式

        元字符      描述

        \               转义符,将特殊字符进行转义,忽略其特殊意义

        ^              匹配行首,在awk中^是匹配字符串的开始

        $               匹配行尾,awk中,$则是匹配字符的结尾

        .                匹配换行符之外的任意单个字符

        [ ]              匹配包含在[ ^字符 ]之中的任意一个字符

        [ ^ ]          匹配[ ^字符 ]之外的任意一个字符

        [ - ]           匹配[ - ]中指定范围中的任意一个字符,要写成递归

        ?               匹配之前的项1次或者0次

| 匹配之前的项1次或者多次 | sa-6+匹配sa-6、sa-666,不能匹配sa-

| 匹配之前的项0次或者多次| co*l匹配cl、col、cool、coool等

() | 匹配表达式,创建一个用于匹配的子串 | ma(tri)?匹配max或maxtrix

{n} | 匹配之前的项n次,n是可以为0的正整数 |[0-9]{3}匹配任意一个三位数,可以扩展为[0-9][0-9][0-9]

{n,}| 之前的项至少需要匹配n次 | [0-9]{2,}匹配任意一个两位数或更多位数不支持{n,}{n,}{n,}

{n,m}| 指定之前的项至少匹配n次,最多匹配m次,n<=m | [0-9]{2,5}匹配从两位数到五位数之间的任意一个数字

|| 交替匹配|两边的任意一项 | ab(c|d)匹配abc或abd

字符截取替换命令

cut列提取命令

语法:

-f 列号: 提取第几列

-d 分隔符: 按照指定分隔符分割列

-n 取消分割多字节字符

-c 字符范围: 不依赖分隔符来区分列,而是通过字符范围(行首为0)来进行字段提取。“n-”表示从第n个字符到行尾;“n-m”从第n个字符到第m个字符;“一m”表示从第1个字符到第m个字符。

--complement    补足被选择的字节、字符或字段

--out-delimiter  指定输出内容是的字段分割符

awk编程

awk概述

注:awk是一种处理文本文件的语言,是一个强大的文本分析工具

printf格式化输出语法:

printf ‘输出类型输出格式’ 输出内容

输出类型:

%c:     ASCII字符.显示相对应参数的第一个字符

%-ns:   输出字符串,减号“-”表示左对齐(默认右对齐),n是数字指代输出几个字符,几个参数就写几个%-ns

%-ni:   输出整数,n是数字指代输出几个数字

%f:    输出小数点右边的位数

%m.nf:  输出浮点数,m和n是数字,指代输出的整数位数和小数位数。如%8.2f代表共输出8位数,其中2位是小数,6位是整数。

输出格式:

\a: 输出警告声音

\b: 输出退格键,也就是Backspace键

\f: 清除屏幕

\n: 换行

\r: 回车,也就是Enter键

\t: 水平输出退格键,也就是Tab 键

\v: 垂直输出退格键,也就是Tab 键

awk基本使用语法:

          amk ‘条件1{动作1} 条件{动作2}…’ 文件名

条件:

          一般使用关系表达式作为条件

动作:

          格式化输出

          流程控制语句

常用参数:

          -F:指定输入时用到的字段分割符

          -v:自定义变量

          -f:从脚本中读取awk命令

          -m:对val值设置内的限制

awk的条件

条件           说明

BEGIN        在awk程序一开始时,尚未读取任何数据之前执行。BEGIN后的动作只在程序开始时执行一次

END           在awk程序处理完所有数据,即将结束时执行。END后的动作只在程序结束时执行一次

>                大于

<                小于

>=             大于等于

<=             小于等于

==             等于

!=            不等于

A~B           判断字符串A中是否包含能匹配B表达式的子字符串

A!~B        判断字符串A中是否不包含能匹配B表达式的子字符串

/正则/        如果在“//”中可以写入字符,也可以支持正则表达式

awk内置变量

awk内置变量     作用

$0                      代表目前awk所读入的整行数据。

$n                      代表目前读入行的第n个字段

NF                      当前行拥有的字段(列)总数

NR                      当前awk所处理的行,是总数据的第几行

FS                       用户定义分隔符

ARGC         命令行参数个数

ARGV         命令行参数数组

FNR                    当文件中的当前记录数

OFMT        数值的输出格式(默认%.6g)

OFS                    输出字段的分隔符(默认空格)

ORS                    输出记录分隔符(默认为换行符)

RS                       输入记录分隔符(默认为换行符)

awk函数

awk编程也允许在编程时使用函数

语法:

function    函数名      (参数列表) {

          函数体

}

awk中调用脚本

注:对于小的单行程序来说,将脚本作为命令行自变量传递给awk是非常简单的,而对于多行程序就比较难处理。当程序是多行的时候,使用外部脚本是很适合的。首先在外部文件中写好脚本,然后可以使用awk的-f选项,使其读入脚本并且执行。

语法:-f 脚本文件  文件目录

sed文档处理工具

注:sed主要是用来讲数据进行选取,替换,删除,新增的命令

sed语法:

sed [选项] ‘[动作]’ 文件名

选项:

-n:  一般sed命令会把所有数据都输出到屏幕,如果加入此选择,则只会把经过sed命令处理的行输出到屏幕。

-e:  允许对输入数据应用多条sed命令编辑。

-f 脚本文件名: 从sed脚本中读入sed操作。和awk命令的-f非常类似。

-r:  在sed中支持扩展正则表达式。

-i:  用sed的修改结果直接修改读取数据的文件,而不是由屏幕输出

动作:

num a \: 追加,在当前行后添加一行或多行。添加多行时,除最后一行外,每行末尾需要用“\”代表数据未完结。num表示第几行

c \: 行替换,用c后面的字符串替换原数据行,替换多行时,除最后一行外,每行末尾需用“”代表数据未完结。

num i \: 插入,在当期行前插入一行或多行。插入多行时,除最后一行外,每行末尾需要用“”代表数据未完结。num表示第几行

d ; 删除,删除指定的行。

p : 打印,输出指定的行。

s : 字串替换,用一个字符串替换另外一个字符串。格式为“行范围s/"旧字串/新字串/g”(和vim中的替换格式类似)。

字符处理命令

sort排序命令:

sort [选项] 文件名

选项:

-f: 忽略大小写

-b: 忽略每行前面的空白部分

-n: 以数值型进行排序,默认使用字符串型排序

-r: 反向排序

-u: 删除重复行。就是uniq命令

-t: 指定分隔符,默认是分隔符是制表符

-k n[,m]: ―按照指定的字段范围排序。从第n字段开始,m字段结束(默认到行尾)

uniq取消重复行:

uniq [选项] 文件名

选项:

-i:忽略大小写

wc统计命令:

wc [选项] 文件名

选项:

-l:只统计行数

-w:只统计单词数

-m:只统计字符数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值