8.1  先测试“/etc/vsftpd”、“/etc/hosts”是否为目录,并通过“$?”变量查看返回状态值,据此判断测试结果。
[root@localhost ~]# [ -d /etc/vsftpd ]
[root@localhost ~]# echo $?
0
[root@localhost ~]# [ -d /etc/hosts ]
[root@localhost ~]# echo $?
1
[root@localhost ~]# ls -ld /etc/vsftpd /etc/hosts
-rw-r--r-- 2 root root  187 10-17 13:53 /etc/hosts
drwxr-xr-x 2 root root 4096 10-18 13:31 /etc/vsftpd
8.2  测试“/media/cdrom/Server”及其父目录是否存在,如果存在则显示“YES”,否则不输出任何信息。
[root@localhost ~]# [ -e /media/cdrom/Server ] && echo "YES"
                                              //无输出表示该目录不存在
[root@localhost ~]# [ -e /media/cdrom ] && echo "YES"
YES                                           //显示YES表示该目录存在
8.3  使用普通用户teacher登录,并测试是否对“/etc/passwd”文件有读、写权限,如果是则显示“YES”。
[teacher@localhost ~]$ [ -w /etc/passwd ] && echo "YES"
[teacher@localhost ~]$ [ -r /etc/passwd ] && echo "YES"
YES
8.4  测试当前登录到系统中的用户数量是否小于或等于10,是则输出“YES”。
[root@localhost ~]$ who | wc -l
2
[root@localhost ~]$ [ `who | wc -l` -le 10 ] && echo "YES"
YES
8.5  提取出“/boot”分区的磁盘使用率,并判断是否超过95%(为了便于理解,操作步骤以适当进行分解)。

8.6  提示用户输入一个文件路径,并判断是否是“/etc/inittab”,如果是则显示“YES”。
[root@localhost ~]# df -hT | grep "/boot" | awk '{print $6}'
[root@localhost ~]# read -p "Localtion: " FilePath 
Localtion: /etc/inittab   
[root@localhost ~]# [ $FilePath = "/etc/inittab" ] && echo "YES"
YES
8.7  若当前环境变量LANG的内容不是“en.US”,则输出LANG变量的值,否则无输出。
[root@localhost ~]# [ $LANG != "en.US" ] && echo $LANG
zh_CN.UTF-8
8.8  使用touch命令建立一个新文件,测试其内容是否为空,向文件中写入内容后,再次进行测试。
[root@localhost ~]# touch zero.file
[root@localhost ~]# [ -z 'cat zero.file' ] && echo "YES"
YES                                      //表示该文件为空文件
[root@localhost ~]# [ -z 'cat zero.file' ] && echo "YES"
[root@localhost ~]# echo "something" > zero.file
[root@localhost ~]# [ -z 'cat zero.file' ] && echo "YES"
                                         //无输出表示文件不为空
8.9  测试当前的用户是否是teacher,若不是则提示“Not teacher”。
[root@localhost ~]# echo $USER
root
[root@localhost ~]# [ $USER = "teacher" ] || echo "Not teacher"
Not teacher
8.10  只要“/etc/rc.d/rc.local”或者“/etc/init.d/rc.local”中有一个是文件,则显示“YES”,否则无任何输出。
[root@localhost ~]# [ -f /etc/rc.d/rc.local ] || [ -f /etc/init.d/rc.local ] && echo "YES"
YES
8.11  测试“/etc/profile” 文件是否有可执行权限,若确实没有可执行权限,则提示“No x mode.”的信息。
[root@localhost ~]# [ ! -x "/etc/profile" ] && echo "No x mode."
No x mode.
8.12  若当前的用户是root且使用的shell程序是“/bin/bash”, 则显示“YES”,否则无任何输出。
[root@localhost ~]# echo $USER $SHELL
root /bin/bash
[root@localhost ~]# [ $USER = "root" ] && [ $SHELL = '/bin/bash' ] && echo "YES" 
YES
8.13  检查“/var/log/messages”文件是否存在,若存在则统计文件内容的行数并输出,否则不做任何操作(合理使用变量,可以提高编写效率)。
[root@localhost ~]# vim chklog.sh
#!/bin/bash
LogFile="/var/log/messages"
if [ -f $LogFile ] ;  then
    wc -l $LogFile
fi
[root@localhost ~]# sh chklog.sh 
1005 /var/log/messages
8.14  提示用户指定备份目录的路径,若目录已存在则显示提示信息后跳过,否则显示相应提示信息后创建该目录。
[root@localhost ~]# vim mkbak.sh
#!/bin/bash
read -p "What is your backup directory: " BakDir
if [ -d $BakDir ] ; then
echo "$BakDir already exist. "
else
    echo "$BakDir is not exist, will make it. "
    mkdir $BakDir
fi
[root@localhost ~]# sh mkbak.sh 
What is your backup directory: /opt/bakroot
/opt/bakroot is not exist, will make it. 
[root@localhost ~]# ls -ld /opt/bakroot/
drwxr-xr-x. 2 root root 4096 11?.17 19:30 /opt/bakroot/
8.15 统计当前登录到系统中的用户数量,并判断是否超过三个,若是则显示实际数量并给出警告信息,否则列出登录的用户账号名称及所在终端。
[root@localhost ~]# vim chkuser.sh
#!/bin/bash
UserNum=`who | wc -l`
if [ $UserNum -gt 3 ] ; then
    echo "Alert, too many login users ( Total: $UserNum ). "
else
    echo "Login users: "
    who | awk '{print $1,$2}'
fi
[root@localhost ~]# sh chkuser.sh 
Login users: 
root tty1
root pts/0
8.16  检查portmap进程是否已经存在,若已经存在则输出“portmap service if running.” ;否则检查是否存在“/etc/rc.d/init.d/portmap” 可执行脚本,存在则启动portmap服务,否则提示“no portmap script file.”。
[root@localhost ~]# vim chkportmap.sh
#!/bin/bash
pgrep portmap &> /dev/null
if [ $? -eq 0 ] ; then
    echo "portmap service is running. "
elif [ -x "/etc/rc.d/init.d/portmap" ] ; then
     service portmap start
else
    echo "no portmap script file. "
fi
[root@localhost ~]# sh chkportmap.sh 
no portmap script file.
8.17  每隔五分钟监测一次mysqld服务进程的运行状态,若发现mysqld进程已终止,则在“/var/log/messages”文件中追加写入日志信息(包括当时时间),并重启mysqld服务;否则不进行任何操作。
[root@localhost ~]# vim chkportmap.sh
#!/bin/bash
service mysqld status &> /dev/null
if [ $? -ne 0 ] ; then
   echo "At time: `date`: MySQL server is down. " >> /var/log/messages
   service mysqld restart
fi
[root@localhost ~]# sh chkportmap.sh
[root@localhost ~]# tail -1 /var/log/messages
At time: 2011 年 11 月 18 日 星期五 20:16:31 CST : MySQL server is down.
[root@localhost ~]# crontab –e     //需确认crond服务已运行
*/5 * * * * /root/chkdbsvr.sh
8.18  依次输出三条文字信息,包括一天中的“Moring”、“Noon”、“Evening”字串。
[root@localhost ~]# vim showday.sh
#!/bin/bash
for TM in "Morning" "Noon" "Evening"
do
    echo "The $TM of the day. "
done
[root@localhost ~]# sh showday.sh 
The Morning of the day. 
The Noon of the day. 
The Evening of the day.
8.19  对于使用“/bin/bash”作为登录shell的系统用户,检查他们在“/opt”目录中拥有的子目录或文件数量,如果超过100个,则列出具体数值及对应的用户账号。
[root@localhost ~]# vim chkfileown.sh

#!/bin/bash
DIR="/opt"
LMT=100
ValidUsers=`grep "/bin/bash" /etc/passwd | cut -d ":" -f 1`
for UserName in $ValidUsers
do
   Num=`find $DIR -user $UserName | wc -l`
   if [ $Num -gt $LMT ] ; then
         echo "$UserName have $Num files. "
   fi
done
[root@localhost ~]# sh chkfileown.sh 
[root@localhost ~]# find -user root | wc -l
40
8.20  计算“/etc”目录中所有“*.conf”形式的配置文件所占用的总空间大小。
[root@localhost ~]# vim confsize.sh
#!/bin/bash
SizeNums=$(ls -l $(find /etc -type f -a -name *.conf) | awk '{print $5}')
Total=0
for i in $SizeNums
do
    Total=`expr $Total + $i`
done
echo "Total size of conf files: $Total bytes. "
[root@localhost ~]# sh confsize.sh 
Total size of conf files: 813 bytes.
8.21  由用户从键盘输入一个大于1的整数(如50),并计算从1到该数之间各整数的和。
[root@localhost ~]# vim sumint.sh
#!/bin/bash
read -p "Input a number (>1): "  UP
i=1
sum=0
while [ $i -le $UP ]
do
    sum=`expr $sum + $i`
    i=`expr $i + 1`
done
echo "The sum of 1-$UP is : $sum"
[root@localhost ~]# sh sumint.sh 
Input a number (>1): 50
The sum of 1-50 is : 1275
8.22  批量添加20个系统用户账号,用户名称依次为“stu1”、“stu2”、“stu3”、……“stu20”,各用户的初始密码均设置为“123456”。
[root@localhost ~]# vim add20users.sh
#!/bin/bash
i=1
while [ $i -le 20 ]
do
useradd stu$i
echo "123456" | passwd --stdin stu$i &> /dev/null
     i=`expr $i + 1`
done
[root@localhost ~]# sh add20users.sh
[root@localhost ~]# tail -2 /etc/passwd
stu19:541:541::/home/stu19:/bin/bash
stu20:542:542::/home/stu20:/bin/bash
8.23  编写一个批量删除用户的脚本程序,将上例中添加的20个用户删除。
[root@localhost ~]# vim del20users.sh

#!/bin/bash
i=1
while [ $i -le 20 ]
do
      userdel -r stu$i
      i=`expr $i + 1`
done
[root@localhost ~]# sh del20users.sh
[root@localhost ~]# grep "stu" /etc/passwd     //无输出则表示上述用户已删除
8.24  由用户从键盘输入一个字符,并判断该字符是否为字母、数字或者其他字符,并输出相应的提示信息。
[root@localhost ~]# vim hitkey.sh
#!/bin/bash
read -p "ress some key, then press Return: " KEY
case "$KEY" in
   [a-z] | [A-Z])
        echo "It's a letter."
    ;;
[0-9])
        echo "It's a digit."
    ;;
*)
      echo "It's function keys,spacebar or other keys. "
esac
[root@localhost ~]# sh hitkey.sh 
Press some key, then press Return: K
It's a letter.
[root@localhost ~]# sh hitkey.sh 
Press some key, then press Return: 6
It's a digit.
[root@localhost ~]# sh hitkey.sh 
Press some key, then press Return: ^[[19~   //按F8键
It's function keys,spacebar or other keys.
8.25  编写一个shell程序,计算多个整数值的和,需要计算的各个数值由用户在执行脚本时作为命令行参数给出。
[root@localhost ~]# vim sumer.sh
#!/bin/bash
Result=0
while [ $# -gt 0 ]
do
    Result=`expr $Result + $1`
    shift
done
echo "The sum is : $Result"
[root@localhost ~]# chmod a+x sumer.sh 
[root@localhost ~]# ./sumer.sh 12 34
The sum is : 46
8.26  循环提示用户输入字符串,并将每次输入的内容保存到临时文件“/tmp/input.txt”中,当用户输入“END”字符串时退出循环体,并统计出input.txt文件中的行数、单词数、字节数等信息,统计完后删除临时文件。
[root@localhost ~]# vim inputbrk.sh
#!/bin/bash
while true
do
      read -p "Input a string: " STR
      echo $STR >> /tmp/input.txt
      if [ "$STR" = "END" ] ;  then
           break
      fi
done
wc /tmp/input.txt
rm -f /tmp/input.txt
[root@localhost ~]# sh inputbrk.sh 
Input a string: wandogn
Input a string: dongdonga
Input a string: END
3  3 22 /tmp/input.txt
8.27  删除系统中的stu1~stu20各用户账号,但stu8、stu18除外。
[root@localhost ~]# sh add20users.sh       //执行上面建立的脚本添加用户
[root@localhost ~]# tail -2 /etc/passwd
stu19:542:542::/home/stu19:/bin/bash
stu20:543:543::/home/stu20:/bin/bash
[root@localhost ~]# vim delsome.sh
#!/bin/bash
i=1
while [ $i -le 20 ]
do
    if [ $i -eq 8 ] || [ $i -eq 18 ] ; then
       let i++
       continue
    fi
    userdel -r stu$i
    let i++
done
[root@localhost ~]# sh delsome.sh 
[root@localhost ~]# grep "stu" /etc/passwd
stu8:531:531::/home/stu8:/bin/bash
stu18:541:541::/home/stu18:/bin/bash
8.28  在脚本中定义一个help函数,当用户输入的脚本参数不是“start”或“stop”时,加载该函数并给出关于命令用法的帮助信息,否则给出对应的提示信息。
[root@localhost ~]# vim helpfun.sh

#!/bin/bash
help() {
      echo "Usage: "$0" start|stop"
}
case "$1" in
   start)
      echo "Starting ..."
     ;;
*)
     help
esac
[root@localhost ~]# chmod a+x helpfun.sh
[root@localhost ~]# ./helpfun.sh start
Starting ...
[root@localhost ~]# ./helpfun.sh restart
Usage: ./helpfun.sh start|stop
8.29  在脚本中定义一个加法函数,用于计算两个数的和,并调用该函数分别计算12+34、56+789的和。
[root@localhost ~]# vim adderfun.sh
#!/bin/bash
adder() {
      echo `expr $1 + $2`
}
adder 12 34
adder 56 789
[root@localhost ~]# sh adderfun.sh 
46
845

编写shell管理脚本(二)的更多相关文章

  1. 编写shell管理脚本(一)

    7.1  查看当前linux系统中能够使用的shell程序的列表[root@localhost ~]# cat /etc/shells/bin/sh/bin/bash/sbin/nologin/bin ...

  2. [转贴]systemd 编写服务管理脚本

    [转贴]sparkdev大神的博客, 关于 systemd的配置文件的 介绍, 自己之前二进制安装 k8s 时 超过一个 service文件 但是当时不明不白的. 现在再学习一下大神的文章 的确牛B ...

  3. systemd 编写服务管理脚本

    我们运行 linux 服务器的主要目的是通过运行程序提供服务,比如 mysql.web server等.因此管理 linux 服务器主要工作就是配置并管理上面运行的各种服务程序.在 linux 系统中 ...

  4. systemd 编写服务管理脚本---学习

    转载:https://www.cnblogs.com/sparkdev/p/8521812.html 我们运行 linux 服务器的主要目的是通过运行程序提供服务,比如 mysql.web serve ...

  5. 编写shell脚本让springboot项目在CentOS中开机自启动

    springboot项目部署在CentOS系统上时,如果遇到停电关机,公司的实施人员就得跑到甲方现场重新启动项目并测试,很是麻烦,这里探讨如何编写shell脚本控制springboot项目开机时自动启 ...

  6. 小鸟初学Shell编程(二)编写简单的Shell脚本

    Shell脚本 编写Python.PHP脚本通常需要掌握语言的函数,那么Shell脚本则不需要,只需要掌握Linux命令就可以编写Shell脚本,因为Shell脚本就是由多个Linux命令组成,通过将 ...

  7. linux软件管理之------编译安装nginx服务器并手动编写自动化运行脚本

    红帽系列的 linux软件管理分为三类:1. rpm 安装软件.2. yum 安装软件.3. 源码包编译安装.前面两种会在相关专题给出详细讲解.源码包的编译安装是非常关键的,我们知道linux的相关版 ...

  8. shell脚本二

    在shell脚本一 中,我讨论了shell脚本的语法规范,shell脚本的变量,以及shell脚本的测试语句. 仅仅懂得这些只能写简单的脚本,在简单的脚本中各条语句按顺序执行,从而实现自动化的管理,顺 ...

  9. linux 的基本操作(编写shell 脚本)

    终于到shell 脚本这章了,在以前笔者卖了好多关子说shell脚本怎么怎么重要,确实shell脚本在linux系统管理员的运维工作中非常非常重要.下面笔者就带你正式进入shell脚本的世界吧. 到现 ...

随机推荐

  1. poj: 2255

    跟LEETCODE的preorder,inorder转postorder题很像 #include <iostream> #include <stdio.h> #include ...

  2. windows系统调用 进程终止

    #include "windows.h" #include "iostream" #include "stdio.h" using name ...

  3. struts局部、全局类型转换器

    第01步:编写bean package com.self.bean; import java.util.Date; public class User { private Date birthday ...

  4. Demo12SimpleAdapter

    /Users/alamps/AndroidStudioProjects/Demo12SimpleAdapter/Demo12SimpleAdapter/src/main/res/layout/data ...

  5. 解决Android抽屉被击穿问题

    1,创建一个抽屉DrawerLayout,在V4包下android.support.v4.widget.DrawerLayout,在要设置抽屉的布局中设置android:layout_gravity= ...

  6. Java魔法堂:注释和注释模板 (转)

    http://www.cnblogs.com/fsjohnhuang/p/3988883.html 一.注释   1. 注释类型 [a]. 单行注释 // 单行注释 String type = &qu ...

  7. Openstack的HA解决方案【haproxy和keepalived】

    1. 安装haproxy,keepalived, httpd,3台机器一致. yum install haproxy keepalived httpd -y 2. 修改httpd的默认页面. 在/va ...

  8. 鸟哥的Linux私房菜之学习shell script

    运行程序的时候一般都是创建一个子程序来执行,所以子程序中的变量什么的在当前的shell下没法使用,但是如果使用source来执行就可以在当前shell下执行程序 shift 1 去掉第一个参数,后面接 ...

  9. 精通 JS正则表达式

    一.正则表达式可以: 测试字符串的某个模式.例如,可以对一个输入字符串进行测试,看在该字符串是否存在一个电话号码模式或一个信用卡号码模式.这称为数据有效性验证 替换文本.可以在文档中使用一个正则表达式 ...

  10. 给NIOS II CPU添加一颗澎湃的心——sysclk的使用

    给NIOS II CPU添加一颗澎湃的心——系统时钟的使用 本实验介绍如何在Qsys中添加一个定时器作为NIOS II的心跳定时器,并在NIOS II中软件编程使用该定时器. 将上一个实验watchd ...