目录
从用户列表中过滤用户名并创建用户
######################### name.sh
#!/bin/bash
n=0
userName=`echo $(cat /root/name.txt | tr -s " " | cut -d " " -f2 )`
for userN in $userName
do
let ++n
dirName=`echo $(cat /root/name.txt | awk -F " " '{print $1}')| cut -d " " -f$n`
useradd -d /home/$dirName $userN
echo 123456 | passwd --stdin $userN
done
awk、tr、cut 指令的文本处理
awk、tr、cut 指令可以很好的进行文本信息处理
tr指令
一般用于文本或字符串编辑处理,可以替换、删除、合并重复字符。
tr -s "Str" textString #将testString中的重复的"Str"合并为一个
#如:
tr -s " " 将标准输入的Text中的连续的" " 合并重一个空格符
cut指令
以分割的方式来编辑文本
cut -d " " -f2
-d 定义分隔符,将标准输入的文本信息以" "作为分隔符
-f 和-d配合指定分割后要显示的区域
-c numberRange <==>(2-5) 将Text中的2-5范围的字符截取出来
awk指令
awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理。
工作原理:读入并分割有’
’换行符的的一条记录,再将这条记录以-F " "
指定的特定分割符来划分出域,填充域,最后使用$Number
来选择需要显示第几个域并最终使用{print $Number}
显示。没有-F指定特定分隔符时,默认分隔符为”空白键” 或 “[tab]键”。
备份文件
#############################Backups.sh
#!/bin/bash
read -p "请输入要备份的内容:" backupName
read -p "请输入要备份的文件名及路径:" backupUrl
read -p "请输入要备份的文件的存放路径:" backupCpUrl
read -p "请输入要使用的压缩算法:" backupAlg
alg=0
algName=0
case $backupAlg in
gzip)
alg=z
algName=gz
;;
bzip2)
alg=j
algName=bz2
;;
xz)
alg=J
algName=xz
;;
*)
echo "请输入正确的压缩算法类型!"
esac
tar ${alg}cvf ${backupCpUrl}/${backupName}.tar.${algName} ${backupUrl}
if [ $? -eq 0 ]
then echo "打包备份文件成功!"
else
echo "打包备份失败!"
fi
########################################## SCRIPT END
测试LFTPServer权限设定
########################################## Lftp.sh
#!/bin/bash
lftp 192.168.8.248 -u user1,fanguiju -e "cd share;ls;exit" &> /dev/null
if [ $? -eq 0 ]
then echo "user1用户可以读取share目录,符合要求!"
else
echo "user1用户不可以读取share目录,不符合要求!"
fi
lftp 192.168.8.248 -u user1,fanguiju -e "cd share;mkdir testSaDir_user1;exit" &> /dev/null
if [ $? -eq 1 ]
then echo "user1用户不可以写入share目录,符合要求!"
else
echo "user1用户可以写入share目录,不符合要求!"
fi
lftp 192.168.8.248 -u user1,fanguiju -e "cd data;ls;exit" &> /dev/null
if [ $? -eq 0 ]
then echo "user1用户可以读取data目录,符合要求!"
else
echo "user1用户不可以读取data目录,不符合要求!"
fi
lftp 192.168.8.248 -u user1,fanguiju -e "cd data;mkdir testDaDir_user1;exit" &> /dev/null
if [ $? -eq 0 ]
then echo "user1用户可以写入data目录,符合要求!"
else
echo "user1用户可以不写入data目录,不符合要求!"
fi
lftp 192.168.8.248 -u user2,fanguiju -e "cd share;ls;exit" &> /dev/null
if [ $? -eq 0 ]
then echo "user2用户可以读取share目录,符合要求!"
else
echo "user2用户不可以读取share目录,不符合要求!"
fi
lftp 192.168.8.248 -u user2,fanguiju -e "cd share;mkdir testSaDir_user2;exit" &> /dev/null
if [ $? -eq 1 ]
then echo "user2用户不可以写入share目录,符合要求!"
else
echo "user2用户可以写入share目录,不符合要求!"
fi
lftp 192.168.8.248 -u user2,fanguiju -e "cd data;ls;exit" &> /dev/null
if [ $? -eq 0 ]
then echo "user2用户可以读取data目录,符合要求!"
else
echo "user2用户不可以读取data目录,不符合要求!"
fi
lftp 192.168.8.248 -u user2,fanguiju -e "cd data;mkdir testDaDir_user2;exit" &> /dev/null
if [ $? -eq 1 ]
then echo "user1用户不可以写入data目录,符合要求!"
else
echo "user1用户可以写入data目录,不符合要求!"
fi
#FTP(File Transfer Protocol) lftp FTPServerIP -u userName,Password -e "command1;command2;exit" &> /dev/null 是编写LFTP服务脚本的方法
################################################## SCRIPT END
开启Httpd
################################################## HttpStatus.sh
#!/bin/bash
while true
do
netstat -lputn | grep :80 &> /dev/null
if [ $? -eq 0 ]
then echo "httpd running!"
exit
else
echo "httpd stop"
echo "正在尝试重启httpd服务..."
echo `date +"%Y-%m-%d %H:%M:%S"` >> /var/log/mylog
tail -n 1 /etc/httpd/logs/error_log >> /var/log/mylog
service httpd start
fi
netstat -lputn | grep :80 &> /dev/null
if [ $? -eq 0 ]
then
echo "httpd 重启启动成功!"
break
fi
done
exit 0
################################################## SCRIPT END
安装Httpd
################################################## InstallHttp.sh
#!/bin/bash
rpm -q httpd
if [ $? -eq 0 ]
then echo "httpd已经安装!"
exit 0
else
echo -n "正在安装httpd..."
fi
yum install -y httpd &> /dev/null
rpm -q httpd
if [ $? -eq 0 ]
then echo "安装成功!"
else
echo -n "安装失败!" >> /var/log/mylog
date >> /var/log/mylog
fi
################################################# SCRIPT END
批量创建用户
################################################# UserAdd.sh
#!/bin/bash
while true
do
read -p "请输入要添加的用户数目(100以内):" userNum
if [ $userNum -le 0 ] || [ $userNum -ge 100 ]
then
echo "请输入正确的数目范围!"
else
break
fi
done
read -p "请输入用户名前缀:" userName
read -p "请输入用户帐号的失效时间(MM/DD/YY):" userTime
read -p "请输入用户的初始密码:" userPwd
num=0
for (( num=0;num<=$userNum;num++ ))
do
if [ $num -lt 10 ]
then
name=${userName}0${num}
else
name=${userName}$num
fi
useradd -e $userTime $name
echo $userPwd | passwd --stdin $name
done
echo "你成功创建了${userNum}个用户!"
########################################### SCRIPT END
批量删除用户
########################################### UserDel.sh
#!/bin/bash
if [ $# -ne 1 ]
then echo "语法错误!"
echo "用法:$0 用户名前缀"
fi
num=`echo $(cat /etc/passwd | grep -v ^root$ | cut -d ":" -f1 | grep -v ^root$ | grep $1 )`
if [ -z $num ]
then echo "没有以$1为前缀的用户"
else
for userName in $num
do
echo -n "正在删除用户$userName..."
userdel -r $userName
echo "完成"
done
fi
# $# 脚本后接参数的个数 $# -ne 1 脚本后参数的个数!=1
############################################ SCRIPT END