逼格高又实用的 Linux 高级命令,开发运维都要懂

前言mysql


在运维的坑里摸爬滚打好几年了,我还记得我刚开始的时候,我只会使用一些简单的命令,写脚本的时候,也是要多简单有多简单,因此有时候写出来的脚本又长又臭。
linux

像一些高级点的命令,好比说 Xargs 命令、管道命令、自动应答命令等,若是当初我要是知道,那我也可能写出简洁高效的脚本。sql

无论出于任何缘由,我都想对一些 Linux 使用的高级命令进行用法说明,利人利己,之后不记得的话,我也能够回头翻来看看。数据库

1、实用的 xargs 命令api


在平时的使用中,我认为 xargs 这个命令仍是较为重要和方便的。咱们能够经过使用这个命令,将命令输出的结果做为参数传递给另外一个命令。安全

好比说咱们想找出某个路径下以 .conf 结尾的文件,并将这些文件进行分类,那么普通的作法就是先将以 .conf 结尾的文件先找出来,而后输出到一个文件中,接着 cat 这个文件,并使用 file 文件分类命令去对输出的文件进行分类。服务器

这个普通的方法还的确是略显麻烦,那么这个时候 xargs 命令就派上用场了。
例1:找出 / 目录下以 .conf 结尾的文件,并进行文件分类
命令:# find / -name *.conf -type f -print | xargs file
输出结果以下所示:网络

c28ad9daa01b3feff4b3f58686760c0e.jpeg

xargs 后面不只仅能够加文件分类的命令,你还能够加其余的不少命令,好比说实在一点的tar命令,你可使用find命令配合tar命令,将指定路径的特殊文件使用find命令找出来,而后配合tar命令将找出的文件直接打包,命令以下:app

# find / -name *.conf -type f -print | xargs tar cjf test.tar.gz运维

2、命令或脚本后台运行


有时候咱们进行一些操做的时候,不但愿咱们的操做在终端会话断了以后就跟着断了,特别是一些数据库导入导出操做,若是涉及到大数据量的操做,咱们不可能保证咱们的网络在咱们的操做期间不出问题,因此后台运行脚本或者命令对咱们来讲是一大保障。

好比说咱们想把数据库的导出操做后台运行,而且将命令的操做输出记录到文件,那么咱们能够这么作:
nohup mysqldump -uroot -pxxxxx —all-databases > ./alldatabases.sql &(xxxxx是密码)

固然若是你不想密码明文,你还能够这么作:
nohup mysqldump -uroot -pxxxxx —all-databases > ./alldatabases.sql (后面不加&符号)

执行了上述命令后,会提示叫你输入密码,输入密码后,该命令还在前台运行,可是咱们的目的是后天运行该命令,这个时候你能够按下Ctrl+Z,而后在输入bg就能够达到第一个命令的效果,让该命令后台运行,同时也可让密码隐蔽输入。

命令后台执行的结果会在命令执行的当前目录下留下一个nohup.out文件,查看这个文件就知道命令有没有执行报错等信息。

3、找出当前系统内存使用量较高的进程


在不少运维的时候,咱们发现内存耗用较为严重,那么怎么样才能找出内存消耗的进程排序呢?
命令:# ps -aux | sort -rnk 4 | head -20

280210ba9ae0cb4404d9e8852741dda5.jpeg

输出的第4列就是内存的耗用百分比。最后一列就是相对应的进程。


4、找出当前系统CPU使用量较高的进程


在不少运维的时候,咱们发现CPU耗用较为严重,那么怎么样才能找出CPU消耗的进程排序呢?
命令:# ps -aux | sort -rnk 3 | head -20

e4523935845ba8e38a6d01991dbd8d2d.jpeg

输出的第3列为CPU的耗用百分比,最后一列就是对应的进程。

我想你们应该也发现了,sort 命令后的三、4其实就是表明着第3列进行排序、第4列进行排序。

5、同时查看多个日志或数据文件


在平常工做中,咱们查看日志文件的方式多是使用tail命令在一个个的终端查看日志文件,一个终端就看一个日志文件。包括我在内也是,可是有时候也会以为这种方式略显麻烦,其实有个工具叫作multitail能够在同一个终端同时查看多个日志文件。

首先安装multitail:

# wget ftp://ftp.is.co.za/mirror/ftp.rpmforge.net/redhat/el6/en/x86_64/dag/RPMS/multitail-5.2.9-1.el6.rf.x86_64.rpm

# yum -y localinstall multitail-5.2.9-1.el6.rf.x86_64.rpm

multitail工具支持文本的高亮显示,内容过滤以及更多你可能须要的功能。

以下就来一个有用的例子:
此时咱们既想查看secure的日志指定过滤关键字输出,又想查看实时的网络ping状况:
命令以下:

# multitail -e "Accepted" /var/log/secure -l "ping baidu.com"

ae8fefc39a411bed999b5fbdaf97263b.jpeg是否是很方便?若是平时咱们想查看两个日志之间的关联性,能够观察日志输出是否有触发等。若是分开两个终端可能来回进行切换有点浪费时间,这个multitail工具查看何尝不是一个好方法。


6、持续ping并将结果记录到日志


不少时候,运维总会听到一个声音,是否是网络出什么问题了啊,致使业务出现怪异的症状,确定是服务器网络出问题了。这个就是俗称的背锅,业务出了问题,第一时间相关人员找不到缘由不少状况下就会把问题归结于服务器网络有问题。

这个时候你去ping几个包把结果丢出来,人家会反驳你,刚刚那段时间有问题而已,如今业务都恢复正常了,网络确定正常啊,这个时候估计你要气死。

你要是再拿出zabbix等网络监控的数据,这个时候就不太稳当了,zabbix的采集数据间隔你不可能设置成1秒钟1次吧?小编就遇到过这样的问题,结果我经过如下的命令进行了ping监控采集。

而后再有人让我背锅的时候,我把出问题时间段的ping数据库截取出来,你们公开谈,结果那次被我叼杠回去了,之后他们都不敢轻易甩锅了,这个感受好啊。

命令:
ping api.jpush.cn | awk ‘{ print $0”    “ strftime(“%Y-%m-%d %H:%M:%S”,systime()) } ‘ >> /tmp/jiguang.log &
输出的结果会记录到/tmp/jiguang.log 中,每秒钟新增一条ping记录,以下:

451a484ddb8b8f21113186fdee90202a.jpeg

7、查看tcp链接状态


指定查看80端口的tcp链接状态,有利于分析链接是否释放,或者***时进行状态分析。

命令:# netstat -nat |awk ‘{print $6}’|sort|uniq -c|sort -rn

5977f9cc3284a5b63fb802b59d9aaf0e.jpeg

8、查找80端口请求数最高的前20个IP


有时候业务的请求量忽然上去了,那么这个时候咱们能够查看下请求来源IP状况,若是是集中在少数IP上的,那么多是存在***行为,咱们使用防火墙就能够进行封禁。命令以下:

# netstat -anlp|grep 80|grep tcp|awk '{print $5}'|awk -F: '{print $1}'|sort|uniq -c|sort -nr|head -n20

f0d7214bb85e0754d67ce7c6e454cbe2.jpeg

9、ssh实现端口转发


可能不少的朋友都据说过ssh是linux下的远程登陆安全协议,就是通俗的远程登陆管理服务器。可是应该不多朋友会据说过ssh还能够作端口转发。其实ssh用来作端口转发的功能仍是很强大的,下面就来作示范。

实例背景:咱们公司是有堡垒机的,任何操做均须要在堡垒机上进行,有写开发人员须要访问ELasticSearch的head面板查看集群状态,可是咱们并不想将ElasticSearch的9200端口映射出去,依然想经过堡垒机进行访问。因此才会将通往堡垒机(192.168.1.15)的请求转发到服务器ElasticSearch(192.168.1.19)的9200上。

例子:
将发往本机(192.168.1.15)的9200端口访问转发到192.168.1.19的9200端口
ssh -p 22 -C -f -N -g -L 9200:192.168.1.19:9200 ihavecar@192.168.1.19
记住:前提是先进行秘钥传输。

命令执行完后,访问192.168.1.15:9200端口则真实是访问192.168.1.19:9200端口。

后续


此次就先记录到这里,下次有时间再继续进行整理和记录。


本文转载自:运维人生,www.ywadmin.com

相关文章
相关标签/搜索