#!/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 $12、编写脚本/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 -r6、编写脚本/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 |bc8、编写脚本/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 health12、编写脚本/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.sh16、任意用户登录系统时,显示红色字体的警示提醒信息“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
先到这....