本文主要是介绍linux文本分析工具grep、sed和awk打印输出文本的单双奇偶行(grep也可以打印奇偶行)以及熟悉的ssh命令却有你不知道的一些用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一、linux文本分析工具grep、sed和awk打印输出文本的单双奇偶行(grep也可以打印奇偶行)
其实sed和awk要打印输出奇偶行是很容易的事情,不过只能使用grep来输出奇偶行的话怎么实现呢?今天我就想了一下,如果真的只能使用grep来输出奇偶行的话,能不能实现?怎么实现?当然这个只当玩玩了,毕竟有awk和sed,用grep来实现的必要性不大。
如果你不看这篇文章,你可以先自己想想怎么实现?我刚才也开始想这事,开始我觉得好像没法实现,但是我又想只有想不到,没有做不到。于是我真花了几秒钟想了一下,确实可以实现,实现如下:做了一个测试文件testnum.txt共计12行文本,使用grep打印输出奇偶行如下:
[online@G18 ~]$ cat testnum.txt 35606 1discover31534 2index1119 3yestest2136 4someuser3211 T9330+21 RACCUA111 P11HD321 4Gkermit 007kermit 007.cn
007cn 007.cn
007cn www.007.cn
#grep直接打奇偶行好像行不能,因为选项属性里没有直接的奇偶判断逻辑,可以换一个想法:
[online@G18 ~]$ grep -n '' testnum.txt | grep '[24680]:'
2: 31534 2index
4: 2136 4someuser
6: 21 RACCUA
8: 321 4G
10: kermit 007.cn
12:007cn www.007.cn
#这样便匹配出了偶数行
[online@G18 ~]$ grep -n '' testnum.txt | grep '[24680]:' | grep -o -E '[^:]*$'31534 2index2136 4someuser21 RACCUA321 4Gkermit 007.cn
007cn www.007.cn
#这样便匹配出了奇数行
[online@G18 ~]$ grep -n '' testnum.txt | grep '[13579]:' | grep -o -E '[^:]*$' 35606 1discover1119 3yestest3211 T9330+111 P11HDkermit 007
007cn 007.cn
对于awk,sed来说,匹配出奇偶行那是awk,sed的长项了。比如使用awk可以有多种方法来匹配。比如使用行记录号NR来判断,也可以使用自增变量来判断。
#通过NR值对2求余判断取奇数行
[online@G18 ~]$ awk 'NR%2' testnum.txt 35606 1discover1119 3yestest3211 T9330+111 P11HDkermit 007
007cn 007.cn
#下面这条命令取反,即是取的偶数行
[online@G18 ~]$ awk '!(NR%2)' testnum.txt
#使用自增计算来判断奇偶行,如下取偶数行:
[online@G18 ~]$ awk 'i++%2' testnum.txt 31534 2index2136 4someuser21 RACCUA321 4Gkermit 007.cn
007cn http://47.93.183.36
#如下则为取奇数行
[online@G18 ~]$ awk '!(i++%2)' testnum.txt
#换一个写法,使用++i来试一下,如下取的是奇数行
[online@G18 ~]$ awk '++i%2' testnum.txt 35606 1discover1119 3yestest3211 T9330+111 P11HDkermit 007
007cn 007.cn
#相反这取的就是偶数行
[online@G18 ~]$ awk '!(++i%2)' testnum.txt
#上面所有的写法里都省略了{print $0}部分,因为这是默认的,实际和下面的命令意义一样。
[online@G18 ~]$ awk '!(++i%2) {print $0}' testnum.txt
对于sed命令,使用起来也是一样方便。sed命令中使用-n 1,2p(表示取第1到第2行)也可以使用1,+2p(从第一行和后面的2行)还有一种用法是1~2p(表示从第一行开始,每2行输出),即~表示步长的意义,后面的值即是步长的值。三者的示例如下:
[online@G18 ~]$ sed -n 1,2p testnum.txt 35606 1discover31534 2index
[online@G18 ~]$ sed -n 1,+2p testnum.txt 35606 1discover31534 2index1119 3yestest
[online@G18 ~]$ sed -n 1~2p testnum.txt 35606 1discover1119 3yestest3211 T9330+111 P11HDkermit 007
007cn 007.cn
二、熟悉的ssh命令却有你不知道的一些用法
ssh命令是openssh套件中的客户端连接工具,可以给予ssh加密协议实现安全的远程登录服务器。一般系统都已装好,如果没有,使用以下安装(centos),如果ssh登录时出现问题在排除其它网络权限问题的情况下可以考虑重装ssh,相关命令如下:
#安装ssh
[root@kur15z ~]# yum install -y openssh-server openssh-clinets
#删除重装ssh
[root@kur15z ~]# yum remove openssh*;rm -rf /etc/ssh*;yum install -y openssh*;systemctl start sshd.service
ssh命令用法: ssh 选项 参数 , 其中可用选项如下:
-1:强制使用ssh协议版本1;
-2:强制使用ssh协议版本2;
-4:强制使用IPv4地址;
-6:强制使用IPv6地址;
-A:开启认证代理连接转发功能;
-a:关闭认证代理连接转发功能;
-b:使用本机指定地址作为对应连接的源ip地址;
-C:请求压缩所有数据;
-F:指定ssh指令的配置文件;
-f:后台执行ssh指令;
-g:允许远程主机连接主机的转发端口;
-i:指定身份文件;
-l:指定连接远程服务器登录用户名;
-N:不执行远程指令;
-o:指定配置选项;
-p:指定远程服务器上的端口;
-q:静默模式;
-X:开启X11转发功能;
-x:关闭X11转发功能;
-y:开启信任X11转发功能。
#参数一般是远程主机以及执行指令
远程主机:指定要连接的远程ssh服务器;
指令:要在远程ssh服务器上执行的指令,但注意如果有指令,ssh不会跳至远程机器,执行完后会仍在本机。
#使用示例如下:
[root@kur15z ~]# ssh 114.215.80.214
Last login: Tue Sep 25 13:58:44 2018 from 124.212.96.19
Kermit: 114.215.80.214 快捷命令如下:
Welcome to server:80.214
[root@kur15z ~]#
如果注意以上命令会发现,在使用ssh的时候,并没有提示输入密码,对,这就是已经实现了ssh免密跳转,和之前这篇文章里的实现是一样的:(可在本博客中通过搜索相关文章:rsync通过ssh的文件同步传输以及免密码传输的实现 ) 即是在本机执行ssh-keygen -t rsa 命令得到id_rsa.pub文件并将此文件放至目标机器/用户/.ssh/authorized_keys中即可(注意此文件权限)。这里可以使用ssh-copy-id命令,它可将本机的公钥直接复制到远程机器的authorized_keys文件中,ssh-copy-id也能让你有到远程机器的/home/username/.ssh和~/.ssh/authorized_keys的权利。
在上面的ssh命令选项中,常用的选项也就是-l和-p了,分别用于指定ssh登录的用户和端口,如ssh -l hello -p 20001 114.215.80.214即表示使用用户hello登录服务器的20001端口,默认不写时用的就是root用户,另外也可以使用@写法。如下:
#使用用户hello登录服务器的20001端口
ssh -l hello -p 20001 114.215.80.214
ssh -p 20001 hello@ 114.215.80.214
#默认就是root用户和22端口,所以以下写法功能是一样的
[root@kur15z ~]#ssh 114.215.80.214
[root@kur15z ~]#ssh root@114.215.80.214
[root@kur15z ~]#ssh -p 22 root@114.215.80.214
[root@kur15z ~]#ssh -l root -p 22 114.215.80.214
#下面这条命令有点不一样,后面加了一条命令ls -l,此命令是在目标机器上执行的,但是显示到本地,执行后仍在本机。
[root@kur15z ~]#ssh 114.215.80.214 ls -l
#ssh -copy-id使用示例
[root@kur15z ~]#ssh-copy-id user@ip
[root@kur15z ~]#ssh-copy-id -i /root/.ssh/id_rsa.pub user@ip
ssh的使用的时候是受目标服务器控制的,细心看一下,上面在使用ssh示例演示的时候,进入到新的服务器时会有Last login的时间提示以及其它提示信息,这里都是在目标服务器上的配置起的作用。ssh的配置文件/etc/ssh/sshd_config中有如下配置项:
PrintMotd yes
PrintLastLog yes
#几项常用的配置,是否允许root用户ssh登录
#PermitRootLogin yes
PermitRootLogin no
#默认的ssh端口
Port 22
#以下两项配置使用no可加快ssh登录
UseDNS no
GSSAPIAuthentication no
#sshd的重启
[root@kur15z ~]# service sshd status
openssh-daemon (pid 1381) is running...
[root@kur15z ~]# service sshd restart
Stopping sshd: [ OK ]
Starting sshd: [ OK ]
[root@kur15z ~]#
PrintMotd即表示从远程登录此服务器时是否显示提示信息,打开此项后编辑文件:/etc/motd文件,此文件里即是提示的内容。PrintLastLog即表示自动显示上一次的最后登录时间,但是光打开这项不够,还需要在/var/log/文件夹里添加lastlog文件夹才能生效。在ssh的配置文件中还有几项常用:PermitRootLogin和Port端口设置、空闲超时时间等,修改sshd_config文件要生效是需要重启sshd的:service sshd restart
有一篇文章总结的挺全的,记录一下:https://www.cnblogs.com/kevingrace/p/6110842.html
这篇关于linux文本分析工具grep、sed和awk打印输出文本的单双奇偶行(grep也可以打印奇偶行)以及熟悉的ssh命令却有你不知道的一些用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!