Linux shell腳本學習和實戰之一


一、在/test目錄下使用for循環建立10個文件如:test-1,test-2,...test-10
mkdirsh.sh
#!/bin/bash
for i in `seq 10`
do
[ ! -d /test ] && mkdir -p /test
touch /test/test-$i
done
chmod +x mkdirsh.sh

二、在/test目錄下快速建立10個文件的方法如:test-1,test-2,...test-10
[root@Titu-BackupFS test]# touch test-{1..10}
[root@Titu-BackupFS test]# ll
total 0
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-1
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-10
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-2
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-3
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-4
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-5
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-6
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-7
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-8
-rw-r--r-- 1 root root 0 Mar 30 10:36 test-9

三、將以上文件名的test改成bruce(用for循環)
renamesh.sh
#!/bin/bash
[ -d /test ] && cd /test
for file in `ls test*`
do
mv $file `echo $file | sed 's#test#bruce#g' `
done
chmod +x renamesh.shbash


四、將以上文件名的bruce快速改成networkide

[root@Titu-BackupFS test]# rename test network *bruce*
[root@Titu-BackupFS test]# ll
total 0
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-1
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-10
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-2
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-3
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-4
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-5
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-6
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-7
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-8
-rw-r--r-- 1 root root 0 Mar 30 10:36 network-9

五、批量建立10個系統賬號test01,test02,...test10並設置密碼
(1)、首先理解序號數字的生成方法
[root@Titu-BackupFS test]# echo {01..10}
01 02 03 04 05 06 07 08 09 10

[root@Titu-BackupFS test]# seq 10
1
2
3
4
5
6
7
8
9
10

[root@Titu-BackupFS test]# seq -w 10
01
02
03
04
05
06
07
08
09
10
spa


(2)、基於序號數字來依次生成用戶賬戶和密碼信息
createusersh.sh
#!/bin/bash
for i in `seq -w 10`
do
useradd test$i && echo "test$i" | passwd --stdin test$i
done
chmod +x createusersh.sh
[root@Titu-BackupFS ~]# ./createusersh.sh
Changing password for user test01.
passwd: all authentication tokens updated successfully.
Changing password for user test02.
passwd: all authentication tokens updated successfully.
Changing password for user test03.
passwd: all authentication tokens updated successfully.
Changing password for user test04.
passwd: all authentication tokens updated successfully.
Changing password for user test05.
passwd: all authentication tokens updated successfully.
Changing password for user test06.
passwd: all authentication tokens updated successfully.
Changing password for user test07.
passwd: all authentication tokens updated successfully.
Changing password for user test08.
passwd: all authentication tokens updated successfully.
Changing password for user test09.
passwd: all authentication tokens updated successfully.
Changing password for user test10.
passwd: all authentication tokens updated successfully.
[root@Titu-BackupFS ~]# cat /etc/passwd | grep test*
test01:x:502:502::/home/test01:/bin/bash
test02:x:503:503::/home/test02:/bin/bash
test03:x:504:504::/home/test03:/bin/bash
test04:x:505:505::/home/test04:/bin/bash
test05:x:506:506::/home/test05:/bin/bash
test06:x:507:507::/home/test06:/bin/bash
test07:x:508:508::/home/test07:/bin/bash
test08:x:509:509::/home/test08:/bin/bash
test09:x:510:510::/home/test09:/bin/bash
test10:x:511:511::/home/test10:/bin/bash
說明:生成test01,test02,...test10用戶成功!token


六、批量刪除用戶
userdelsh.sh
#!/bin/bash
for username in `cat /etc/passwd| grep test*|awk -F: '{print $1}'`
do
userdel -r $username
done
chmod +x userdelsh.sh
[root@Titu-BackupFS ~]# ./userdelsh.sh
[root@Titu-BackupFS ~]# cat /etc/passwd|grep test*
說明:刪除test01,test02,...test10用戶成功!md5


七、批量建立10個賬號bruce01,bruce02,...bruce10並設置隨機密碼
createusernew.sh
#!/bin/bash
for i in `seq -w 10`
do
passwd=`echo $RANDOM | md5sum | cut -c 1-8`
##注意:將隨機數定義爲變量後,在後續引用過程當中其值保持不變!
useradd bruce$i && echo "$passwd" | passwd --stdin bruce$i
echo -e "user:bruce$i \t password:$passwd" >> /tmp/userandpw.log
done
chmod +x createusernew.shit

[root@Titu-BackupFS ~]# ./createusernew.sh
Changing password for user bruce01.
passwd: all authentication tokens updated successfully.
Changing password for user bruce02.
passwd: all authentication tokens updated successfully.
Changing password for user bruce03.
passwd: all authentication tokens updated successfully.
Changing password for user bruce04.
passwd: all authentication tokens updated successfully.
Changing password for user bruce05.
passwd: all authentication tokens updated successfully.
Changing password for user bruce06.
passwd: all authentication tokens updated successfully.
Changing password for user bruce07.
passwd: all authentication tokens updated successfully.
Changing password for user bruce08.
passwd: all authentication tokens updated successfully.
Changing password for user bruce09.
passwd: all authentication tokens updated successfully.
Changing password for user bruce10.
passwd: all authentication tokens updated successfully.
[root@Titu-BackupFS ~]# su - bruce01
[bruce01@Titu-BackupFS ~]$ cat /tmp/userandpw.log
user:bruce01     password:277e5794
user:bruce02     password:e0ed3fdb
user:bruce03     password:1936a6d4
user:bruce04     password:dd10be6e
user:bruce05     password:842e552b
user:bruce06     password:ed8d2b54
user:bruce07     password:50da7bcf
user:bruce08     password:0463a374
user:bruce09     password:f29e9d10
user:bruce10     password:6e88cb6a
[bruce01@Titu-BackupFS ~]$ su - bruce02
Password:
[bruce02@Titu-BackupFS ~]$ exit
說明:批量建立用戶並生成隨機數密碼驗證併成功登陸!io

相關文章
相關標籤/搜索