1.shell脚本
当命令或程序语句不在命令行下执行,而是通过一个程序文件来执行,该程序文件即脚本。
2.Shell 脚本运行
方法一:切换到 shell 脚本所在的目录(此时,称为工作目录)执行 shell 脚本
方法二:以绝对路径的方式去执行 bash shell 脚本:
方法三:直接使用 bash 或 sh 来执行 bash shell 脚本:
方法四:在当前的 shell 环境中执行 bash shell 脚本:source 或.
区别:
1、方法三:可以在脚本中不指定解释器,脚本可以没有执行权限
2、方法一和方法二脚本需要有执行权限,./script_name.sh 或
/path/script_name.sh
3、方法四:当前 shell 执行,方法 1-3 开启子 shell
3.shell 脚本规范
(1)开头指定脚本解释器#!/bin/sh 或#!/bin/bash,其他行#表示注释,名称见名知义 backup_mysql.sh,以 sh 结尾
(2)开头加版本版权等信息
#Date:创建日期
#Author:作者
#Mail:联系方式
#Function:功能
#Version:版本
(3)脚本中尽量不用中文注释
尽量用英文注释,防止本机或切换系统环境后中文乱码的困扰;单行注释,可以放在代码行的尾部或代码行的上部;多行注释,用于注解复杂的功能说明,可以放在程序体中,也可以放在代码块的开始部分代码修改时,对修改的内容
(4)多使用内部命令
(5)没有必要使用 cat 命令
eg:cat /etc/passwd | grep guru
使用以下方式即可
eg:grep guru etc/passwd
(6)代码缩进
(7)仔细阅读出错信息
(8)脚本以.sh 为扩展名
eg:script-name.sh
4.命令排序
; 不具备逻辑判断,&=and,&& || 具备逻辑判断
注:command & 后台执行
command &>/dev/null 混合重定向(标准输出 1,错误输出 2)
command1 && command2 命令排序,逻辑判断
5. shell 通配符(元字符)表示的不是本意
匹配任意多个字符 ls in* rm -rf * rm -rf .pdf find / -iname "-eth0"
? 匹配任意一个字符 touch love loove live l7ve; ll l?ve
[] 匹配括号中任意一个字符 [abc] [a-z] [0-9] [a-zA-Z0-9] [^a-zAZ0-9]
ll l[io]ve ll l[^a-z]ve
() 在子 shell 中执行(cd /boot;ls) (umask 077; touch file1000)
{}集合 touch file{1…9}
\ 转义符,让元字符回归本意
shell变量
1.自定义变量
例1:touch test.sh
vi test.sh
chmod u+x test.sh
./test.sh
例2 touch ping.sh
vi ping.sh
chmod u+x ping.sh
./ping.sh 192.16.16.130
2.变量赋值
定义或引用变量时注意事项:
" " 弱引用
’ ’ 强引用
命令替换 等价于 $() 反引号中的 shell 命令会被先执行
例:touch b.sh
vi b.sh
给变量$1 $2 $3 赋值为1 2 3
3.变量运算
1)整数运算
方法一:expr
expr $num1 + $ num2 + - * / %
方法二:$(()) 优先级
echo
(
(
((
((num1+$num2)) + - * / %
方法三:$[] 表示幂
echo $[5+2] + - * / %
echo $[52]
方法四:let
let sum=2+3; echo $sum
let i++; echo $i
方法五:内置命令 declare
declare –i 变量=算术式 declare –i r=2+3
shell练习题
#1.显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小,保存脚本为sys_info.sh
1)touch sys_info.sh
2)vi sys_info.sh
3)chmod u+x sys_info.sh
4)./ sys_info.sh
#2.将/etc/目录备份到/tmp下,并以此格式保存bak_etc_yyyy-mm-dd,保存为脚本bak_etc.sh
1)touch bak_etc.sh
2)vi bak_etc.sh
3)chmod u+x bak_etc.sh
4) ./ bak_etfc.sh
#3.显示当前硬盘分区中空间利用率最大的值,保存脚本为disk_used.sh
1)touch disk_used.sh
2)vi disk_used.sh
3)chmod u+x disk_used.sh
4)./ disk_used.sh
#4.显示正连接本主机的每个远程主机的IPv4地址和连接数,并按连接数从大到小排序,保存脚本为link.sh
#5.计算/etc/passwd文件中的第5个用户和第15用户的ID之和,保存脚本sum_id.sh
1)touch sum_id.sh
2)vi sum_id.sh
3)chmod u+x sum_id.sh
4)./sum_id.sh
#6.统计/etc, /var, /usr目录中共有多少文件,保存脚本为sum.sh
1)touch sum.sh
2)vi sum.sh
3)chmod u+x sum.sh
4)./sum.sh
#7.接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则输出“该IP地址可访问”;如果不可ping通,则输出“该IP地址不可访问”,保存脚本为ping.sh
1)vi ping.sh
2) chmod u +x ping.sh
3) ./ping.sh 192.168.50.133