格式1:
for name [ in word ] ; do list ; done
格式2:
for (( expr1 ; expr2 ; expr3 )) ; do list ; done
1、在指定的区间中来循环:
for i in xx01 xx02 xx02
do
echo $i
done
2、在运算结果中来循环
for i in {100..110}
do
echo $i
done
for ((i=1;i<=10;i++))
do
echo $i
done
3、从文件列表来循环
for i in `cat a.txt`
do
echo $i
done
实例1:批量新建10个用户
1、所有用户的初始化密码是password
2、所有用户每30天需要改一次密码,如果不改密码,在密码过期后三天账号不可用
3、所有的账号第一登录时都需要强制修改密码
for i in {1..10}
do
useradd login$i
echo "password" | passwd --stdin login$i
chage -M 30 -I 3 login$i
chage -d 0 login$i
done
实例2:根据花名册来新建用户
cat user.txt --花名册
工号 姓名 所在部门 入职时间 离职时间 薪水
001 zhang3 rs 2012-1-1 5000
002 li04 cw 2000-1-1 2005-12-12 4000
003 wang5 sc 2010-10-10 3500
脚本如下:
#!/bin/bash
users=$(awk 'NR>1 {print $3"_"$2}' user.txt)
for i in $users
do
useradd $i
echo "password" | passwd --stdin $i
chage -M 30 -I 3 $i
chage -d 0 $i
done
for+if写备份脚本:
#!/bin/bash
backup_day=$(date +%F)
rm_day=$(date +%F --date '3 days ago')
backup_dir=/bak/web/$backup_day
pidfile=/var/run/bak.pid
lockfile=/var/lock/subsys/bak
export backup_day rm_day backup_dir pid pidfile lockfile
#查看PID,进程是否正在运行
if [ -f $lockfile ]
then
export pid=`cat $pidfile`
ps -p $pid | grep sh &> /dev/null && echo $0 is running, pid is $pid
exit 1
fi
if [ 0 -eq $UID ] || [ bak_user == "$USER" ]
then
echo $$ > $pidfile
touch $lockfile
if [ -d /bak/web/$rm_day ]
then
rm -rf /bak/web/$rm_day
fi
mkdir -p $backup_dir
cd /data
for i in web*
do
tar cjf $backup_dir/"$i".tar.gz "$i"
done
rm -rf $pidfile
rm -rf $lockfile
else
echo "当前用户不是管理员或者bak_user" && exit 1
fi
实例3:批量设置磁盘配额 (普通用户和老板的配额需要不一样)
useradd u01
useradd boss
#!/bin/bash
users="u01 u02 boss"
block_soft=$((1*1024*1024))
block_hard=$((2*1024*1024))
inode_soft=0
inode_hard=0
mountpoint=/home
for i in $users
do
if [ "$i" = boss ]
then
setquota -u $i 20000000 30000000 $inode_soft $inode_hard $mountpoint
else
setquota -u $i $block_soft $block_hard $inode_soft $inode_hard $mountpoint
fi
done