AIX系统中shell脚本的编写

本文详细介绍了Shell脚本的基础知识,包括脚本的编写、分析和实例应用。通过示例展示了如何使用Shell脚本从多台服务器获取OS级别信息、执行FTP文件传输以及实现自动化登录和文件操作。此外,还提供了功能性脚本实例,如读取文件、计算数字、用户管理和网络探测。
摘要由CSDN通过智能技术生成

初识shell脚本

如下脚本代码:如果需要从多个服务器拉取信息,而不希望分别登录到各个服务器,可以编写一段基本的 shell 脚本来执行该功能。如下示例是一段报告 OS 级别的简单脚本:

#!/bin/sh
#Variables
_list_of_servers="mars earth saturn jupiter"
# Main Code
for _server in $_list_of_servers
do
  echo "$_server OS Level:"
  ssh $_server "oslevel -s"
  echo "\n"
done

现在,此脚本将结束运行并从多个服务器报告 OS 级别:mars、earth、saturn 和 jupiter。如果运行脚本 ./script.sh,将获得以下输出:

mars
6100-06-04-1112
 
earth
6100-06-04-1112
 
saturn
6100-06-04-1112
 
jupiter
6100-06-04-1112

shell脚本的编写分析

现在逐行分析一下该脚本:

#!/bin/sh

该脚本一直是任何脚本的第一部分。它被称为 “shebang” 行。这告诉系统下面将如何解释该脚本,通常就是告诉系统下面将使用哪些 shell,#!这行的意思是说,把下面的字符统统传递给/bin/sh。这很重要,因为每个 shell 都有所不同。这里使用了 /bin/sh,它只是一个 Bourne shell。使用此 shell 是因为它使代码可以兼容不同的 OS 类型。AIX 默认情况下会使用 Korn shell,而大部分 Linux 版本默认也使用 Bourne shellBourne shell 是一个适用于大部分 UNIX OS 的常用 shell。
(请注意,所有以井号 (#) 开头的内容都是一条注释,不会执行。)

_list_of_servers="mars earth saturn jupiter"

这是一个变量。在 shell 脚本中,这些声明类似于变量=某个东西。变量名显示在等号左侧,该变量的内容位于右侧。在此情况下,变量是一个包含 4 个服务器名称的字符串。

for _server in $_list_of_servers

这是非常重要的一行,因为它是 “for 循环” 的开始。如果脚本是一辆车,那么 for 循环就是发动机。以下是 for 循环的语法:

for _NEW_VARIABLE in SUPPLIED_CONDITION

每一部分解释如下:_NEW_VARIABLE 可以是想要的任何东西,例如 “x”“variable”。正确的编程实践是将它命名为描述下面将做的事情的表达式。在此示例中,将它命名为 _server,因为它表示变量 $_list_of_server 的一次迭代。可以将 _NEW_VARIABLE 视为一个临时空间。SUPPLIED_CONDITION 表示内容,它向循环提供数据。同样使用汽车作为类比,这将是为发动机提供动力的燃油。在示例中,该变量为 $_list_of_servers。所以当脚本执行时,它实际表达的含义是:

for _server in mars earth saturn jupiter

归纳一下:在第一次循环迭代中,变量 _server 将为 mars,在第二次循环迭代中,它将为 earth,依此类推。

do

形象一点的说,现在已启动了发动机并踏下了油门,下一个逻辑步骤是说,“执行以下操作”。

echo "$_server OS Level:"

这一行是标签。它将在返回 OS 级别之前打印服务器的名称。这样,我们将知道哪个 OS 级别属于哪台服务器。

ssh $_server "oslevel -s"

这是脚本的内容。它使用 SSH 登录到服务器,运行 oslevel -s 命令并将它返回到屏幕上。如果没有设置 SSH 键,那么必须输入一个密码。

echo "\n"

这只是在 OS 级别后放置了一个空行。这样做只是为了保持美观,条理很清晰。

done

最后一行关闭循环。
以上这是一个简单的 shell 脚本。从基础层面上讲,shell 脚本只是系统命令。所以在练习编写 shell 脚本的时候,还会不断充实有关系统和系统命令的知识。

shell脚本的编写实例

一、AIX主机下用SHELL脚本编写FTP传某个目录下的文件到LINUX主机
ftp_backup_to_remote.sh

#!/usr/bin/ksh
ftp -n<<!
open 192.168.89.10
user oracle oracle
binary
cd /backup/exp/operation
lcd /backup/exp
prompt
mput *
close
bye
EOF

二、Linux下使用Shell脚本向FTP服务器上传或下载一个文件
ftpput.sh

#!/bin/sh      
#FileName:ftpput.sh   
#Function:从本地客户端向ftp服务器上传一个文件     
#Version:V1.0    
#Author:galton    
#Date:2020-09-20
	
#$#表示传递给此Shell脚本的参数个数
#-lt表示小于
#-eq表示等于
#-ne表示不等于
if [ $# -ne 2  ] 
then
	echo "Usage $0  <local_dir/filename> <remote_dir>" 
	exit 1
fi	
 
#IP表示ftp的服务器ip地址
#IP=127.0.0.1  
IP=192.168.6.1
 
#FULLNAME获取本地文件全路径名
FULLNAME=$1
 
#DESTDIR获取需要上传的ftp远程目录路径
DESTDIR=$2
 
#basename返回一个路径中的文件名部分
#如FULLNAME="/home/Proj/log/test.log"; 
#当local_filename=`basename $FULLNAME`
#最终local_filename="test.log"
local_filename=`basename $FULLNAME`
 
#DESTFILE表示ftp服务器的路径,以及保存后的文件名
DESTFILE=$DESTDIR/$local_filename 
 
#-i表示在多个文件传输期间关闭交互提示
#-n表示禁止自动登录到初始连接
#<<FTPIT 和最后的 FTPIT:术语叫:当前文档here documents. here document 就是一段特殊目的的代码块,
#它使用I/O重定向的形式来将一个命令序列传递到一个交互程序或者命令中,比如ftp、cat,或者ex文本编辑器.
#本句可以理解从<<FTPIT开始以非对话模式的ftp连接,直到输入FTPIT为止的所有命令.
#当然FTPIT这个名字是可以随便取的,不一定必须是FTPIT,可以取其它的名字。
#ftp -i -n $IP <<FTPIT
ftp -i -n <<FTPIT
 
#连接到指定ftp服务器上
open $IP
#连接到指定ftp服务器上,并指定端口
#open $IP $PORT
 
#登陆ftp服务器上的用户名和密码
#user username password
user galton galton
 
#bin表示以二进制方式传输
#bin等价于bi,binary等
#另一种方式传输是ascii,默认情况下,将文件传输类型设置为ASCII
bin
 
#主动模式的FTP是指服务器主动连接客户端的数据端口,被动模式的FTP是指服务器被动地等待客户端连接自己的数据端口 
#被动模式的FTP通常用在处于防火墙之后的FTP客户访问外界FTP服务器的情况.
#因为在这种情况下,防火墙通常配置为不允许外界访问防火墙之后主机,而只允许由防火墙之后的主机发起的连接请求通过.
#因此在这种情况下不能使用主动模式的FTP传输,而被动模式的FTP可以良好的工作.
#passive表示设置为被动模式的FTP
passive
 
#cd表示更改ftp服务器上(即远程计算机)的工作目录
cd /home/remote/log/ftpfile
 
#lcd表示更改本地计算机的工作目录
#lcd /home/Proj/log/

#put local_file [ remote_file ]
#其中local_file是指定要复制的本地文件,remote_file是指定要复制的远程计算机上的文件名,
#remote_file为可选项,如果不指定的话是和本地计算机上的文件名同名.
#put表示把本地路径下的文件复制到FTP服务器(远程计算机)上设置的路径下的文件
put $FULLNAME $DESTFILE
 
#quit表示结束与远程计算机的FTP会话,并退出FTP.
#还有个等价的命令为bye(或by)结束与远程计算机的FTP会话并退出FTP
quit
 
#here document块结束
FTPIT
 
#正式写这个Shell脚本时,here document中的#和空行都会执行,
#所以为了消除警告最好去掉here document块中#开头的语句以及空行
exit 0

ftpget.sh

#!/bin/sh      
#FileName:ftpget.sh   
#Function:从ftp服务器上下载一个文件到本地计算机上    
#Version:V1.0      
#Author:galton     
#Date:2020-09-20
	
#$#表示传递给此Shell脚本的参数个数
#-ne表示不等于
if [ $# -ne 2  ] 
then
	echo "Usage $0  <remote_dir/filename> <local_dir>" 
	exit 1
fi	
 
#IP表示ftp的服务器ip地址
IP=127.0.0.1  
#IP=192.168.6.1
 
#FULLNAME获取从ftp服务器上下载的文件全路径名
FULLNAME=$1
 
#DESTDIR获取从ftp服务器上下载的文件所存放的本地计算机的目录路径
DESTDIR=$2
 
#remote_filename获取从ftp服务器上下载的文件名
remote_filename=`basename $FULLNAME`
 
#DESTFILE表示下载文件所存放的本地路径,以及本地保存后的文件名
DESTFILE=$DESTDIR/$remote_filename 
 
#ftp -i -n $IP <<FTPIT
ftp -i -n <<FTPIT
open $IP
user galton galton
bin
cd /home/remote/log/ftpfile
get $FULLNAME $DESTFILE
quit
FTPIT
exit 0
 
#get remote_file [ local_file ]
#remote_file是指定要复制的文件,local_file是指定本地计算机上的文件名,
#local_file为可选项,没有指定的话则跟remote_file同名。

三、ftp自动批量下载文件

  1. ftp自动登录批量下载文件。
    从ftp服务器上的/home/data 到 本地的/home/databackup
#!/bin/sh
ftp -n<<!
open 192.168.1.171
user guest 123456
binary
cd /home/data
lcd /home/databackup
prompt
mget *
close
bye
!
  1. ftp自动登录上传文件。
    本地的/home/databackup to ftp服务器上的/home/data
#!/bin/sh
ftp -n<<!
open 192.168.1.171
user guest 123456
binary
hash
cd /home/data
lcd /home/databackup
prompt
mput *
close
bye
!
  1. ftp自动登录下载单个文件。
    ftp服务器上下载/home/data/a.sh 到 local /home/databackup
#!/bin/sh
ftp -n<<!
open 192.168.1.171
user guest 123456
binary
cd /home/data
lcd /home/databackup
prompt
get a.sh a.sh
close
bye
!
  1. ftp自动登录上传单个文件。
    把本地/home/databachup/a.sh 上传到 ftp /home/databackup 下
#!/bin/sh
ftp -n<<!
open 192.168.1.171
user guest 123456
binary
cd /home/data
lcd /home/databackup
prompt
put a.sh a.sh
close
bye
!

四、功能性shell脚本实例
实例一:写一个脚本
1.设定变量file的值为/etc/passwd
2.使用循环读取文件/etc/passwd的第2,4,6,10,13,15行,并显示其内容
3.把这些行保存至/tmp/mypasswd文件中

   #!/bin/bash
   file="/etc/passwd"
   for I in 2 4 6 10 13 15
   do
   exec 3>/tmp/mypasswd
   line=`head -$I $file | tail -1`
   echo "$line"
   echo "$line" >&3
   exec 3>&-
   done

实例二:写一个脚本
传递两个整数给脚本,让脚本分别计算并显示这两个整数的和,差,积,商。 test.sh

 #!/bin/bash
 echo "first number $1"  (表示输出第一个数)
 echo "second number $2" (表示输出第二个数)
 echo " $(($1+$2))"      (输出两数之和)
 echo "$[$1-$2]"         (输出两数之差)
 echo "$[$1*$2]"         (输出两数之积)
 echo "$[$1/$2]"         (输出两数之商)
 chmod +x test.sh       (给test.sh执行的权限)
 ./test.sh 2 3          (传递两个参数并执行脚本     

实例三:写一个脚本
添加10个用户user1到user10,但要求只有用户不存在的情况下才能添加:

   #!/bin/bash
   for I in `seq 1 10`
   do
   cut -d: -f1 /etc/passwd |grep "user$I" 2>>/tmp/etc.err || useradd user$I
   done

实例四:写一个脚本
通过ping命令测试192.168.0.151到192.168.0.254之间的所有主机是否在线,如果在线,就显示“ip is up”,如果不在线,就显示“ip is down”:

#!/bin/bash
for I in `seq 151 254`
do
ping -c1 -w1 192.168.0.$I &>/dev/null && echo "192.168.0.$I is up" ||        
echo "192.168.0.$I is down"
done 

实例五:网银部署脚本
deploy_perbank_20200922.sh(个人网银部署脚本)

/usr/IBM/WebSphere/Appserver/profiles/AppSrv01/bin/wsadmin.sh -c '$AdminApp update perbank partialapp {-operation addupdate -update.ignore.old -contents /home/ebank/20200922/patch-20200922-perbank.zip}'

wsadmin.sh

#!/bin/sh
binDir=`dirname ${0}`
. ${binDir}/setupCmdLine.sh
${WAS_HOME}/bin/wsadmin.sh "$@"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值