本文介绍了shell脚本的基本建立过程,并举了4个案例。关键是例3的shell脚本检测局域网ip地址机器是否宕机,例4的shell脚本获取本机ip地址
一、第一个shell脚本
1、定义解释器
#!/bin/bash echo "hello world"
#! 是一个约定的标记,它告诉系统这个脚本需要什么解释器来执行,即使用哪一种 shell,类似C语言中的#include
echo 命令用于向窗口输出文本
2、建立文件并赋予可执行权限
创建文件通过touch first.h
,而后执行vim first.sh
进行内容编辑。
注意刚创建的文件只有可读可写权限,不可执行
输入命令chmod +x first.sh
chmod :改变文件的权限, SUID, SGID, SBIT等等的特性。因此这段代码是向first.sh加入可执行的权限
3、变量操作
1、定义变量
使用一个定义过的变量,只要在变量名前面加美元符号即可;并且变量名与等号之间不能有空格
echo "hello world" x="www.0voice.com" echo $x #或者echo ${domain}
2、删除变量
#!/bin/bash url="www.0voice.com" unset url echo $url
二、例子
1、输出路径下的所有目录
先看一下for 循环一般格式为:
for var in item1 item2 ... itemN do command1 command2 ... commandN done # 可以写成一行 for var in item1 item2 ... itemN; do command1; command2… done;
A、输出路径下的所有目录的命令
#!/bin/bash for file in $(ls /home/zxm/share/00_shell); do echo "${file}" done
B、输出1 2 3 4 5的命令
#!/bin/bash for loop in 1 2 3 4 5 do echo "The value is: $loop" done
2、实现从1到100的和
!#/bin/bash sum=0; for i in {1..100};do let sum+=i done echo $sum
3、shell脚本实现检测局域网内哪些ip地址机器宕机
#!/bin/bash for i in {1..254};do # "&>/dev/null"表示不再屏幕上显示其他结果 ping -c 2 -i 0.5 192.168.48.$i &>/dev/null # "$?"用于获取上一条命令的执行结果,如成功返回0 if [ $? -eq 0 ]; then echo "192.168.48.$i is up" else echo "192.168.48.$i is down" fi done
4、shell脚本中获取本机ip地址
#!/bin/bash local_ip=`ifconfig -a|grep inet|grep -v 127.0.0.1|grep -v inet6|awk '{print $2}'|tr -d "addr:"` echo "${local_ip}"
- ifconfig -a \quad\quad //和window下执行此命令一样道理,返回本机所有ip信息
- grep inet \quad\quad //截取包含ip的行
- grep -v 127.0.0.1 \quad\quad //去掉本地指向的那行
- grep -v inet6 \quad\quad //去掉包含inet6的行
- awk { print $2} \quad\quad //$2 表示默认以空格分割的第二组,同理$1表示第一组
- tr -d “addr:” \quad\quad //删除"addr:"这个字符串