本文介绍了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:"这个字符串