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 1discover
  31534 2index
   1119 3yestest
   2136 4someuser
   3211 T9330+
     21 RACCUA
    111 P11HD
    321 4G
 kermit 007
 kermit 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 2index
   2136 4someuser
     21 RACCUA
    321 4G
 kermit 007.cn
007cn www.007.cn
#这样便匹配出了奇数行
[online@G18 ~]$ grep -n '' testnum.txt | grep  '[13579]:' | grep -o -E '[^:]*$'     
  35606 1discover
   1119 3yestest
   3211 T9330+
    111 P11HD
 kermit 007
007cn 007.cn

        对于awk,sed来说,匹配出奇偶行那是awk,sed的长项了。比如使用awk可以有多种方法来匹配。比如使用行记录号NR来判断,也可以使用自增变量来判断。

#通过NR值对2求余判断取奇数行
[online@G18 ~]$ awk 'NR%2' testnum.txt  
  35606 1discover
   1119 3yestest
   3211 T9330+
    111 P11HD
 kermit 007
007cn 007.cn
#下面这条命令取反,即是取的偶数行
[online@G18 ~]$ awk '!(NR%2)' testnum.txt 
#使用自增计算来判断奇偶行,如下取偶数行:
[online@G18 ~]$ awk 'i++%2' testnum.txt 
  31534 2index
   2136 4someuser
     21 RACCUA
    321 4G
 kermit 007.cn
007cn http://47.93.183.36
#如下则为取奇数行
[online@G18 ~]$ awk '!(i++%2)' testnum.txt
#换一个写法,使用++i来试一下,如下取的是奇数行
[online@G18 ~]$ awk '++i%2' testnum.txt       
  35606 1discover
   1119 3yestest
   3211 T9330+
    111 P11HD
 kermit 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 1discover
  31534 2index
[online@G18 ~]$ sed -n 1,+2p testnum.txt 
  35606 1discover
  31534 2index
   1119 3yestest
[online@G18 ~]$ sed -n 1~2p testnum.txt   
  35606 1discover
   1119 3yestest
   3211 T9330+
    111 P11HD
 kermit 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​

  • 12
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

林戈的IT生涯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值