shell脚本基础日常练习

时间:2021-09-22 04:21:12
1、编写一个脚本,名为/root/bin/createscripts.sh ,当执行该脚本时,输入 createscripts.sh /path/newsh.sh 则会在指定路径生成脚本文件,并涵盖注释信息如下:
#!/bin/bash
# ------------------------------------------
# Filename:    hello.sh
# Revision:    1.0
# Date:        2020/01/01
# Author:      ty
# Email:       ty@gmail.com
# Website:     www.ty.com
# Description:
# ------------------------------------------
# Copyright:   2020ty
# License:     GPL

并自动打开该 文件,开始编辑,在编辑结束后,自动给该脚本加上执行权限。

方法一:

#!/bin/bash
#
A=`basename $1 |grep -o "\.sh$"` 
#echo $A
if [ -n "$A" ];then
		echo -e "#!/bin/bash \n#" >> $1
		echo  "#---------------------------------------" >> $1
		echo  "# Filename:    `basename $1`" >> $1
		echo  "# Revision:    1.0" >> $1
		echo  "# Date:        `date +"%F %T"`">> $1
		echo  "# Author:      `id -nu`" >> $1
		echo  "# Email:       sezina_f@163.com" >> $1
		echo  "# Description:" >> $1
		echo  "#---------------------------------------" >> $1
		echo  "# Copyright:   2020 tzx" >> $1
		echo  "# License:     GPL" >> $1
		echo  >> $1
		vim +13 $1
		chmod +x $1
	else
		echo "Usage: Please end file with .sh."
方法二:
#!/bin/bash
touch  /app/root/bin$1
chmod +x /app/root/bin$1
echo "#!/bin/bash
# ---------------------------------------
# Filename:   $1
# Revision:   1.0
# Date:       $(date +%F)
# Author:     $(whoami)
# Email:      ty@163.com
# Website:    www.100.com
# Description:
# ---------------------------------------
# Copyright:
#License:
" >$1
vim $1
chmod +x $1
2、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小
当前主机系统信息如下:
主机名: hostname
IPV4地址: ifconfig
操作系统版本: cat /etc/redhat-release
内核版本: uname -r
CPU型号:lscpu
内存型号: free -m  格式为:xxxx MB
硬盘大小: fdisk -l /dev/sda  格式为:xxx GB
#!/bin/bash
		# -------------------------------------------------
		echo "当前主机系统如下:"
		echo "主机名: $(hostname)"
		echo "IPV4地址: "  "$(ifconfig|grep "inet "|grep -o "\([0-9]\{1,3\}\.\)\{3\}[1-9]\{1,3\}")"
		echo "操作系统版本:" "$(cat /etc/redhat-release)"
		echo "内核版本:" "$(uname -r)"
		echo "CPU型号:" "$(lscpu|grep -i "model name")"
		echo "内存大小" $(free -hm|head -2|tr -s " "  |tail -1|cut -d" " -f2)
		echo "磁盘容量" $(fdisk -l /dev/sda|head -2|tail -1|cut -d " " -f3,4)
3、编写脚本/root/bin/backup.sh,可实现每日将/etc/目录备份到/root/etcYYYY-mm-dd中
cp -a /etc/ /root/etc`date +%Y-%m-%d`
4、编写脚本/root/bin/disk.sh,显示当前硬盘分区中空间利用率最大的值
echo "当前硬盘分区中空间利用率最大的值:$( df |grep -o "[0-9]\{1,3\}%" |sort -rn |head -1)"
5、编写脚本/root/bin/links.sh,显示正连接本主机的每个远程主机的IPv4地址和连接数,并按连接数从大到小排序
cat /var/log/httpd/access_log |cut -d" " -f1|sort -r
6、编写脚本/root/bin/sumid.sh,计算/etc/passwd文件中的第10个用户和第20用户的ID之和.
id1=$(cat /etc/passwd |cut -d: -f3 |head -$1 | tail -1)
id2=$(cat /etc/passwd |cut -d: -f3 |head -$2 | tail -1)
echo "$[$id1+$id2]"
7、编写脚本/root/bin/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和
space1=`cat $1 |grep "^[[:space:]]*$"|wc -l`
space2=`cat $2 |grep "^[[:space:]]*$"|wc -l`
echo $space1+$space2 |bc
8、编写脚本/root/bin/sumfile.sh,统计/etc, /var, /usr目录*有多少个一级子目录和文件
etc=$[$(ls -l /etc/ |wc -l)-1]
var=$[$(ls -l /var/ |wc -l)-1]
usr=$[$(ls -l /usr/ |wc -l)-1]
echo $[$etc+$var+$usr]
9、编写脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如果不可ping通,则提示用户“该IP地址不可访问”
#!/bin/bash
[ $# -eq 0 ] && echo "请输入一个合法的IPV4地址" && exit 1
ping -c1 -W1 $1 &> /dev/null  && echo "该IP地址可访问" || echo "该IP地址不可访问"
10、对以上对该脚本进行升级,可以判断ip地址的合法型,如果不合法,直接提示用户"IP地址不合法"并退出
a1=`echo $1|cut -d. -f1`
a2=`echo $1|cut -d. -f2`
a3=`echo $1|cut -d. -f3`
a4=`echo $1|cut -d. -f4`
[ $a1 -le 255 ] && [ $a2 -le 255 ] && [ $a3 -le 255 ] && [ $a4 -le 255 ] || echo "IP地址不合法" && exi
t 1
ping -c1 -W1 $1 &> /dev/null && echo "该IP可访问" || echo "该IP不可访问"
11、编写脚本/root/bin/checkdisk.sh,检查磁盘分区空间和inode使用率,如果超过80%,就发广播警告空间将满
usagea=$(df |grep "^/.*sd" |egrep -o "[0-9]{1,3}%" |tr -d % |sort -n |tail -1)
usageb=$(df -i |grep "^/.*sd" |egrep -o "[0-9]{1,3}%" |tr -d % |sort -n |tail -1)
[ $usagea -ge 80 -o $usageb -ge 80 ] && wall warning || echo health
12、编写脚本/bin/per.sh,判断当前用户对指定的参数文件,是否不可读并且不可写
#!/bin/bash
#判断用户对指定的文件是否不可读写
[ ! -r $1 -a ! -w $1 ] && echo "该文件不可读写" 
13、编写脚本/root/bin/excute.sh ,判断参数文件是否为sh后缀的普通文件,如果是,添加所有人可执行权限,否则提示用户非脚本文件
#!/bin/bash
#判断用户对指定的文件是否不可读写

[ ! -e $1 ] && echo 文件不存在 && exit 0
[ -f $1 -a $1{.sh$} ]  && chmod o+x $1 ||echo "非脚本文件"
14、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充许普通用户登录系统
uid=`cat /etc/passwd|cut -d: -f3`

user=`egrep "^[[:alnum:]]+:x:[0-9]{4,5}.*bash$" /etc/passwd|cut -d: -f1`

version=`cat /etc/redhat-release |cut -d" " -f4|cut -d"." -f1`

[ $version -eq 6 ] && [ $uid -ge 500 ] && 
[ $version -eq 7 ] && [ $uid -ge 1000 ] && 
15、让所有用户的PATH环境变量的值多出一个路径,例如:/usr/local/apache/bin
export PATH=$PATH:/usr/local/apache/bin
注意全局配置路径:/etc/profile,/etc/profile.d/*.sh,/etc/bashrc

vim /etc/profile.d/env.sh
export PATH=/usr/local/apache/bin:$PATH
source /etc/profile.d/env.sh
16、任意用户登录系统时,显示红色字体的警示提醒信息“Hi,dangerous!”
vim /etc/profile.d/env.sh
echo -e '\033[31m hi,dangerous! \033[0m'

17、编写用户的环境初始化脚本reset.sh,包括别名,登录提示符,vim的设置,环境变量等

vim /root/bin/reset.sh
	#!/bin/bash
	# reset.sh
	cat > /etc/profile.d/env.sh << EOF
	alias cdnet="cd /etc/sysconfig/network-scripts"
	alias editnet="vim /etc/sysconfig/network-scripts/ifcfg-ens33"
	
	export PATH=/app/bin:$PATH
	EOF
	cat > ~/.vimrc << EOF
	set nu
	EOF

shell脚本基础日常练习

      先到这....