当前位置:网站首页 > 网络安全培训 > 正文

shell编程15例(一)

freebuffreebuf 2022-03-23 273 0

本文来源:

1、编写hello world脚本

#!/bin/bash  # 编写hello world脚本   echo "Hello World!" 

2、通过位置变量创建 Linux 系统账户及密码

#!/bin/bash  # 通过位置变量创建 Linux 系统账户及密码   #$1 是执行脚本的第一个参数,$2 是执行脚本的第二个参数 useradd    "$1"  echo "$2"  |  passwd  ‐‐stdin  "$1" 

3、备份日志

#!/bin/bash # 每周 5 使用 tar 命令备份/var/log 下的所有日志文件 # vim  /root/logbak.sh # 编写备份脚本,备份后的文件名包含日期标签,防止后面的备份将前面的备份数据覆盖 # 注意 date 命令需要使用反引号括起来,反引号在键盘<tab>键上面 tar  -czf  log-`date +%Y%m%d`.tar.gz  /var/log    # crontab ‐e  #编写计划任务,执行备份脚本 00  03  *  *  5  /root/logbak.sh 

4、一键部署 LNMP(RPM 包版本)

#!/bin/bash # 一键部署 LNMP(RPM 包版本) # 使用 yum 安装部署 LNMP,需要提前配置好 yum 源,否则该脚本会失败 # 本脚本使用于 centos7.2 或 RHEL7.2 yum ‐y install httpd yum ‐y install mariadb mariadb‐devel mariadb‐server yum ‐y install php  php‐mysql   systemctl start httpd mariadb systemctl enable httpd mariadb 

5、监控内存和磁盘容量,小于给定值时报警

#!/bin/bash  # 实时监控本机内存和硬盘剩余空间,剩余内存小于500M、根分区剩余空间小于1000M时,发送报警邮件给root管理员   # 提取根分区剩余空间 disk_size=$(df / | awk '/\//{print $4}')   # 提取内存剩余空间 mem_size=$(free | awk '/Mem/{print $4}') while : do # 注意内存和磁盘提取的空间大小都是以 Kb 为单位 if  [  $disk_size -le 512000 -a $mem_size -le 1024000  ] then     mail  ‐s  "Warning"  root  <<EOF   Insufficient resources,资源不足 EOF fi done  

6、猜数字游戏

#!/bin/bash  # 脚本生成一个 100 以内的随机数,提示用户猜数字,根据用户的输入,提示用户猜对了, # 猜小了或猜大了,直至用户猜对脚本结束。   # RANDOM 为系统自带的系统变量,值为 0‐32767的随机数 # 使用取余算法将随机数变为 1‐100 的随机数 num=$[RANDOM%100+1] echo "$num"   # 使用 read 提示用户猜数字 # 使用 if 判断用户猜数字的大小关系:‐eq(等于),‐ne(不等于),‐gt(大于),‐ge(大于等于), # ‐lt(小于),‐le(小于等于) while  : do   read -p "计算机生成了一个 1‐100 的随机数,你猜: " cai     if [ $cai -eq $num ]     then          echo "恭喜,猜对了"          exit       elif [ $cai -gt $num ]       then              echo "Oops,猜大了"         else              echo "Oops,猜小了"    fi done 

7、检测本机当前用户是否为超级管理员,如果是管理员,则使用 yum 安装 vsftpd,如果不是,则提示您非管理员(使用字串对比版本)

#!/bin/bash  # 检测本机当前用户是否为超级管理员,如果是管理员,则使用 yum 安装 vsftpd,如果不 # 是,则提示您非管理员(使用字串对比版本)  if [ $USER == "root" ] then   yum ‐y install vsftpd else     echo "您不是管理员,没有权限安装软件" fi 

8、检测本机当前用户是否为超级管理员,如果是管理员,则使用 yum 安装 vsftpd,如果不是,则提示您非管理员(使用 UID 数字对比版本)

#!/bin/bash  # 检测本机当前用户是否为超级管理员,如果是管理员,则使用 yum 安装 vsftpd,如果不 # 是,则提示您非管理员(使用 UID 数字对比版本) if [ $UID -eq 0 ];then     yum ‐y install vsftpd else     echo "您不是管理员,没有权限安装软件" fi  

9、编写脚本:提示用户输入用户名和密码,脚本自动创建相应的账户及配置密码。如果用户不输入账户名,则提示必须输入账户名并退出脚本;如果用户不输入密码,则统一使用默认的 123456 作为默认密码。

#!/bin/bash  # 编写脚本:提示用户输入用户名和密码,脚本自动创建相应的账户及配置密码。如果用户 # 不输入账户名,则提示必须输入账户名并退出脚本;如果用户不输入密码,则统一使用默 # 认的 123456 作为默认密码。   read -p "请输入用户名: " user #使用‐z 可以判断一个变量是否为空,如果为空,提示用户必须输入账户名,并退出脚本,退出码为 2 #没有输入用户名脚本退出后,使用$?查看的返回码为 2 if [ -z $user ];then      echo "您不需输入账户名"    exit 2 fi #使用 stty ‐echo 关闭 shell 的回显功能 #使用 stty  echo 打开 shell 的回显功能 stty -echo read -p "请输入密码: " pass stty echo pass=${pass:‐123456} useradd "$user" echo "$pass" | passwd ‐‐stdin "$user" 

10、输入三个数并进行升序排序

#!/bin/bash  # 依次提示用户输入 3 个整数,脚本根据数字大小依次排序输出 3 个数字 read -p "请输入一个整数:" num1 read -p "请输入一个整数:" num2 read -p "请输入一个整数:" num3 # 不管谁大谁小,最后都打印 echo "$num1,$num2,$num3" # num1 中永远存最小的值,num2 中永远存中间值,num3 永远存最大值 # 如果输入的不是这样的顺序,则改变数的存储顺序,如:可以将 num1 和 num2 的值对调 tmp=0 # 如果 num1 大于 num2,就把 num1 和和 num2 的值对调,确保 num1 变量中存的是最小值 if [ $num1 -gt $num2 ];then      tmp=$num1   num1=$num2   num2=$tmp fi # 如果 num1 大于 num3,就把 num1 和 num3 对调,确保 num1 变量中存的是最小值 if [ $num1 -gt $num3 ];then        tmp=$num1     num1=$num3     num3=$tmp fi # 如果 num2 大于 num3,就把 num2 和 num3 对标,确保 num2 变量中存的是小一点的值 if [ $num2 -gt $num3 ];then     tmp=$num2     num2=$num3     num3=$tmp fi echo "排序后数据(从小到大)为:$num1,$num2,$num3" 

11、石头、剪刀、布游戏

  #!/bin/bash  # 编写脚本,实现人机<石头,剪刀,布>游戏 game=(石头 剪刀 布) num=$[RANDOM%3] computer=${game[$num]} # 通过随机数获取计算机的出拳 # 出拳的可能性保存在一个数组中,game[0],game[1],game[2]分别是 3 中不同的可能   echo "请根据下列提示选择您的出拳手势" echo "1.石头" echo "2.剪刀" echo "3.布"   read -p "请选择 1‐3:" person case  $person  in 1)   if [ $num -eq 0 ]   then     echo "平局"     elif [ $num -eq 1 ]     then       echo "你赢"   else     echo "计算机赢"   fi;; 2)      if [ $num -eq 0 ]   then     echo "计算机赢"     elif [ $num -eq 1 ]     then       echo "平局"   else     echo "你赢"   fi;; 3)   if [ $num -eq 0 ]   then     echo "你赢"     elif [ $num -eq 1 ]     then       echo "计算机赢"   else     echo "平局"   fi;; *)   echo "必须输入 1‐3 的数字" esac 

12、编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机状态(for 版本)

  #!/bin/bash  # 编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机 # 状态(for 版本) for i in {1..254} do   # 每隔0.3秒ping一次,一共ping2次,并以1毫秒为单位设置ping的超时时间      ping ‐c 2 ‐i 0.3 ‐W 1 192.168.4.$i  &>/dev/null     if  [ $? -eq 0 ];then          echo "192.168.4.$i is up"      else          echo  "192.168.4.$i is down"      fi done  

13、编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机状态(while 版本)

 #!/bin/bash  # 编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机 # 状态(while 版本)  i=1 while [ $i -le 254 ] do      ping ‐c 2 ‐i 0.3 ‐W 1 192.168.4.$i  &>/dev/null      if  [ $? -eq 0 ];then          echo "192.168.4.$i is up"     else          echo  "192.168.4.$i is down"      fi      let i++ done 

14、编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机状态(多进程版)

#!/bin/bash  # 编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机 # 状态(多进程版)   #定义一个函数,ping 某一台主机,并检测主机的存活状态 myping(){ ping ‐c 2 ‐i 0.3 ‐W 1 $1  &>/dev/null if  [ $? -eq 0 ];then   echo "$1 is up" else   echo "$1 is down" fi } for i in {1..254} do      myping 192.168.4.$i & done # 使用&符号,将执行的函数放入后台执行 # 这样做的好处是不需要等待ping第一台主机的回应,就可以继续并发ping第二台主机,依次类推。 

15、编写脚本,显示进度条

#!/bin/bash  # 编写脚本,显示进度条 jindu(){ while : do      echo -n '#'      sleep 0.2 done } jindu & cp -a $1 $2 killall $0 echo "拷贝完成" 

转载请注明来自网盾网络安全培训,本文标题:《shell编程15例(一)》

标签:shell函数linux脚本shellshell编程

关于我

欢迎关注微信公众号

关于我们

网络安全培训,黑客培训,渗透培训,ctf,攻防

标签列表