并自动打开该 文件,开始编辑,在编辑结束后,自动给该脚本加上执行权限。
方法一:
#!/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: [email protected]" >> $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: [email protected]
# Website: www.100.com
# Description:
# ---------------------------------------
# Copyright:
#License:
" >$1
vim $1
chmod +x $1
2、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小
#!/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
先到这....