一、单独抓取文件中ip地址,文件内容是
Mar 31 07:53:20 drserver2 spamdyke[27749]: ALLOWED from: [email]texn@baptiststandard.com[/email] to: [email]christina@terra.com.cn[/email] origin_ip: 71.229.51.19 origin_rdns: c-71-229-51-19.hsd1.ga.comcast.net auth: (unknown)
Mar 31 07:53:54 drserver2 spamdyke[27789]: DENIED_RDNS_RESOLVE from: [email]service@hichina.com[/email] to: [email]cs@terra.com.cn[/email] origin_ip: 115.29.253.214 origin_rdns: ip29.hichina.com auth: (unknown)
Mar 31 07:53:57 drserver2 spamdyke[27786]: DENIED_RDNS_MISSING from: npdcy3@[url]www.success-way.cn[/url] to: [email]christina@terra.com.cn[/email] origin_ip: 211.141.222.78 origin_rdns: (unknown) auth: (unknown)
Mar 31 07:54:36 drserver2 spamdyke[27805]: DENIED_RDNS_MISSING from: [email]ojdffhry98ghyghjg-fjkgh@gjrukg8fh.263.com[/email] to: [email]terrajob@terra.com.cn[/email] origin_ip: 120.83.163.110 origin_rdns: (unknown) auth: (unknown)
 
方法:
[root@test-linux tmp]# awk 'BEGIN{OFS="\n"}{for (i=1;i<=NF;i++) {print $i}}' zh.txt |grep '[1-9]\.[1-9]'
71.229.51.19
115.29.253.214
211.141.222.78
120.83.163.110
[root@test-linux tmp]#
 
(2)
文件t内容是
1 a
2 b
3 c
4 d
[root@test-linux tmp]# awk '{name[x++]=$2};END{for (i=0 ; i<=NR ; i++) print name[i]}' t
a
b
c
d
 
name[x++] 第一次$2域赋值到是“0”
 
[root@test-linux tmp]# awk '{name[x++]=$2};END{for (i=1 ; i<=NR ; i++) print name[i]}' t
b
c
d
[root@test-linux tmp]#

 
理解
 
[root@test-linux tmp]# awk '{name[$2]++};END{for (i in name) print i,name[i]}' t
a 1
b 1
c 1
d 1
[root@test-linux tmp]#
 
二、ftp
[root@ht root]# cat ftpaaa.sh
#!/bin/bash
hostname=192.168.1.238
user=f5
password=f5
ftp -i -v -n $hostname <<END_FTP
user $user $password
binary
lcd /tmp
cd /tmp
mput *
bye
END_FTP
 
 
注解:
1. -i 当传输多文件时关闭交互式提示 -n 不受.netrc文件的影响。(ftp默认为读取.netrc文件中的设定) -v 显示详细信息
2. << 是使用即时文件重定向输入。
3. END_FTP是即时文件的标志它必须成对出现,以标识即时文件的开始和结尾。
 
以下copy高人的ftp参数
FTP使用的内部命令如下(中括号表示可选项):

1.![cmd[args]]:在本地机中执行交互shell,exit回到ftp环境,如:!ls*.zip

2.$ macro-ame[args]: 执行宏定义macro-name。

3.account[password]: 提供登录远程系统成功后访问系统资源所需的补充口令。

4.append local-file[remote-file]:将本地文件追加到远程系统主机,若未指定远程系统文件名,则使用本地文件名。

5.ascii:使用ascii类型传输方式。
6.bell:每个命令执行完毕后计算机响铃一次。

7.bin:使用二进制文件传输方式。
8.bye:退出ftp会话过程。

9.case:在使用mget时,将远程主机文件名中的大写转为小写字母。

10.cd remote-dir:进入远程主机目录。

11.cdup:进入远程主机目录的父目录。

12.chmod mode file-name:将远程主机文件file-name的存取方式设置为mode,如:chmod 777 a.out。

13.close:中断与远程服务器的ftp会话(与open对应)。

14.cr:使用asscii方式传输文件时,将回车换行转换为回行。

15.delete remote-file:删除远程主机文件。

16.debug[debug-value]:设置调试方式, 显示发送至远程主机的每条命令,如:deb up 3,若设为0,表示取消debug。

17.dir[remote-dir][local-file]:显示远程主机目录,并将结果存入本地文件
18.disconnection:同close。

19.form format:将文件传输方式设置为format,缺省为file方式。

20.get remote-file[local-file]: 将远程主机的文件remote-file传至本地硬盘的local-file。

21.glob:设置mdelete,mget,mput的文件名扩展,缺省时不扩展文件名,同命令行的-g参数。

22.hash:每传输1024字节,显示一个hash符号(#)。

23.help[cmd]:显示ftp内部命令cmd的帮助信息,如:help get。
24.idle[seconds]:将远程服务器的休眠计时器设为[seconds]秒。

25.p_w_picpath:设置二进制传输方式(同binary)。

26.lcd[dir]:将本地工作目录切换至dir。

27.ls[remote-dir][local-file]:显示远程目录remote-dir, 并存入本地文件local-file。

28.macdef macro-name:定义一个宏,遇到macdef下的空行时,宏定义结束。
29.mdelete[remote-file]:删除远程主机文件。
30.mdir remote-files local-file:与dir类似,但可指定多个远程文件,如 :mdir *.o.*.zipoutfile 。

31.mget remote-files:传输多个远程文件。

32.mkdir dir-name:在远程主机中建一目录。

33.mls remote-file local-file:同nlist,但可指定多个文件名。
34.mode[modename]:将文件传输方式设置为modename, 缺省为stream方式。
35.modtime file-name:显示远程主机文件的最后修改时间。

36.mput local-file:将多个文件传输至远程主机。

37.newer file-name: 如果远程机中file-name的修改时间比本地硬盘同名文件的时间更近,则重传该文件。
38.nlist[remote-dir][local-file]:显示远程主机目录的文件清单,并存入本地硬盘的local-file。
39.nmap[inpattern outpattern]:设置文件名映射机制, 使得文件传输时,文件中的某些字符相互转换, 如:nmap $1.$2.$3[$1,$2].[$2,$3],则传输文件a1.a2.a3时,文件名变为a1,a2。 该命令特别适用于远程主机为非UNIX机的情况。
40.ntrans[inchars[outchars]]:设置文件名字符的翻译机制,如ntrans1R,则文件名LLL将变为RRR。

41.open host[port]:建立指定ftp服务器连接,可指定连接端口。

42.passive:进入被动传输方式。

43.prompt:设置多个文件传输时的交互提示。

44.proxy ftp-cmd:在次要控制连接中,执行一条ftp命令, 该命令允许连接两个ftp服务器,以在两个服务器间传输文件。第一条ftp命令必须为open,以首先建立两个服务器间的连接。
45.put local-file[remote-file]:将本地文件local-file传送至远程主机。
46.pwd:显示远程主机的当前工作目录。

47.quit:同bye,退出ftp会话。

48.quote arg1,arg2...:将参数逐字发至远程ftp服务器,如:quote syst.
49.recv remote-file[local-file]:同get。

50.reget remote-file[local-file]:类似于get, 但若local-file存在,则从上次传输中断处续传。

51.rhelp[cmd-name]:请求获得远程主机的帮助。

52.rstatus[file-name]:若未指定文件名,则显示远程主机的状态, 否则显示文件状态。

53.rename[from][to]:更改远程主机文件名。

54.reset:清除回答队列。

55.restart marker:从指定的标志marker处,重新开始get或put,如:restart 130。
56.rmdir dir-name:删除远程主机目录。

57.runique:设置文件名只一性存储,若文件存在,则在原文件后加后缀.1, .2等。

58.send local-file[remote-file]:同put。

59.sendport:设置PORT命令的使用。

60.site arg1,arg2...:将参数作为SITE命令逐字发送至远程ftp主机。

61.size file-name:显示远程主机文件大小,如:site idle 7200。

62.status:显示当前ftp状态。

63.struct[struct-name]:将文件传输结构设置为struct-name, 缺省时使用stream结构。

64.sunique:将远程主机文件名存储设置为只一(与runique对应)。

65.system:显示远程主机的操作系统类型。

66.tenex:将文件传输类型设置为TENEX机的所需的类型。

67.tick:设置传输时的字节计数器。

68.trace:设置包跟踪。

69.type[type-name]:设置文件传输类型为type-name,缺省为ascii,如:type binary,设置二进制传输方式。

70.umask[newmask]:将远程服务器的缺省umask设置为newmask,如:umask 3

71.user user-name[password][account]:向远程主机表明自己的身份,需要口令时,必须输入口令,如:user anonymous my@email。