Linux shell脚本练习
- 一、编写脚本实现登陆远程主机。(使用expect和shell脚本两种形式)
- 二、生成10个随机数保存于数组中,并找出其最大值和最小值
- 三、输入若干个数值存入数组中,采用冒泡算法进行升序或降序排序
- 四、编写脚本,使用for和while分别实现192.168.0.0/24网段内,地址是否能够ping通,若ping通则输出"success!",若ping不通则输出"fail!"
- 五、每周的工作日1:30,将/etc备份至/backup目录中,保存的文件名称格式 为“etcbak-yyyy-mm-dd-HH.tar.xz”,其中日期是前一天的时间
- 六、查看系统负载的几种命令,总结top命令的指标大概什么含义
一、编写脚本实现登陆远程主机。(使用expect和shell脚本两种形式)
[root@localhost ~]# cat auto_login_expect
#!/bin/expect
set ip 192.168.1.118
set user root
set password 123456
set timeout 15
spawn ssh $user@$ip
expect {
"yes/no" {
send "yes\n"; exp_continue }
"password" {
send "$password\n" }
}
interact
[root@localhost ~]# expect auto_login_expect
spawn ssh root@192.168.1.30
The authenticity of host '192.168.1.30 (192.168.1.30)' can't be established.
ECDSA key fingerprint is SHA256:td1/tqC4WTpifU86hM76rYi9en5DtfSBICpCBdoj/pw.
ECDSA key fingerprint is MD5:31:b4:9c:d6:b9:61:1c:5b:6d:23:23:d7:32:f9:1a:91.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '192.168.1.30' (ECDSA) to the list of known hosts.
root@192.168.1.30's password:
Last login: Fri Feb 11 22:57:37 2022
[root@study ~]# exit
logout
Connection to 192.168.1.30 closed.
[root@localhost ~]# expect auto_login_expect
spawn ssh root@192.168.1.30
root@192.168.1.30's password:
Last login: Fri Feb 11 22:58:42 2022 from 192.168.1.31
[root@study ~]#
[root@localhost ~]# cat remotelogin.sh
#!/bin/bash
IP=$1
USER=$2
PASSWORD=$3
sshpass -p $PASSWORD ssh -o StrictHostKeyChecking=no $USER@$IP
[root@localhost ~]# bash remotelogin.sh 192.168.1.30 root 123456
Last login: Fri Feb 11 23:42:12 2022 from 192.168.1.31
[root@study ~]#
[root@study ~]# hostname -I
192.168.1.30
[root@study ~]#
二、生成10个随机数保存于数组中,并找出其最大值和最小值
思想:使用RANDOM生成10个数放在数组中,把数组中的第一个数作为最大值(变量:max),也做为最小值(变量:min)。
然后取数组中的第二个和第一个数做比较,如果大于第一个数,则赋值为max,如果小于第一个数则保持第一个数为最大值;
同时,数组中的第二个和第一个数做比较,如果小于第一个数,则赋值为mix,如果大于第一个数则min保持第一个数为最小值
依照此法,一直到数组中最后一个数(即数组小标为9的数)的比较完成,就可得出最大值和最小值。
[root@felix ~]