设为首页 收藏本站
查看: 1601|回复: 0

Linux基础shell脚本题

[复制链接]

尚未签到

发表于 2018-8-26 10:25:39 | 显示全部楼层 |阅读模式
  1、编写脚本/root/bin/sumid.sh,计算/etc/passwd文件中的第10个用户和第20用户的ID之和
  解:vim /root/bin/sumid.sh
  #!/bin/bash
  tenuser=`cat /etc/passwd | head -n10 | tail -n1 |cut -d: -f3`
  twentyuser=`cat /etc/passwd | head -n20 |tail -n1 | cut -d: -f3`
  let sum=$[tenuser+twentyuser]
  echo "The tenuser and twentyuser finally is $sum"
  2、编写脚本/root/bin/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和
  解:vim /root/bin/sumspace.sh
  #!/bin/bash
  first=`cat $1 | grep "^[[:space:]]*$" | wc -l`
  second=`cat $2 | grep "^[[:space:]]*$" | wc -l`
  let sum=$[first+second]
  echo $sum
  3、编写脚本/root/bin/sumfile.sh,统计/etc, /var, /usr目录中共有多少个一级子目录和文件
  解:vim /root/bin/sumfile.sh
  #!/bin/bash
  first=`ls -l /etc | egrep "(^d.*)|(^-.*)" | wc -l`
  second=`ls -l /var | egrep "(^d.*)|(^-.*)" | wc -l`
  third=`ls -l /usr | egrep "(^d.*) | (^.*)" | wc -l`
  let sum=$[first+second+third]
  echo $sum
  4、编写脚本/root/bin/argsnum.sh,接受一个文件路径作为参数;如果参数个数小于1,则提示用户“至少应该给一个参数”,并立即退出;如果参数个数不小于1,则显示第一个参数所指向的文件中的空白行数
  解:vim /root/bin/argsnum.sh
  #!/bin/bash
  [ "$#" -lt 1 ] && echo "The must one arg" && exit 20
  [ -e $1 ] || { echo "No such file or directory" && exit 30; }
  [ "$#" -ge 1 ] && echo "The blankspace is `grep "^[[:space:]]*$" $1 | wc -l`"
  5、编写脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如果不可ping通,则提示用户“该IP地址不可访问”
  解:[[ ! $1 =~ (([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]) ]] && echo "please print right ip format!" && exit 20
  `ping $1 -c1 &>/dev/null` && echo "Yes" || echo "No"
  6、编写脚本/root/bin/checkdisk.sh,检查磁盘分区空间和inode使用率,如果超过80%,就发广播警告空间将满
  解:vim /root/bin/checkdisk.sh
  disk=`df -h | grep /dev/sd | tr -s " "  % | cut -d % -f5 | sort -nr | head -n1`
  inode=`df -i | grep /dev/sd | tr -s " " % | cut -d % -f5 | sort -nr | head -n1`
  [ "$disk" -gt 80 ] && echo "The disk is "$disk"% will man" ||  echo The disk>
  [ "$inode" -gt 5 ] && echo The inode is "$inode"% man  || { echo The indoe>
  7、编写脚本/bin/per.sh,判断当前用户对指定的参数文件,是否不可读并且不可写
  解:vim /bin/per.sh
  #!/bin/bash
  [ ! -r "$@" ] && [ ! -w "$@" ] && echo The "$@" is Not have w and r permisson or have some one permisson || echo The "$@" have w and r permission
  #另一种写法
  [ ! \( -r "$@" -a -w "$@" \) ] && echo The "$@" is Not have w and r permisson or have some one permisson || echo The "$@" have w and r permission
  8、编写脚本/root/bin/excute.sh ,判断参数文件是否为sh后缀的普通文件,如果是,添加所有人可执行权限,否则提示用户非脚本文件
  解:vim /root/bin/excute.sh
  [[ "$@" =~ .*\.sh ]] && `chmod a+x "$@" ` || echo The "$@" is not script file
  9、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充许普通用户登录系统
  解:vim /root/bin/nologin.sh
  #!/bin/bash
  touch /etc/nologin
  echo "disabled common user login"
  vim /root/bin/nologin.sh
  #!/bin/bash
  rm -rf /etc/nologin
  禁止普通用户登录时执行第一个脚本,允许登录后执行第二个脚本
  10、编写脚本/root/bin/agree.sh,提示用户输入各种各样的Yes或No都可以,输入错误的话提示"请输入正确选项"
  解:vim /root/bin/agree.sh
  #!/bin/bash
  read -p "Do you agree,Plase print Yes or No: " ANS(#变量名)
  [[ "$ANS" =~ [Yy]|[Yy][Ee][Ss]|[Nn][Oo]|[Nn] ]] || { echo "please input right options" && exit 20;}
  11、让所有用户的PATH环境变量的值多出一个路径,例如:/usr/local/apache/bin
  解:vim /etc/profile
  PATH=$PATH:$HOME/bin:/usr/local/apache/bin
  source /etc/profile
  12、用户root登录时,将命令指示符变成红色,并自动启用如下别名:
  rm=‘rm –i’
  cdnet=‘cd /etc/sysconfig/network-scripts/’
  editnet=‘vim /etc/sysconfig/network-scripts/ifcfg-eth0’
  editnet=‘vim /etc/sysconfig/network-scripts/ifcfg-eno16777736 或 ifcfg-ens33 ’ (如果系统是CentOS7)
  解:vim ~/.bashrc
  rm='rm –i'
  cdnet='cd /etc/sysconfig/network-scripts/'
  editnet='vim /etc/sysconfig/network-scripts/ifcfg-ens33'
  export PS1='\[\e[1;31m\][\u@\h \W]\$\[\e[0m\]'
  source ~/.bashrc
  13、任意用户登录系统时,显示红色字体的警示提醒信息“Hi,dangerous!”
  解:vim /etc/profile.d/danger.sh
  #!/bin/bash
  echo -e "\033[1;5;31mHi,dangerous!\033[0m"
  14、编写生成脚本基本格式的脚本,包括作者,联系方式,版本,时间,描述等
  解:vim /root/bin/createscript.sh
  #!/bin/bash
  touch $1
  chmod +x $1
  echo "#/bin/bash
  #*************************************
  #Filename:                    $1
  #Author:                      Fang
  #Date:                     `date "+%Y-%m-%d %H:%M:%S"`
  #*************************************" > $1
  vim + $1


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-556713-1-1.html 上篇帖子: mysql增量备份二进制日志shell脚本 下篇帖子: Shell使用RANDOM编写1-10以内随机数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表