shell编程练习(二): 笔试11-20

时间:2023-03-08 18:15:03
shell编程练习(二): 笔试11-20

笔试练习(二):

11、写一个shell脚本来得到当前的日期,时间,用户名和当前工作目录。

[root@VM_0_5_centos test]# vi 11.sh
[root@VM_0_5_centos test]# cat 11.sh
#!/bin/bash
echo "Hello, $LOGNAME"
echo "Current date is `date`"
echo "User is `who i am`"
echo "Current directory `pwd`"
[root@VM_0_5_centos test]# sh 11.sh
Hello, root
Current date is Tue Jul 24 11:35:23 CST 2018
User is root pts/0 2018-07-24 11:34 (222.211.249.187)
Current directory /test

12、编写shell脚本获取本机的网络地址。

[root@VM_0_5_centos ~]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.27.0.5 netmask 255.255.240.0 broadcast 172.27.15.255
ether 52:54:00:34:12:97 txqueuelen 1000 (Ethernet)
RX packets 18464043 bytes 1387072767 (1.2 GiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 1111041544 bytes 1128965265141 (1.0 TiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
loop txqueuelen 1 (Local Loopback)
RX packets 343083420 bytes 34242325784 (31.8 GiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 343083420 bytes 34242325784 (31.8 GiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 [root@VM_0_5_centos test]# vi 12.sh
[root@VM_0_5_centos test]# cat 12.sh
#!/bin/bash
#This script print ip and network IP=`ifconfig eth0 | grep 'inet ' | sed 's/^.*inet//g'| sed 's/ netmask.*$//g'`
NETMASK=`ifconfig eth0 | grep 'inet '| sed 's/^.*netmask//g' | sed 's/broadcast.*$//g'`
echo "IP is $IP"
echo "NETMASK is $NETMASK"
exit 0 [root@VM_0_5_centos test]# sh 12.sh
IP is 172.27.0.5
NETMASK is 255.255.240.0

13、编写个shell脚本将当前目录下大于10K的文件转移到/tmp目录下:

[root@VM_0_5_centos test]# vi 13.sh
[root@VM_0_5_centos test]# cat 13.sh
#/bin/bash # Using for move currently directory lt 10k file to /tmp for FileName in `ls -l | awk '$5>10240 {print $9}'`; do
mv $FileName /tmp
done ls -al /tmp echo "Done! "

14、编写一个名为myfirstshell.sh的脚本,它包括以下内容:

a) 包含一段注释,列出您的姓名、脚本的名称和编写这个脚本的目的。
b) 问候用户。
c) 显示日期和时间。
d) 显示这个月的日历。
e) 显示您的机器名。
f) 显示当前这个操作系统的名称和版本。
g) 显示父目录中的所有文件的列表。
h) 显示root正在运行的所有进程。
i) 显示变量TERM、PATH和HOME的值。
j) 显示磁盘使用情况。
k) 用id命令打印出您的组ID。
m) 跟用户说“Good bye”
[root@VM_0_5_centos test]# vi 14.sh
[root@VM_0_5_centos test]# cat 14.sh
#!/bin/bash user=`whoami`
case $user in
root)
echo "hello root";;
mmzs)
echo "hello mmzs";;
*)
echo "hello $user,welcome"
esac echo "日期和时间: `date`"
echo "本月的日历: `cal`"
echo "本机的机器名:`uname -n`"
echo "当前这个操作系统的名称和版本:`uname -s;uname -r`"
echo "变数TERM的值:$TERM"
echo "变数PATH的值:$PATH"
echo "变数HOME的值:$HOME"
echo "磁盘的使用情况:`df`"
echo "用id命令打印出你的组ID:`id -g`"
echo "root正在运行的所有进程:` ps -u root`"
echo "父目录中的所有文件的列表:`ls ../`"
echo "Good bye!"
exit 0 [root@VM_0_5_centos test]# sh 14.sh
hello root
日期和时间: Thu Jul 26 14:40:40 CST 2018
本月的日历: July 2018
Su Mo Tu We Th Fr Sa
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
本机的机器名:VM_0_5_centos
当前这个操作系统的名称和版本:Linux
3.10.0-693.el7.x86_64
变数TERM的值:xterm
变数PATH的值:/usr/local/mongodb3.0.6/bin:/usr/local/node/8.11.2/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/software/jdk1.7.0_79/bin:/software/jdk1.7.0_79/lib:/root/bin
变数HOME的值:/root
磁盘的使用情况:Filesystem 1K-blocks Used Available Use% Mounted on
/dev/vda1 51474024 45832784 3335164 94% /
devtmpfs 932328 0 932328 0% /dev
tmpfs 941808 24 941784 1% /dev/shm
tmpfs 941808 384 941424 1% /run
tmpfs 941808 0 941808 0% /sys/fs/cgroup
tmpfs 188364 0 188364 0% /run/user/0
用id命令打印出你的组ID:0
root正在运行的所有进程: PID TTY TIME CMD
1 ? 00:00:15 systemd
2 ? 00:00:00 kthreadd
3 ? 00:02:05 ksoftirqd/0
5 ? 00:00:00 kworker/0:0H
……等等 父目录中的所有文件的列表:bin
boot
data
dev
etc
home
install
lib
lib64
opt
proc
root
run
sbin
……等等 Good bye!

15、文件移动拷贝,有m1.txt m2.txt m3.txt m4.txt,分别创建出对应的目录,m1 m2 m3 m4 并把文件移动到对应的目录下。

[root@VM_0_5_centos test]# vi 15.sh
[root@VM_0_5_centos test]# cat 15.sh
#!/bin/bash
touch m1.txt m2.txt m3.txt m4.txt
I=1 while [ $I -le 4 ]; do
mkdir m$I
mv m$I.txt m$I
I=$((I+1))
done [root@VM_0_5_centos test]# sh 15.sh
[root@VM_0_5_centos test]# ll
total 32
-rw-r--r-- 1 root root 128 Jul 26 14:05 11.sh
-rw-r--r-- 1 root root 271 Jul 26 14:15 12.sh
-rw-r--r-- 1 root root 635 Jul 26 14:40 14.sh
-rw-r--r-- 1 root root 131 Jul 26 15:03 15.sh
drwxr-xr-x 2 root root 4096 Jul 26 15:03 m1
drwxr-xr-x 2 root root 4096 Jul 26 15:03 m2
drwxr-xr-x 2 root root 4096 Jul 26 15:03 m3
drwxr-xr-x 2 root root 4096 Jul 26 15:03 m4
[root@VM_0_5_centos test]# cd m1/
[root@VM_0_5_centos m1]# ll
total 0
-rw-r--r-- 1 root root 0 Jul 26 15:03 m1.txt

16、root用户今天登陆了多长时间?

[root@VM_0_5_centos m1]# vi 16.sh
[root@VM_0_5_centos m1]# cat 16.sh
#! /bin/sh cat /proc/uptime| awk -F. '{run_days=$1 / 86400;run_hour=($1 % 86400)/3600;run_minute=($1 % 3600)/60;run_second=$1 % 60;printf("系统已运行:%d天%d时%d分%d秒\n",run_days,run_hour,run_minute,run_second)}'
[root@VM_0_5_centos m1]# sh 16.sh
系统已运行:1天21时53分19秒

17、终端输入一个文件名,判断是否是设备文件?

[root@VM_0_5_centos test]# vi 17.sh
[root@VM_0_5_centos test]# cat 17.sh
#/bin/bash echo -e "The program will Judge a file is or not a device file.\n\n"
read -p "Input a filename:" filename
if [ -b $filename -o -c $filename ]; then
echo "$filename is a device file"
exit 0
else
echo "$filename is not a device file"
exit 1
fi

18、统计IP访问:要求分析apache访问日志,找出访问页面数量在前100位的IP数。日志大小在78M左右。

以下是apache的访问日志节选:

202.101.129.218 - - [26/Mar/2006:23:59:55 +0800] "GET /online/stat_inst.php?pid=d065 HTTP/1.1" 302 20-"-" "-" "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)"
[root@VM_0_5_centos test]# mkdir -p 18
[root@VM_0_5_centos test]# mv 18.sh access.log 18
[root@VM_0_5_centos test]# cd 18 [root@VM_0_5_centos 18]# vi 18.sh
[root@VM_0_5_centos 18]# cat 18.sh
#! /bin/bash # $1 为要测试的日志文件
awk '{print $1}' $1 | sort | uniq -c | sort -k1nr | head -n3
[root@VM_0_5_centos 18]# ll
total 20
-rw-r--r-- 1 root root 108 Aug 6 14:58 18.sh
-rw-r--r-- 1 root root 14372 May 20 2015 access.log
[root@VM_0_5_centos 18]# cat access.log
192.168.1.108 - - [23/Dec/2014:06:56:49 +0800] "GET / HTTP/1.1" 200 612 "-" "curl/7.22.0 (i686-pc-linux-gnu) libcurl/7.22.0 OpenSSL/1.0.1 zlib/1.2.3.4 libidn/1.23 librtmp/2.3"
省略更多访问记录…… [root@VM_0_5_centos 18]# sh 18.sh access.log
34 127.0.0.1
16 192.168.1.108
13 192.168.6.254
[root@VM_0_5_centos 18]#

19、设计一个Shell程序,在/userdata目录下建立50个目录,即user1~user50,并设置每个目录的权限,其中其他用户的权限为:读;文件所有者的权限为:读、写、执行;文件所有者所在组的权限为:读、执行。

[root@VM_0_5_centos test]# mkdir -p 19
[root@VM_0_5_centos test]# cd 19
[root@VM_0_5_centos 19]# vi 19.sh
[root@VM_0_5_centos 19]# cat 19.sh
#!/bin/bash
# 需要root权限
echo "create /test/19/tset"
#为方便测试,将/userdata目录修改为/test/19/tset
mkdir /test/19/tset if [ $? -eq 0 ]; then
i=1
while [ $i -le 50 ]; do
mkdir -p /test/19/test/user$i
chmod 754 /test/19/test/user$i
let i++
done
else
echo "bye"
exit 1
fi exit 0 [root@VM_0_5_centos 19]# sh 19.sh
create /usrdata
[root@VM_0_5_centos 19]# cd /test/19/test
[root@VM_0_5_centos test]# ll
total 200
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user1
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user10
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user11
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user12
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user13
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user14
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user15
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user16
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user17
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user18
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user19
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user2
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user20
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user21
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user22
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user23
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user24
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user25
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user26
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user27
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user28
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user29
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user3
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user30
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user31
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user32
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user33
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user34
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user35
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user36
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user37
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user38
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user39
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user4
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user40
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user41
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user42
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user43
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user44
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user45
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user46
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user47
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user48
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user49
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user5
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user50
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user6
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user7
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user8
drwxr-xr-- 2 root root 4096 Aug 6 15:03 user9
[root@VM_0_5_centos test]#

20、设计一个shell程序,添加一个新组为class1,然后添加属于这个组的30个用户,用户名的形式为stdxx,其中xx从01到30,并设置密码为对应的stdxx。

[root@VM_0_5_centos test]# vi 20.sh
[root@VM_0_5_centos test]# cat 20.sh
#!/bin/bash
#设计一个shell程序,添加一个新组为class1,然后添加属于这个组的30个用户,用户名的形式为stdxx,其中xx从01到30。
#请 su root 或者 sudo su 变成root用户 groupadd class1
for i in {9901..9930}; do
xx=`echo $i | sed 's/99//g'`
useradd -g class1 -s /bin/bash -d /home/std$xx -m std$xx
echo -e "std$xx\nstd$xx" | passwd std$xx
echo -e "user std$xx password is std$xx" >> /root/newuser.txt
done

获取脚本

注:所有脚本均可通过关注右侧公众号,后台回复"shell编程练习"获取百度网盘链接。