1. 使用case实现成绩优良中差的判断
[root@localhost ~]# vim score.sh
#!/bin/bash
read -p "请输入成绩:" score
case $score in
[0-5][0-9])
echo "差!"
;;
6[0-9])
echo "中"
;;
[7-8][0-9])
echo "良"
;;
9[0-9]|100)
echo "优!"
;;
esac
测试:
[root@localhost ~]# sh score.sh 请输入成绩:40 差! [root@localhost ~]# sh score.sh 请输入成绩:65 中 [root@localhost ~]# sh score.sh 请输入成绩:99 优!
2. for创建20用户
用户前缀由用户输入
用户初始密码由用户输入
例如:test01,test10
[root@localhost ~]# vim uname.sh
#!/bin/bash
read -p "请输入用户前缀:" prefix
read -p "请输入用户密码:" pas
for i in {1..20}
do
user=$prefix$i
password=$pas$i;
if ! id -u $user &> /dev/null
then
useradd $user
echo $password | passwd --stdin $user &> /dev/null
else
echo "用户已存在!"
fi
done
测试:
[root@localhost ~]# sh uname.sh 请输入用户前缀:CHQ 请输入用户密码:123456 [root@localhost ~]# cat /etc/passwd | grep CHQ* CHQ1:x:1019:1019::/home/CHQ1:/bin/bash CHQ2:x:1020:1020::/home/CHQ2:/bin/bash CHQ3:x:1021:1021::/home/CHQ3:/bin/bash CHQ4:x:1022:1022::/home/CHQ4:/bin/bash CHQ5:x:1023:1023::/home/CHQ5:/bin/bash CHQ6:x:1024:1024::/home/CHQ6:/bin/bash CHQ7:x:1025:1025::/home/CHQ7:/bin/bash CHQ8:x:1026:1026::/home/CHQ8:/bin/bash CHQ9:x:1027:1027::/home/CHQ9:/bin/bash CHQ10:x:1028:1028::/home/CHQ10:/bin/bash CHQ11:x:1029:1029::/home/CHQ11:/bin/bash CHQ12:x:1030:1030::/home/CHQ12:/bin/bash CHQ13:x:1031:1031::/home/CHQ13:/bin/bash CHQ14:x:1032:1032::/home/CHQ14:/bin/bash CHQ15:x:1033:1033::/home/CHQ15:/bin/bash CHQ16:x:1034:1034::/home/CHQ16:/bin/bash CHQ17:x:1035:1035::/home/CHQ17:/bin/bash CHQ18:x:1036:1036::/home/CHQ18:/bin/bash CHQ19:x:1037:1037::/home/CHQ19:/bin/bash CHQ20:x:1038:1038::/home/CHQ20:/bin/bash
3. for ping测试指网段的主机
网段由用户输入,例如用户输入192.168.128 ,则ping 192.168.128.10 — 192.168.128.20
UP: /tmp/host_up.txt
Down: /tmp/host_down.txt
[root@localhost ~]# vim forping.sh
#!/bin/bash
read -p "请输入网段:" ip
for i in {10..20}
do
IP="$ip"."$i"
echo $IP
if ping -c 1 $IP &> /dev/null
then
echo "$IP is up " >> /tmp/host_up.txt
else
echo "$IP is down " >> /tmp/host_down.txt
fi
done
测试:
[root@localhost ~]# sh forping.sh 请输入网段:192.168.128 192.168.128.10 192.168.128.11 192.168.128.12 192.168.128.13 192.168.128.14 192.168.128.15 192.168.128.16 192.168.128.17 192.168.128.18 192.168.128.19 192.168.128.20 [root@localhost ~]# cat /tmp/host_down.txt 192.168.128.10 is down 192.168.128.11 is down 192.168.128.12 is down 192.168.128.13 is down 192.168.128.14 is down 192.168.128.15 is down 192.168.128.16 is down 192.168.128.17 is down 192.168.128.18 is down 192.168.128.19 is down 192.168.128.20 is down
4. 使用for实现批量主机root密码的修改
成功或失败都必须记录
提示:主机IP存放在一个文件中
SSH:实现公钥认证,执行远程中主机命令
实现公钥认证
ssh-keygen 在用于管理的主上生成密钥对
ssh-copy-id -i 192.168.2.3
[root@localhost ~]# vim ssh.sh
#!/bin/bash
ssh-keygen -f /root/.ssh/id_rsa -P '' -q &>/dev/null
for ip in `cat ipfile`
do
echo $ip
ssh-copy-copy-id root@$ip
done
for ip in `cat ipfile`
do
echo $ip
ssh root@ip "echo redhat | passwd --stdin root" &>/dev/null
if [ "$?" -eq 0 ];then
echo "host $ip successfully update passwd"
else
echo "host $ip error update passwd"
fi
done



